Prechádzať zdrojové kódy

Since LFS started using docbook-1.78.1, there is a lot of unused data
in the stylesheet directory. Basically, a whole docbook-stylesheet is
there, while we need only fo and xhtml (+ some common dirs). Each time
we checkout the repo, we have to download this whole thing, which is by
far the biggest part of the repo (~33 M). By removing unused cruft,
this could be down to ~12 M.

Of course, it would be even better to remove completely the stylesheets
and use host ones (repo size down to 2M). but let's do this first, it is
easier :)


git-svn-id: http://svn.linuxfromscratch.org/LFS/trunk/BOOK@11778 4aa44e1e-78dd-0310-a6d2-fbcd4c07a689

Pierre Labastie 5 rokov pred
rodič
commit
2e524f93fc
100 zmenil súbory, kde vykonal 0 pridanie a 124434 odobranie
  1. 0 4
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/AUTHORS
  2. 0 21
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/BUGS
  3. 0 48
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/COPYING
  4. 0 88
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/INSTALL
  5. 0 89
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/Makefile
  6. 0 176
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/NEWS
  7. 0 18
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/NEWS.html
  8. 0 174
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/NEWS.xml
  9. 0 175
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/README
  10. 0 7523
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/RELEASE-NOTES-TMP.xml
  11. 0 20
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/RELEASE-NOTES.html
  12. 0 18790
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/RELEASE-NOTES.pdf
  13. 0 10546
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/RELEASE-NOTES.txt
  14. 0 7412
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/RELEASE-NOTES.xml
  15. 0 1
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/REVISION
  16. 0 23
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/TODO
  17. 0 115
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/VERSION
  18. 0 195
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/assembly/README
  19. 0 677
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/assembly/assemble.xsl
  20. 0 11035
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/assembly/schema/assembly51b7.rnc
  21. 0 12976
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/assembly/schema/docbook51b7.rnc
  22. 0 221
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/assembly/topic-maker-chunk.xsl
  23. 0 78
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/assembly/topic-maker.xsl
  24. 0 8
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/catalog.xml
  25. 0 10
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/docsrc/authors.xml
  26. 0 18
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/docsrc/copyright.xml
  27. 0 23
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/docsrc/license.xml
  28. BIN
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/docsrc/page.png
  29. 0 79
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/docsrc/reference.css
  30. 0 241
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/docsrc/reference.xml
  31. 0 35597
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/docsrc/reference.xml.included
  32. 0 11
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/docsrc/warranty.xml
  33. 0 306
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/eclipse/eclipse.xsl
  34. 0 111
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/eclipse/eclipse3.xsl
  35. 0 269
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/eclipse/profile-eclipse.xsl
  36. 0 88
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/epub/README
  37. 0 76
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/epub/bin/dbtoepub
  38. 0 227
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/epub/bin/lib/docbook.rb
  39. 0 12
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/epub/bin/xslt/obfuscate.xsl
  40. 0 1693
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/epub/docbook.xsl
  41. 0 329
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/epub3/README
  42. 0 29
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/epub3/chunk.xsl
  43. 0 69
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/epub3/chunkfast.xsl
  44. 0 142
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/epub3/docbook-epub.css.xml
  45. 0 19
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/epub3/docbook.xsl
  46. 0 51
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/epub3/epub3-chunk-mods.xsl
  47. 0 2506
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/epub3/epub3-element-mods.xsl
  48. 0 54
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/epub3/profile-chunk.xsl
  49. 0 408
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/epub3/profile-docbook.xsl
  50. 0 712
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/epub3/titlepage.templates.xml
  51. 0 3841
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/epub3/titlepage.templates.xsl
  52. 0 264
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/extensions/LICENSE.txt
  53. 0 12
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/extensions/NOTICE.txt
  54. 0 52
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/extensions/README.LIBXSLT
  55. 0 4
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/extensions/README.txt
  56. 0 239
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/extensions/docbook.py
  57. BIN
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/extensions/lucene-analyzers-3.0.0.jar
  58. BIN
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/extensions/lucene-core-3.0.0.jar
  59. BIN
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/extensions/saxon65.jar
  60. BIN
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/extensions/tagsoup-1.2.1.jar
  61. BIN
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/extensions/webhelpindexer.jar
  62. BIN
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/extensions/xalan27.jar
  63. 0 84
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/extensions/xslt.py
  64. 0 16
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/highlighting/README
  65. 0 95
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/highlighting/bourne-hl.xml
  66. 0 117
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/highlighting/c-hl.xml
  67. 0 187
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/highlighting/cmake-hl.xml
  68. 0 120
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/highlighting/common.xsl
  69. 0 151
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/highlighting/cpp-hl.xml
  70. 0 194
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/highlighting/csharp-hl.xml
  71. 0 176
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/highlighting/css21-hl.xml
  72. 0 220
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/highlighting/delphi-hl.xml
  73. 0 45
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/highlighting/ini-hl.xml
  74. 0 117
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/highlighting/java-hl.xml
  75. 0 147
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/highlighting/javascript-hl.xml
  76. 0 140
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/highlighting/lua-hl.xml
  77. 0 90
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/highlighting/m2-hl.xml
  78. 0 116
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/highlighting/myxml-hl.xml
  79. 0 120
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/highlighting/perl-hl.xml
  80. 0 154
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/highlighting/php-hl.xml
  81. 0 100
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/highlighting/python-hl.xml
  82. 0 109
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/highlighting/ruby-hl.xml
  83. 0 496
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/highlighting/sql1999-hl.xml
  84. 0 565
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/highlighting/sql2003-hl.xml
  85. 0 339
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/highlighting/sql92-hl.xml
  86. 0 180
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/highlighting/tcl-hl.xml
  87. 0 133
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/highlighting/upc-hl.xml
  88. 0 56
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/highlighting/xslthl-config.xml
  89. 0 1120
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/htmlhelp/htmlhelp-common.xsl
  90. 0 22
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/htmlhelp/htmlhelp.xsl
  91. 0 1083
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/htmlhelp/profile-htmlhelp-common.xsl
  92. 0 22
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/htmlhelp/profile-htmlhelp.xsl
  93. BIN
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/images/annot-close.png
  94. BIN
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/images/annot-open.png
  95. BIN
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/images/blank.png
  96. BIN
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/images/callouts/1.gif
  97. BIN
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/images/callouts/1.png
  98. 0 15
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/images/callouts/1.svg
  99. BIN
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/images/callouts/10.gif
  100. BIN
      stylesheets/lfs-xsl/docbook-xsl-1.78.1/images/callouts/10.png

+ 0 - 4
stylesheets/lfs-xsl/docbook-xsl-1.78.1/AUTHORS

@@ -1,4 +0,0 @@
-The DocBook XSL stylesheets are maintained by Norman Walsh,
-<ndw@nwalsh.com>, and members of the DocBook Project,
-<docbook-developers@sf.net>
-

+ 0 - 21
stylesheets/lfs-xsl/docbook-xsl-1.78.1/BUGS

@@ -1,21 +0,0 @@
-To view a list of all open DocBook Project XSL stylesheet bugs:
-
-  http://docbook.sf.net/tracker/xsl/bugs
-
-To submit a bug report against the stylesheets:
-
-  http://docbook.sf.net/tracker/submit/bug
-
-To do a full-text search of all DocBook Project issues:
-
-  http://docbook.sf.net/tracker/search
-
-Discussion about the DocBook Project XSL stylesheets takes place
-on the docbook-apps mailing list:
-
-  http://wiki.docbook.org/topic/DocBookAppsMailingList
-
-Real-time discussion takes place on IRC:
-
-  http://wiki.docbook.org/topic/DocBookIrcChannel
-  irc://irc.freenode.net/docbook

+ 0 - 48
stylesheets/lfs-xsl/docbook-xsl-1.78.1/COPYING

@@ -1,48 +0,0 @@
-Copyright
----------
-Copyright (C) 1999-2007 Norman Walsh
-Copyright (C) 2003 Jiří Kosek
-Copyright (C) 2004-2007 Steve Ball
-Copyright (C) 2005-2008 The DocBook Project
-Copyright (C) 2011-2012 O'Reilly Media
-
-Permission is hereby granted, free of charge, to any person
-obtaining a copy of this software and associated documentation
-files (the ``Software''), to deal in the Software without
-restriction, including without limitation the rights to use,
-copy, modify, merge, publish, distribute, sublicense, and/or
-sell copies of the Software, and to permit persons to whom the
-Software is furnished to do so, subject to the following
-conditions:
-
-The above copyright notice and this permission notice shall be
-included in all copies or substantial portions of the Software.
-
-Except as contained in this notice, the names of individuals
-credited with contribution to this software shall not be used in
-advertising or otherwise to promote the sale, use or other
-dealings in this Software without prior written authorization
-from the individuals in question.
-
-Any stylesheet derived from this Software that is publically
-distributed will be identified with a different name and the
-version strings in any derived Software will be changed so that
-no possibility of confusion between the derived package and this
-Software will exist.
-
-Warranty
---------
-THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
-EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
-OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
-NONINFRINGEMENT.  IN NO EVENT SHALL NORMAN WALSH OR ANY OTHER
-CONTRIBUTOR BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
-WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
-FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
-OTHER DEALINGS IN THE SOFTWARE.
-
-Contacting the Author
----------------------
-The DocBook XSL stylesheets are maintained by Norman Walsh,
-<ndw@nwalsh.com>, and members of the DocBook Project,
-<docbook-developers@sf.net>

+ 0 - 88
stylesheets/lfs-xsl/docbook-xsl-1.78.1/INSTALL

@@ -1,88 +0,0 @@
-$Id: INSTALL 6145 2006-08-06 13:13:03Z xmldoc $
-
-INSTALL file for the DocBook XSL stylesheets distribution
-
-----------------------------------------------------------------------
-Case #1: Installation using a package management system
-----------------------------------------------------------------------
-If you have installed the DocBook XSL distribution using "apt-get",
-"yum", "urpmi", or some similar package-management front-end,
-then, as part of the package installation, the stylesheets have
-already been automatically installed in the appropriate location
-for your system, and your XML catalog environment has probably
-been updated to use that location.
-
-----------------------------------------------------------------------
-Case #2: Installing manually
-----------------------------------------------------------------------
-If you have downloaded a docbook-xsl zip, tar.gz, or tar.bz2
-file, use the following steps to install it.
-
-  1. Move the zip, tar.gz, or tar.bz2 file to the directory where
-     you'd like to install it (not to a temporary directory).
-
-  2. unzip or untar/uncompress the file
-
-     That will create a docbook-xsl-$VERSION directory (where
-     $VERSION is the version number for the release).
-
-The remaining steps are all OPTIONAL. They are intended to
-automatically update your user environment with XML Catalog
-information about the DocBook XSL distribution. You are NOT
-REQUIRED to complete these remaining steps. However, if you do
-not, and you want to use XML catalogs with the DocBook XSL
-stylesheets, you will need to manually update your XML catalog
-environment
-
-  3. Change to the docbook-xsl-$VERSION directory and execute the
-     install.sh script:
-
-       ./install.sh
-
-     That will launch an interactive installer, which will emit a
-     series of prompts for you to respond to.
-
-     To instead run it non-interactively without being prompted
-     for confirmation of the changes it makes, invoke it with the
-     "--batch" switch, like this:
-
-       ./install.sh --batch
-
-     After the process is complete, the installer will emit a
-     message with a command you need to run in order to source
-     your environment for use with the stylesheets.
-
-  4. To test that he installation has updated your environment
-     correctly, execute the test.sh script:
-
-       ./test.sh
-
-     That will test your XML catalog environment, using both the
-     xmlcatalog application and the Apache XML Commons Resolver.
-
-     NOTE: The test.sh file is not created until the install.sh
-           file is run for the first time.
-
-  5. (UNINSTALLING) If/when you want to uninstall the release,
-     execute the uninstall.sh script.
-
-       ./uninstall.sh
-
-     To instead run it non-interactively without being prompted
-     for confirmation of the changes it makes, invoke it with the
-     "--batch" switch, like this:
-
-       ./uninstall.sh --batch
-
-     NOTE: The uninstall.sh file is not created until the install.sh
-           file is run for the first time.
-
-
-----------------------------------------------------------------------
-Note to packagers
-----------------------------------------------------------------------
-The install.sh, .CatalogManager.properties.example, and .urilist
-files should not be packaged. They are useful only to users who
-are installing the stylesheets manually.
-
-The catalog.xml file should be packaged.

+ 0 - 89
stylesheets/lfs-xsl/docbook-xsl-1.78.1/Makefile

@@ -1,89 +0,0 @@
-# $Id: Makefile.tests 8481 2009-07-13 20:18:41Z abdelazer $
-#
-# This makefile does a "smoketest" of stylesheets for various
-# output formats in the DocBook XSL Stylesheets release package.
-# It doesn't actually check the output -- it's just useful for
-# confirming whether each XSLT transformation actually executes
-# successfully without any errors.
-#
-# To use it, run "make check" or just "make"
-
-XSLTPROC=xsltproc
-XSLTPROC_FLAGS=
-
-TESTFILE=tests/refentry.007.xml
-TESTFILE_NS=tests/refentry.007.ns.xml
-
-NORMAL_STYLES=fo/docbook.xsl html/docbook.xsl xhtml/docbook.xsl
-NORMAL_PROFILE_STYLES=fo/profile-docbook.xsl html/profile-docbook.xsl xhtml/profile-docbook.xsl
-CHUNK_STYLES=html/chunk.xsl html/onechunk.xsl xhtml/chunk.xsl xhtml/onechunk.xsl
-HELP_STYLES=htmlhelp/htmlhelp.xsl javahelp/javahelp.xsl eclipse/eclipse.xsl
-MULTIFILE_STYLES=$(CHUNK_STYLES) $(HELP_STYLES)
-CHUNK_PROFILE_STYLES=html/profile-chunk.xsl html/profile-onechunk.xsl xhtml/profile-chunk.xsl xhtml/profile-onechunk.xsl
-HELP_PROFILE_STYLES=htmlhelp/profile-htmlhelp.xsl eclipse/profile-eclipse.xsl javahelp/profile-javahelp.xsl
-MULTIFILE_PROFILE_STYLES=$(CHUNK_PROFILE_STYLES) $(HELP_PROFILE_STYLES)
-
-MAN_STYLE=manpages/docbook.xsl
-MAN_PROFILE_STYLE=manpages/profile-docbook.xsl
-
-TWO_PROFILE_STYLE=profiling/profile.xsl 
-
-ROUNDTRIP_STYLES=roundtrip/dbk2ooo.xsl roundtrip/dbk2pages.xsl roundtrip/dbk2wordml.xsl
-SLIDES_STYLES=slides/html/default.xsl slides/xhtml/default.xsl slides/fo/plain.xsl
-WEBSITE_STYLES=website/website.xsl
-WEBSITE_CHUNK_STYLES=website/chunk-website.xsl
-
-# chunked output gets written to TMP_OUTPUT_DIR
-TMP_OUTPUT_DIR=/tmp/smoketest-output/
-# if you don't want TMP_OUTPUT_DIR and its contents deleted, unset
-# SMOKETEST_CLEAN_TARGET; e.g. "make check SMOKETEST_CLEAN_TARGET=''"
-SMOKETEST_CLEAN_TARGET=smoketest-clean
-
-check: smoketest-make-tmp-dir smoketest-normal smoketest-normal-profile smoketest-chunk smoketest-chunk-profile smoketest-man smoketest-man-profile smoketest-two-profile $(SMOKETEST_CLEAN_TARGET)
-
-smoketest-make-tmp-dir:
-	$(RM) -r $(TMP_OUTPUT_DIR)
-	mkdir '$(TMP_OUTPUT_DIR)'
-
-smoketest-normal:
-	for stylesheet in $(NORMAL_STYLES); do \
-	echo "$(XSLT) $(TESTFILE) $$stylesheet > /dev/null"; \
-	$(XSLT) $(TESTFILE) $$stylesheet > /dev/null; \
-	echo "$(XSLT) $(TESTFILE_NS) $$stylesheet > /dev/null"; \
-	$(XSLT) $(TESTFILE_NS) $$stylesheet > /dev/null; \
-	done
-
-smoketest-normal-profile:
-	for stylesheet in $(NORMAL_PROFILE_STYLES); do \
-	echo "$(XSLT) $(TESTFILE) $$stylesheet > /dev/null"; \
-	$(XSLT) $(TESTFILE) $$stylesheet > /dev/null; \
-	echo "$(XSLT) $(TESTFILE_NS) $$stylesheet > /dev/null"; \
-	$(XSLT) $(TESTFILE_NS) $$stylesheet > /dev/null; \
-	done
-
-smoketest-chunk:
-	for stylesheet in $(MULTIFILE_STYLES) ; do \
-	$(XSLT) $(TESTFILE) $$stylesheet manifest.in.base.dir=1 base.dir=$(TMP_OUTPUT_DIR) ; \
-	$(XSLT) $(TESTFILE_NS) $$stylesheet manifest.in.base.dir=1 base.dir=$(TMP_OUTPUT_DIR) ; \
-	done;
-
-smoketest-chunk-profile:
-	for stylesheet in $(MULTIFILE_PROFILE_STYLES) ; do \
-	$(XSLT) $(TESTFILE) $$stylesheet manifest.in.base.dir=1 base.dir=$(TMP_OUTPUT_DIR) ; \
-	$(XSLT) $(TESTFILE_NS) $$stylesheet manifest.in.base.dir=1 base.dir=$(TMP_OUTPUT_DIR) ; \
-	done;
-
-smoketest-man:
-	$(XSLT) $(TESTFILE) $(MAN_STYLE) man.output.in.separate.dir=1 man.output.base.dir=$(TMP_OUTPUT_DIR) ; \
-	$(XSLT) $(TESTFILE_NS) $(MAN_STYLE) man.output.in.separate.dir=1 man.output.base.dir=$(TMP_OUTPUT_DIR) ; 
-
-smoketest-man-profile:
-	$(XSLT) $(TESTFILE) $(MAN_PROFILE_STYLE) man.output.in.separate.dir=1 man.output.base.dir=$(TMP_OUTPUT_DIR) ; \
-	$(XSLT) $(TESTFILE_NS) $(MAN_PROFILE_STYLE) man.output.in.separate.dir=1 man.output.base.dir=$(TMP_OUTPUT_DIR) ; 
-
-smoketest-two-profile:
-	$(XSLT) $(TESTFILE_NS) $(TWO_PROFILE_STYLE) > /dev/null ; 
-
-smoketest-clean:
-	$(RM) -r $(TMP_OUTPUT_DIR)
-

+ 0 - 176
stylesheets/lfs-xsl/docbook-xsl-1.78.1/NEWS

@@ -1,176 +0,0 @@
-Changes since the 1.78.0 release
-
-Note: This document lists changes only since the 1.78.0 release. If you instead
-want a record of the complete list of changes for the codebase over its entire
-history, you can obtain one by running the following commands:
-
-  svn checkout https://docbook.svn.sourceforge.net/svnroot/docbook/trunk/xsl
-  svn log --xml --verbose xsl > ChangeHistory.xml
-
-━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
-
-Table of Contents
-
-Release Notes: 1.78.1
-
-    Common
-    FO
-    HTML
-    Manpages
-    Webhelp
-    Params
-    Highlighting
-
-Release Notes: 1.78.1
-
-The following is a list of changes that have been made since the 1.78.0
-release.
-
-Common
-
-The following changes have been made to the common code since the 1.78.0
-release.
-
-  • Robert Stayton: titles.xsl
-
-    Make sure part and set titleabbrev are used in mode="titleabbrev.markup"
-
-  • Robert Stayton: titles.xsl
-
-    Add empty default template for titleabbrev since it is always processed in a mode.
-
-  • Robert Stayton: gentext.xsl
-
-    Make consistent handling of titleabbrev in xrefs.
-
-  • Robert Stayton: titles.xsl
-
-    for missing title in xref, provide parent information of target to help locate problem element.
-    Process bridgehead in mode="title.markup", not normal mode.
-
-  • Jirka Kosek: l10n.xsl
-
-    Fixed bug #3598963
-
-  • Robert Stayton: gentext.xsl; labels.xsl
-
-    Make sure bridgeheads are not numbered in all contexts, including html title attributes.
-
-FO
-
-The following changes have been made to the fo code since the 1.78.0 release.
-
-  • Robert Stayton: division.xsl
-
-    Fix bug where part TOC not generated when partintro is present.
-
-  • Jirka Kosek: xref.xsl
-
-    Footnotes can't be placed into fo:float
-
-  • Robert Stayton: titlepage.templates.xml
-
-    Remove margin-left when start-indent is used because they interfere
-    with each other.
-
-  • Robert Stayton: fo.xsl; pagesetup.xsl
-
-    Use dingbat.fontset rather than dingbat.font.family so it falls
-    back to symbol font if glyph not found, like other font properties.
-
-  • Robert Stayton: inline.xsl
-
-    Change last instance of inline.charseq in inline glossterm to
-    inline.italicseq so it is consistent with the others.
-
-  • Robert Stayton: xref.xsl
-
-    Make consistent handling of titleabbrev in xrefs.
-
-HTML
-
-The following changes have been made to the html code since the 1.78.0 release.
-
-  • Robert Stayton: admon.xsl
-
-    Turn off $admon.style if $make.clean.html is set to non-zero.
-
-  • Jirka Kosek: highlight.xsl
-
-    Added new definitions for syntax highlighting
-
-  • Robert Stayton: chunk-common.xsl
-
-    Make active.olink.hrefs param work for chunked output too.
-
-  • Robert Stayton: xref.xsl
-
-    Make consistent handling of titleabbrev in xrefs.
-
-  • Robert Stayton: graphics.xsl
-
-    Add round() function when pixel counts are used for image width and height.
-
-  • Robert Stayton: glossary.xsl
-
-    fix missing class and id attributes on glossterm and glossdef.
-
-  • Robert Stayton: autoidx.xsl
-
-    Fix bug where prefer.index.titleabbrev ignored info/titleabbrev.
-
-Manpages
-
-The following changes have been made to the manpages code since the 1.78.0
-release.
-
-  • Robert Stayton: utility.xsl
-
-    Fix bug 3599520: spurious newline in para when starts with
-    whitespace and inline element.
-
-Webhelp
-
-The following changes have been made to the webhelp code since the 1.78.0
-release.
-
-  • David Cramer: xsl/webhelp-common.xsl
-
-    Webhelp: Fix test for webhelp.include.search.tab param
-
-  • David Cramer: Makefile.sample
-
-    Webhelp: Fix order of args to xsltproc
-
-  • David Cramer: docsrc/readme.xml
-
-    Webhelp: Turn on xinclude-test.xml in readme to demo xinclude functionality
-
-  • David Cramer: Makefile; Makefile.sample
-
-    Webhelp: In Makefiles, do xinclude in first pass at document
-
-Params
-
-The following changes have been made to the params code since the 1.78.0
-release.
-
-  • David Cramer: webhelp.include.search.tab.xml
-
-    Webhelp: Fix test for webhelp.include.search.tab param
-
-  • Robert Stayton: article.appendix.title.properties.xml
-
-    Remove unneeded margin-left property from article appendix title.
-    It interferes with the start-indent property.
-
-Highlighting
-
-The following changes have been made to the highlighting code since the 1.78.0
-release.
-
-  • Jirka Kosek: c-hl.xml; cpp-hl.xml; sql2003-hl.xml; php-hl.xml; upc-hl.xml;
-    bourne-hl.xml; ⋯
-
-    Added new definitions for syntax highlighting
-

Rozdielové dáta súboru neboli zobrazené, pretože súbor je príliš veľký
+ 0 - 18
stylesheets/lfs-xsl/docbook-xsl-1.78.1/NEWS.html


+ 0 - 174
stylesheets/lfs-xsl/docbook-xsl-1.78.1/NEWS.xml

@@ -1,174 +0,0 @@
-<?xml version="1.0"?>
-
-<article>
-<info>
-<abstract>
-<para><emphasis role="strong">Note:</emphasis> This
-            document lists changes only since the 1.78.0 release.
-            If you instead want a record of the complete list of
-            changes for the codebase over its entire history, you
-            can obtain one by running the following commands:
-            
-<screen>  <code>svn checkout https://docbook.svn.sourceforge.net/svnroot/docbook/trunk/xsl</code>
-  <code>svn log --xml --verbose xsl &gt; ChangeHistory.xml</code></screen></para>
-</abstract>
-</info><title>Changes since the 1.78.0 release</title>
-
-<sect1 xml:id="V1.78.1">
-<title>Release Notes: 1.78.1</title>
-<para>The following is a list of changes that have been made
-        since the 1.78.0 release.</para>
-
-<sect2 xml:id="V1.78.1_Common">
-<title>Common</title>
-<para>The following changes have been made to the
-            <filename>common</filename> code
-            since the 1.78.0 release.</para>
-<itemizedlist>
-<listitem>
-<para><literal>Robert Stayton: titles.xsl</literal></para><screen><phrase role="commit-message">Make sure part and set <tag>titleabbrev</tag> are used in mode="titleabbrev.markup"</phrase></screen>
-</listitem>
-<listitem>
-<para><literal>Robert Stayton: titles.xsl</literal></para><screen><phrase role="commit-message">Add empty default template for <tag>titleabbrev</tag> since it is always processed in a mode.</phrase></screen>
-</listitem>
-<listitem>
-<para><literal>Robert Stayton: gentext.xsl</literal></para><screen><phrase role="commit-message">Make consistent handling of <tag>titleabbrev</tag> in xrefs.</phrase></screen>
-</listitem>
-<listitem>
-<para><literal>Robert Stayton: titles.xsl</literal></para><screen><phrase role="commit-message">for missing <tag>title</tag> in <tag>xref</tag>, provide parent information of target to help locate problem element.
-Process <tag>bridgehead</tag> in mode="title.markup", not normal mode.</phrase></screen>
-</listitem>
-<listitem>
-<para><literal>Jirka Kosek: l10n.xsl</literal></para><screen><phrase role="commit-message">Fixed bug #3598963</phrase></screen>
-</listitem>
-<listitem>
-<para><literal>Robert Stayton: gentext.xsl; labels.xsl</literal></para><screen><phrase role="commit-message">Make sure bridgeheads are not numbered in all contexts, including html <tag>title</tag> attributes.</phrase></screen>
-</listitem>
-</itemizedlist>
-</sect2><!--end of Common changes for 1.78.1-->
-
-<sect2 xml:id="V1.78.1_FO">
-<title>FO</title>
-<para>The following changes have been made to the
-            <filename>fo</filename> code
-            since the 1.78.0 release.</para>
-<itemizedlist>
-<listitem>
-<para><literal>Robert Stayton: division.xsl</literal></para><screen><phrase role="commit-message">Fix bug where part <tag>TOC</tag> not generated when <tag>partintro</tag> is present.</phrase></screen>
-</listitem>
-<listitem>
-<para><literal>Jirka Kosek: xref.xsl</literal></para><screen><phrase role="commit-message">Footnotes can't be placed into fo:float</phrase></screen>
-</listitem>
-<listitem>
-<para><literal>Robert Stayton: titlepage.templates.xml</literal></para><screen><phrase role="commit-message">Remove margin-left when start-indent is used because they interfere
-with each other.</phrase></screen>
-</listitem>
-<listitem>
-<para><literal>Robert Stayton: fo.xsl; pagesetup.xsl</literal></para><screen><phrase role="commit-message">Use dingbat.fontset rather than <parameter>dingbat.font.family</parameter> so it falls
-back to <tag>symbol</tag> font if glyph not found, like other font properties.</phrase></screen>
-</listitem>
-<listitem>
-<para><literal>Robert Stayton: inline.xsl</literal></para><screen><phrase role="commit-message">Change last instance of inline.charseq in inline <tag>glossterm</tag> to 
-inline.italicseq so it is consistent with the others.</phrase></screen>
-</listitem>
-<listitem>
-<para><literal>Robert Stayton: xref.xsl</literal></para><screen><phrase role="commit-message">Make consistent handling of <tag>titleabbrev</tag> in xrefs.</phrase></screen>
-</listitem>
-</itemizedlist>
-</sect2><!--end of FO changes for 1.78.1-->
-
-<sect2 xml:id="V1.78.1_HTML">
-<title>HTML</title>
-<para>The following changes have been made to the
-            <filename>html</filename> code
-            since the 1.78.0 release.</para>
-<itemizedlist>
-<listitem>
-<para><literal>Robert Stayton: admon.xsl</literal></para><screen><phrase role="commit-message">Turn off $admon.style if $make.clean.html is set to non-zero.</phrase></screen>
-</listitem>
-<listitem>
-<para><literal>Jirka Kosek: highlight.xsl</literal></para><screen><phrase role="commit-message">Added new definitions for syntax highlighting</phrase></screen>
-</listitem>
-<listitem>
-<para><literal>Robert Stayton: chunk-common.xsl</literal></para><screen><phrase role="commit-message">Make active.olink.hrefs param work for chunked output too.</phrase></screen>
-</listitem>
-<listitem>
-<para><literal>Robert Stayton: xref.xsl</literal></para><screen><phrase role="commit-message">Make consistent handling of <tag>titleabbrev</tag> in xrefs.</phrase></screen>
-</listitem>
-<listitem>
-<para><literal>Robert Stayton: graphics.xsl</literal></para><screen><phrase role="commit-message">Add round() <tag>function</tag> when pixel counts are used for image width and height.</phrase></screen>
-</listitem>
-<listitem>
-<para><literal>Robert Stayton: glossary.xsl</literal></para><screen><phrase role="commit-message">fix missing class and id attributes on <tag>glossterm</tag> and <tag>glossdef</tag>.</phrase></screen>
-</listitem>
-<listitem>
-<para><literal>Robert Stayton: autoidx.xsl</literal></para><screen><phrase role="commit-message">Fix bug where prefer.index.titleabbrev ignored <tag>info</tag>/<tag>titleabbrev</tag>.</phrase></screen>
-</listitem>
-</itemizedlist>
-</sect2><!--end of HTML changes for 1.78.1-->
-
-<sect2 xml:id="V1.78.1_Manpages">
-<title>Manpages</title>
-<para>The following changes have been made to the
-            <filename>manpages</filename> code
-            since the 1.78.0 release.</para>
-<itemizedlist>
-<listitem>
-<para><literal>Robert Stayton: utility.xsl</literal></para><screen><phrase role="commit-message">Fix bug 3599520: spurious newline in <tag>para</tag> when starts with
-whitespace and inline element.</phrase></screen>
-</listitem>
-</itemizedlist>
-</sect2><!--end of Manpages changes for 1.78.1-->
-
-<sect2 xml:id="V1.78.1_Webhelp">
-<title>Webhelp</title>
-<para>The following changes have been made to the
-            <filename>webhelp</filename> code
-            since the 1.78.0 release.</para>
-<itemizedlist>
-<listitem>
-<para><literal>David Cramer: xsl/webhelp-common.xsl</literal></para><screen><phrase role="commit-message">Webhelp: Fix test for <parameter>webhelp.include.search.tab</parameter> param</phrase></screen>
-</listitem>
-<listitem>
-<para><literal>David Cramer: Makefile.sample</literal></para><screen><phrase role="commit-message">Webhelp: Fix order of args to xsltproc</phrase></screen>
-</listitem>
-<listitem>
-<para><literal>David Cramer: docsrc/readme.xml</literal></para><screen><phrase role="commit-message">Webhelp: Turn on xinclude-test.xml in readme to demo xinclude functionality</phrase></screen>
-</listitem>
-<listitem>
-<para><literal>David Cramer: Makefile; Makefile.sample</literal></para><screen><phrase role="commit-message">Webhelp: In Makefiles, do xinclude in first pass at document</phrase></screen>
-</listitem>
-</itemizedlist>
-</sect2><!--end of Webhelp changes for 1.78.1-->
-
-<sect2 xml:id="V1.78.1_Params">
-<title>Params</title>
-<para>The following changes have been made to the
-            <filename>params</filename> code
-            since the 1.78.0 release.</para>
-<itemizedlist>
-<listitem>
-<para><literal>David Cramer: webhelp.include.search.tab.xml</literal></para><screen><phrase role="commit-message">Webhelp: Fix test for <parameter>webhelp.include.search.tab</parameter> param</phrase></screen>
-</listitem>
-<listitem>
-<para><literal>Robert Stayton: article.appendix.title.properties.xml</literal></para><screen><phrase role="commit-message">Remove unneeded margin-left property from <tag>article</tag> <tag>appendix</tag> <tag>title</tag>.
-It interferes with the start-indent property.</phrase></screen>
-</listitem>
-</itemizedlist>
-</sect2><!--end of Params changes for 1.78.1-->
-
-<sect2 xml:id="V1.78.1_Highlighting">
-<title>Highlighting</title>
-<para>The following changes have been made to the
-            <filename>highlighting</filename> code
-            since the 1.78.0 release.</para>
-<itemizedlist>
-<listitem>
-<para><literal>Jirka Kosek: c-hl.xml; cpp-hl.xml; sql2003-hl.xml; php-hl.xml; upc-hl.xml; bourne-hl.xml; ⋯</literal></para><screen><phrase role="commit-message">Added new definitions for syntax highlighting</phrase></screen>
-</listitem>
-</itemizedlist>
-</sect2><!--end of Highlighting changes for 1.78.1-->
-
-</sect1>
-</article>
-

+ 0 - 175
stylesheets/lfs-xsl/docbook-xsl-1.78.1/README

@@ -1,175 +0,0 @@
-----------------------------------------------------------------------
-              README file for the DocBook XSL Stylesheets
-----------------------------------------------------------------------
-$Id: README 9731 2013-03-17 05:01:54Z bobstayton $
-
-These are XSL stylesheets for transforming DocBook XML document
-instances into various output formats.
-
-This README file provides only very minimal documentation on using
-the stylesheets. For more complete information, see Bob Stayton's
-book "DocBook XSL: The Complete Guide", available online at:
-
-  http://www.sagehill.net/docbookxsl/
-
-----------------------------------------------------------------------
-Installation
-----------------------------------------------------------------------
-See the INSTALL file for information about installing this release.
-
-----------------------------------------------------------------------
-How to use the stylesheets
-----------------------------------------------------------------------
-The base canonical URI for these stylesheets is:
-
-  http://docbook.sourceforge.net/release/xsl/current/
-
-You call any of the stylesheets in this distribution by doing one
-of the following:
-
-  - Use the base canonical URI in combination with one of the
-    pathnames below. For example, for "chunked" HTML, output:
-
-    http://docbook.sourceforge.net/release/xsl/current/html/chunk.xsl
-
-    If your system has a working XML Catalog or SGML Catalog setup
-    (most Linux systems do), then that URI will automatically be
-    resolved and replaced with a local pathname on your system.
-
-  - Use a "real" local system base path in combination with one of
-    the pathnames below. For example, for "chunked" HTML, output:
-
-    /usr/share/xml/docbook/stylesheet/nwalsh/html/chunk.xsl
-
-To transform documents created with the standard DocBook
-schema/DTD, use one of the following stylesheets:
-
-  fo/docbook.xsl              - for XSL-FO
-
-  html/docbook.xsl            - for HTML (as a single file)
-  html/chunk.xsl              - for HTML (chunked into multiple files)
-  html/onechunk.xsl           - for HTML (chunked output in single file)
-
-  xhtml/*.xsl                 - for XHTML versions of the above
-
-  xhtml-1_1/*.xsl             - for XHTML 1.1 versions of the above
-
-  xhtml5/*.xsl                 - for XHTML5 versions of the above
-
-  epub/docbook.xsl            - for .epub version 2 and earlier
-  epub3/docbook.xsl           - for .epub version 3 and later
-
-  htmlhelp/htmlhelp.xsl       - for HTML Help
-  javahelp/javahelp.xsl       - for JavaHelp
-  eclipse/eclipse.xsl         - for Eclipse Help
-
-  manpages/docbook.xsl        - for groff/nroff man pages
-
-  */profile-*                 - single-pass-profiling versions of all above
-
-  roundtrip/*.xsl             - for DocBook to WordML, etc., to DocBook
-
-  assembly/assemble.xsl       - converts an assembly into a DocBook document
-  assembly/topic-maker-chunk.xsl
-                              - converts a DocBook document into an assembly
-                                with topic files.
-
-  webhelp/build.xml           - Ant script to generate webhelp output.  
-  webhelp/Makefile            - Makefile to generate webhelp output.
-
-To transform documents created with the DocBook Slides schema/DTD,
-use one of the following stylesheets:
-
-  slides/xhtml/*.xsl          - for XHTML slides of various kinds
-  slides/fo/plain.xsl         - for XSL-FO slides
-
-To transform documents created with the DocBook Website
-schema/DTD, use one of the following stylesheets:
-
-  website/website.xsl         - for non-tabular, non-chunked output
-  website/tabular.xsl         - for tabular, non-chunked output
-  website/chunk-*             - for chunked output
-
-To generate a titlepage customization layer from a titlepage spec:
-
-  template/titlepage.xsl
-
-For fo titlepage customizations, set the stylesheet parameter named 'ns'
-to 'http://www.w3.org/1999/XSL/Format' when using this stylesheet.
-For xhtml titlepage customizations, set the stylesheet parameter named 'ns'
-to 'http://www.w3.org/1999/xhtml' when using this stylesheet.
-
-For details about creating titlepage spec files and generating and
-using titlepage customization layers, see "DocBook XSL: The
-Complete Guide" <http://www.sagehill.net/docbookxsl/>
-
-----------------------------------------------------------------------
-Manifest
-----------------------------------------------------------------------
-AUTHORS       contact information
-BUGS          about known problems
-COPYING       copyright information
-INSTALL       installation instructions
-README        this file
-RELEASE.*     per-release cumulative summaries of user-visible changes
-TODO          about planned features not yet implemented
-VERSION       release metadata, including the current version
-              number (note that the VERSION file is an XSL stylesheet)
-NEWS          changes since the last public release (for a cumulative list of
-              changes, see the ChangeHistory.xml file)
-
-assembly/     for making and processing DocBook assemblies.
-common/       code used among several output formats (HTML, FO, manpages,...)
-docsrc/       documentation sources
-eclipse/      for producing Eclipse Help
-epub/         for producing .epub version 2.
-epub3/        for producing .epub version 3 and beyond.
-extensions/   DocBook XSL Java extensions
-fo/           for producing XSL-FO
-highlighting  files used for adding source-code syntax highlighting in output
-html/         for producing HTML
-htmlhelp/     for producing HTML Help
-images/       images used in callouts and graphical admonitions
-javahelp/     for producing Java Help
-lib/          utility stylesheets with schema-independent functions
-manpages/     for producing groff/troff man pages
-profiling/    for profiling (omitting/including conditional text)
-roundtrip/    for "round trip" conversion among DocBook and
-              various word-processor formats (WordML, etc.)
-slides/       for producing slides output (from Slides source)
-template/     templates for building stylesheet customization layers
-tools/        assorted supplementary tools
-webhelp/      templates and scripts for generating webhelp output
-website/      for producing website output (from Website source)
-xhtml/        for producing XHTML
-xhtml-1_1/    for producing (stricter) XHTML 1.1
-xhtml5/       for producing XHTML5
-
-----------------------------------------------------------------------
-Changes
-----------------------------------------------------------------------
-See the NEWS file for changes made since the previous release.
-
-See the RELEASE-NOTES.html or RELEASE-NOTES.txt or RELEASE-NOTES.pdf
-files for per-release cumulative summaries of significant
-user-visible changes.
-
-For online access to a hyperlinked view of all changes made over
-the entire history of the codebase, see the following:
-
-  http://docbook.svn.sourceforge.net/viewvc/docbook/trunk/xsl/?view=log
-
-WARNING: That above change history is a very long list and may
-take a long time to load/download.
-
-You can also create an XML-formatted "ChangeHistory.xml" copy of
-the complete change history for the codebase by running the
-following commands:
-
-  svn checkout https://docbook.svn.sf.net/svnroot/docbook/trunk/xsl
-  svn log --xml --verbose xsl > ChangeHistory.xml
-
-----------------------------------------------------------------------
-Copyright information
-----------------------------------------------------------------------
-See the accompanying file named COPYING.

Rozdielové dáta súboru neboli zobrazené, pretože súbor je príliš veľký
+ 0 - 7523
stylesheets/lfs-xsl/docbook-xsl-1.78.1/RELEASE-NOTES-TMP.xml


Rozdielové dáta súboru neboli zobrazené, pretože súbor je príliš veľký
+ 0 - 20
stylesheets/lfs-xsl/docbook-xsl-1.78.1/RELEASE-NOTES.html


Rozdielové dáta súboru neboli zobrazené, pretože súbor je príliš veľký
+ 0 - 18790
stylesheets/lfs-xsl/docbook-xsl-1.78.1/RELEASE-NOTES.pdf


+ 0 - 10546
stylesheets/lfs-xsl/docbook-xsl-1.78.1/RELEASE-NOTES.txt

@@ -1,10546 +0,0 @@
-Release Notes for the DocBook XSL Stylesheets
-
-$Revision$ $Date$
-
-2013-03-17
-
-This release-notes document is available in the following formats: HTML, PDF,
-plain text; it provides a per-release list of enhancements and changes to the
-stylesheets’ public APIs (user-configurable parameters) and excludes
-descriptions of most bug fixes. For a complete list of all changes (including
-all bug fixes) that have been made since the previous release, see the separate
-NEWS (plain text) or NEWS.html files. Also available: An online hyperlinked
-change history (warning: big file) of all changes made over the entire history
-of the codebase.
-
-As with all DocBook Project “dot one plus” releases, this release aspires to be
-stable (in contrast to dot-zero releases, which are experimental).
-
-━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
-
-Table of Contents
-
-Release Notes: 1.78.1
-
-    Common
-    FO
-    HTML
-    Manpages
-    Webhelp
-    Params
-    Highlighting
-
-Release Notes: 1.78.0
-
-    Gentext
-    Common
-    FO
-    HTML
-    Manpages
-    Roundtrip
-    Slides
-    Webhelp
-    Params
-    Profiling
-    Tools
-    Template
-
-Release Notes: 1.77.1
-
-    Gentext
-    Common
-    FO
-    HTML
-    Epub
-    HTMLHelp
-    Eclipse
-    JavaHelp
-    Webhelp
-    Params
-    Highlighting
-    Profiling
-    Lib
-    Template
-    Extensions
-    XSL-Saxon
-
-Release Notes: 1.77.1
-
-    FO
-    HTML
-    Roundtrip
-    Slides
-    Website
-    Webhelp
-
-Release Notes: 1.76.1
-
-    FO
-    HTML
-    Params
-
-Release Notes: 1.76.0
-
-    Gentext
-    Common
-    FO
-    HTML
-    Manpages
-    Epub
-    Eclipse
-    Params
-    XSL-Xalan
-
-Release Notes: 1.75.2
-
-    Gentext
-    Common
-    FO
-    HTML
-    Manpages
-    Epub
-    Profiling
-    XSL-Saxon
-    XSL-Xalan
-
-Release Notes: 1.75.1
-
-    FO
-    HTML
-    Epub
-    Params
-
-Release Notes: 1.75.0
-
-    Gentext
-    Common
-    FO
-    HTML
-    Manpages
-    ePub
-    HTMLHelp
-    Params
-    Highlighting
-    XSL-Saxon
-    XSL-Xalan
-
-Release Notes: 1.74.3
-Release Notes: 1.74.2
-Release Notes: 1.74.1
-
-    Gentext
-    FO
-    HTML
-    Manpages
-    ePub
-    Roundtrip
-    Params
-    Highlighting
-
-Release Notes: 1.74.0
-
-    Gentext
-    Common
-    FO
-    HTML
-    Manpages
-    Epub
-    HTMLHelp
-    Eclipse
-    JavaHelp
-    Roundtrip
-    Slides
-    Website
-    Params
-    Profiling
-    Tools
-    Extensions
-    XSL-Saxon
-    XSL-Xalan
-    XSL-libxslt
-
-Release Notes: 1.73.2
-Release: 1.73.1
-
-    Gentext
-    FO
-    HTML
-    Manpages
-    HTMLHelp
-    Eclipse
-    JavaHelp
-    Roundtrip
-    Params
-
-Release: 1.73.0
-
-    Gentext
-    Common
-    FO
-    HTML
-    Manpages
-    Eclipse
-    JavaHelp
-    Roundtrip
-    Params
-    Highlighting
-    Profiling
-    Lib
-    Tools
-    XSL-Saxon
-    XSL-Xalan
-
-Release: 1.72.0
-
-    Common
-    FO
-    HTML
-    Manpages
-    Params
-    Template
-    Roundtrip
-
-Release: 1.71.1
-
-    Common
-    FO
-    HTML
-    Highlighting
-    Manpages
-    Params
-    Profiling
-
-Release: 1.71.0
-
-    Common
-    Extensions
-    FO
-    HTML
-    Highlighting
-    Manpages
-    Params
-    Tools
-
-Release: 1.70.1
-
-    FO
-    HTML
-    HTMLHelp
-    Params
-
-Release: 1.70.0
-
-    Common
-    Extensions
-    FO
-    HTML
-    Manpages
-    Params
-    Profiling
-    Tools
-    WordML
-
-Release 1.69.1
-Release 1.69.0
-
-    Common
-    FO
-    Help
-    HTML
-    man
-
-Release 1.68.1
-Release 1.68.0
-Release 1.67.2
-Release 1.67.1
-Release 1.67.0
-Release 1.66.1
-Release 1.65.0
-Release 1.64.1
-Release 1.61.0
-Release 1.60.1
-Release 1.59.2
-Release 1.59.1
-Release 1.58.0
-Release 1.57.0
-Release 1.56.0
-Older releases
-About dot-zero releases
-
-Release Notes: 1.78.1
-
-The following is a list of changes that have been made since the 1.78.0
-release.
-
-Common
-
-The following changes have been made to the common code since the 1.78.0
-release.
-
-  • Robert Stayton: titles.xsl
-
-    Make sure part and set titleabbrev are used in mode="titleabbrev.markup"
-
-  • Robert Stayton: titles.xsl
-
-    Add empty default template for titleabbrev since it is always processed in a mode.
-
-  • Robert Stayton: gentext.xsl
-
-    Make consistent handling of titleabbrev in xrefs.
-
-  • Robert Stayton: titles.xsl
-
-    for missing title in xref, provide parent information of target to help locate problem element.
-    Process bridgehead in mode="title.markup", not normal mode.
-
-  • Jirka Kosek: l10n.xsl
-
-    Fixed bug #3598963
-
-  • Robert Stayton: gentext.xsl; labels.xsl
-
-    Make sure bridgeheads are not numbered in all contexts, including html title attributes.
-
-FO
-
-The following changes have been made to the fo code since the 1.78.0 release.
-
-  • Robert Stayton: division.xsl
-
-    Fix bug where part TOC not generated when partintro is present.
-
-  • Jirka Kosek: xref.xsl
-
-    Footnotes can't be placed into fo:float
-
-  • Robert Stayton: titlepage.templates.xml
-
-    Remove margin-left when start-indent is used because they interfere
-    with each other.
-
-  • Robert Stayton: fo.xsl; pagesetup.xsl
-
-    Use dingbat.fontset rather than dingbat.font.family so it falls
-    back to symbol font if glyph not found, like other font properties.
-
-  • Robert Stayton: inline.xsl
-
-    Change last instance of inline.charseq in inline glossterm to
-    inline.italicseq so it is consistent with the others.
-
-  • Robert Stayton: xref.xsl
-
-    Make consistent handling of titleabbrev in xrefs.
-
-HTML
-
-The following changes have been made to the html code since the 1.78.0 release.
-
-  • Robert Stayton: admon.xsl
-
-    Turn off $admon.style if $make.clean.html is set to non-zero.
-
-  • Jirka Kosek: highlight.xsl
-
-    Added new definitions for syntax highlighting
-
-  • Robert Stayton: chunk-common.xsl
-
-    Make active.olink.hrefs param work for chunked output too.
-
-  • Robert Stayton: xref.xsl
-
-    Make consistent handling of titleabbrev in xrefs.
-
-  • Robert Stayton: graphics.xsl
-
-    Add round() function when pixel counts are used for image width and height.
-
-  • Robert Stayton: glossary.xsl
-
-    fix missing class and id attributes on glossterm and glossdef.
-
-  • Robert Stayton: autoidx.xsl
-
-    Fix bug where prefer.index.titleabbrev ignored info/titleabbrev.
-
-Manpages
-
-The following changes have been made to the manpages code since the 1.78.0
-release.
-
-  • Robert Stayton: utility.xsl
-
-    Fix bug 3599520: spurious newline in para when starts with
-    whitespace and inline element.
-
-Webhelp
-
-The following changes have been made to the webhelp code since the 1.78.0
-release.
-
-  • David Cramer: xsl/webhelp-common.xsl
-
-    Webhelp: Fix test for webhelp.include.search.tab param
-
-  • David Cramer: Makefile.sample
-
-    Webhelp: Fix order of args to xsltproc
-
-  • David Cramer: docsrc/readme.xml
-
-    Webhelp: Turn on xinclude-test.xml in readme to demo xinclude functionality
-
-  • David Cramer: Makefile; Makefile.sample
-
-    Webhelp: In Makefiles, do xinclude in first pass at document
-
-Params
-
-The following changes have been made to the params code since the 1.78.0
-release.
-
-  • David Cramer: webhelp.include.search.tab.xml
-
-    Webhelp: Fix test for webhelp.include.search.tab param
-
-  • Robert Stayton: article.appendix.title.properties.xml
-
-    Remove unneeded margin-left property from article appendix title.
-    It interferes with the start-indent property.
-
-Highlighting
-
-The following changes have been made to the highlighting code since the 1.78.0
-release.
-
-  • Jirka Kosek: c-hl.xml; cpp-hl.xml; sql2003-hl.xml; php-hl.xml; upc-hl.xml;
-    bourne-hl.xml; ⋯
-
-    Added new definitions for syntax highlighting
-
-Release Notes: 1.78.0
-
-The following is a list of changes that have been made since the 1.77.1
-release.
-
-Gentext
-
-The following changes have been made to the gentext code since the 1.77.1
-release.
-
-  • Mauritz Jeanson: locale/nn.xml; locale/nb.xml
-
-    Bug #3556630: Updated nb and nn locale files.
-
-  • Mauritz Jeanson: locale/README
-
-    Bug #3556628: Updated information in README.
-
-  • tom_schr: locale/de.xml
-
-    Added keycap context from RFE#3540451 to support @function attribute
-
-  • tom_schr: locale/en.xml
-
-    Added keycap context from RFE#3540451 to support @function attribute
-
-  • Robert Stayton: locale/en.xml
-
-    Add support for title element in screenshot, now allowed in DocBook 5.
-
-Common
-
-The following changes have been made to the common code since the 1.77.1
-release.
-
-  • Robert Stayton: titles.xsl
-
-    Corrected template for bridgehead in mode="title.markup" to
-    process its children in normal mode.
-
-  • Robert Stayton: labels.xsl
-
-    Convert hard wired xsl:number for production into a template
-    with mode="label.markup" to be consistent with other element numbering.
-
-  • Robert Stayton: olink.xsl
-
-    Remove all references and code for obsolete olink attributes
-    @linkmode @targetdocent and @localinfo.
-
-  • Robert Stayton: olink.xsl
-
-    Add parameter 'activate.external.olinks' to allow making
-    external olinks inactive, as for epub output.
-
-FO
-
-The following changes have been made to the fo code since the 1.77.1 release.
-
-  • Robert Stayton: pagesetup.xsl
-
-    Change initial page number for book from 1 to auto so front
-    cover and title pages are sequential, and so that book inside
-    set will continue numbering.
-
-  • Robert Stayton: inline.xsl
-
-    Add missing closing tag for xsl:choose in new template.
-
-  • Robert Stayton: param.xweb; param.ent; pagesetup.xsl
-
-    Add force.blank.pages parameter to allow turning off blank
-    pages in double.sided output.
-
-  • Robert Stayton: lists.xsl; callout.xsl
-
-    Implement active links between co and callout elements for
-    PDF output, linking in both directions.
-
-  • Robert Stayton: table.xsl
-
-    Fix typo to replace "ro" with "row" in three places.
-
-  • Robert Stayton: ebnf.xsl
-
-    Convert hard wired xsl:number for production into a template
-    with mode="label.markup" to be consistent with other element numbering.
-
-  • Robert Stayton: inline.xsl
-
-    Make comma inserted after function/parameter or function/replaceable
-    conditional on $function.parens to be consistent with the function template.
-
-  • tom_schr: inline.xsl
-
-    Added new inline.sansseq template for consistency reasons.
-    Makes it easier for customization layers: Just use
-      <xsl:call-template name="inline.sansseq"/>
-    to change to sans serif font, but also takes into account
-    XLinks and direction of text.
-
-  • Robert Stayton: xref.xsl
-
-    Remove all references and code for obsolete olink attributes
-    @linkmode @targetdocent and @localinfo.
-
-  • Robert Stayton: table.xsl
-
-    Remove passivetex.extensions code.
-
-  • Robert Stayton: spaces.xsl; autotoc.xsl; docbook.xsl; division.xsl;
-    table.xsl; sections.xs⋯
-
-    Remove all passivetex code because it is obsolete.
-
-  • Robert Stayton: param.xweb; param.ent
-
-    Add parameter 'activate.external.olinks' to allow making
-    external olinks inactive, as for epub output.
-
-  • Mauritz Jeanson: table.xsl
-
-    Added support for keep-together PI on informaltable. Closes bug #3555609.
-
-  • tom_schr: verbatim.xsl
-
-    Fixed subtle typo when calling lastLineNumber template: must be $listing instead of listing
-
-  • tom_schr: autoidx.xsl
-
-    Fixed typo: fole -> role attribute for phrase
-
-  • tom_schr: inline.xsl
-
-    Added support for @function attribute in keycap (uses keycap context
-    from language files) => fixes RFE#3540451
-    If @function is set and keycap is empty, then template will use the
-    content from the keycap context, otherwise it will use just the given
-    text
-
-  • Robert Stayton: graphics.xsl; xref.xsl
-
-    Add support for title element in screenshot, now allowed in DocBook 5.
-
-  • Robert Stayton: graphics.xsl
-
-    Restore formatting of figure/caption that was broken in 1.77.1.
-
-HTML
-
-The following changes have been made to the html code since the 1.77.1 release.
-
-  • David Cramer: autotoc.xsl
-
-    Fixing bug where toc.title.p and nodes params had not been declared inside manual-toc template
-
-  • Robert Stayton: autotoc.xsl
-
-    Add 'toc.list.attributes' template to insert class and other
-    attributes on the top level list element in a table of contents.
-
-  • Robert Stayton: block.xsl
-
-    Fix bug 3590039 abstract/title not rendered.
-
-  • Jirka Kosek: chunk-common.xsl; footnote.xsl
-
-    Fixed positioning of footnote separate when CSS decoration is used.
-
-  • Robert Stayton: ebnf.xsl
-
-    Convert hard wired xsl:number for production into a template
-    with mode="label.markup" to be consistent with other element numbering.
-
-  • Robert Stayton: inline.xsl
-
-    Make comma inserted after function/parameter or function/replaceable
-    conditional on $function.parens to be consistent with the function template.
-
-  • Robert Stayton: graphics.xsl
-
-    Add support for mediaobject/alt, with precedence over
-    mediaobject/textobject/phrase.
-
-  • Robert Stayton: param.xweb
-
-    Remove src:fragref elements for deleted obsolete olink params.
-
-  • Robert Stayton: chunker.xsl
-
-    Fix bug #3563697 where template make-relative-filename was using a
-    global param chunk.base.dir instead of its local param base.dir.  Now it uses base.dir.
-
-  • Robert Stayton: param.xweb; param.ent; xref.xsl
-
-    Remove all references and code for obsolete olink attributes
-    @linkmode @targetdocent and @localinfo.
-
-  • Robert Stayton: param.xweb; param.ent
-
-    Add parameter 'activate.external.olinks' to allow making
-    external olinks inactive, as for epub output.
-
-  • stefan: graphics.xsl
-
-    Add hook for customization.
-
-  • tom_schr: docbook.xsl
-
-    Splitting head.content into smaller chunks of templates.
-    See https://lists.oasis-open.org/archives/docbook-apps/201209/msg00037.html
-
-  • tom_schr: verbatim.xsl
-
-    Fixed subtle typo when calling lastLineNumber template: must be $listing instead of listing
-
-  • Robert Stayton: footnote.xsl
-
-    Fix bug in footnote link introduced in 1.77.1.
-
-  • Robert Stayton: formal.xsl; htmltbl.xsl
-
-    Resolve conflict of duplicate ids on html table with caption.
-    Wrap a div with class and id attribute around html table without caption.
-
-  • Robert Stayton: component.xsl
-
-    Remove call to 'generate.id' template in <h1> in component.title because the
-    id is already generated for the parent div element.
-
-  • Robert Stayton: chunker.xsl
-
-    Set omit-xml-declaration to 'yes' for write.text.chunk template, since a text
-    file should never have an xml declaration.
-
-  • tom_schr: inline.xsl
-
-    Added support for @function attribute in keycap (uses keycap context
-    from language files) => fixes RFE#3540451
-    If @function is set and keycap is empty, then template will use the
-    content from the keycap context, otherwise it will use just the given
-    text
-
-  • David Cramer: docbook.xsl
-
-    Also set the title param in head.content since it's sometimes
-    called without that param being passed in. Use the passed-in
-    value in user.head.title.
-
-  • Robert Stayton: docbook.xsl
-
-    Restore missing title param on 'head.content' template, and passed
-    it along to user.head.title. That param
-    is used for certain special chunkings such as Long Descriptions.
-
-  • Robert Stayton: graphics.xsl; xref.xsl
-
-    Add support for title in screenshot, available since DocBook 5.
-
-  • David Cramer: docbook.xsl
-
-    HTML: Add hook for easily customizing html/head/title
-
-Manpages
-
-The following changes have been made to the manpages code since the 1.77.1
-release.
-
-  • Robert Stayton: lists.xsl
-
-    Add a line break at start of variablelist to fix bug #3595156.
-
-  • Robert Stayton: lists.xsl
-
-    Better fix for bug #3545150 by putting the title with the step number
-    rather than before it.
-
-  • Robert Stayton: utility.xsl
-
-    Add 'content' param to template name inline.monoseq to support
-    email format, fixing bug #3524417.
-
-  • Robert Stayton: utility.xsl
-
-    Fix bug #3512473 where an inline synopsis element produced
-    an extra line break in nroff output.
-
-  • Robert Stayton: lists.xsl
-
-    Fix bug 3545150 where procedure/step/title not rendered in man pages.
-
-Roundtrip
-
-The following changes have been made to the roundtrip code since the 1.77.1
-release.
-
-  • Robert Stayton: dbk2wordml.xsl
-
-    Fix bug #3297553 error in Word metadata elements from including
-    WordML markup instead of just text.
-
-Slides
-
-The following changes have been made to the slides code since the 1.77.1
-release.
-
-  • gaborkovesdan: xhtml/plain.xsl
-
-    - Use real push-style processing in the foil/foilgroup page content, which
-      allows better customization in general (e.g. you can add PI templates)
-      and also let us render scattered speakernotes/handoutnotes if that is
-      desired
-
-  • gaborkovesdan: xhtml/Makefile
-
-    - Titlepage markup belongs to the XHTML namespace
-
-  • gaborkovesdan: xhtml/plain.xsl
-
-    - Remove now unnecessary template redefinition
-
-  • gaborkovesdan: xhtml/plain.xsl
-
-    - Generate valid links from cross-references
-
-  • gaborkovesdan: xhtml/plain.xsl
-
-    - Do not add fallbacks for EXSLT extensions, the main DocBook XSL stylesheets
-      do not do that either
-
-  • Robert Stayton: schema/relaxng/slides.rnc
-
-    Update the import path for docbook.rnc after the slides directory was moved.
-
-  • stefan: xhtml/plain.xsl
-
-    Add missing stylesheet.
-
-  • stefan: schema/xsd/Makefile; schema/Makefile; schema/relaxng/Makefile
-
-    Adjust Makefiles.
-
-  • stefan: locatingrules.xml; RELEASE-NOTES.xml; doc; images;
-    locatingrules.xml; Makefile; im⋯
-
-    Moved many files from slides/ to xsl/slides/
-
-  • stefan: fo/param.xweb; xhtml/Makefile; xhtml/param.xweb; fo/Makefile
-
-    Separate slides package.
-
-  • stefan: Makefile
-
-    A bit of cleanup...
-
-  • stefan: xhtml/Makefile; fo/Makefile
-
-    Add to 'clean' target.
-
-  • David Cramer: Makefile
-
-    Slides: Change html to xhtml passim.
-
-  • David Cramer: xhtml
-
-    Adding items to svn ignore for slides
-
-  • stefan: slidy
-
-    Import slidy from vendor branch.
-
-  • stefan: s5
-
-    Import s5 from vendor branch.
-
-  • stefan: Makefile; common/common.xsl; common; fo/param.ent; graphics; xhtml/
-    Makefile.param;⋯
-
-    Merge Slides GSoC project to trunk.
-
-Webhelp
-
-The following changes have been made to the webhelp code since the 1.77.1
-release.
-
-  • David Cramer: docsrc/readme.xml
-
-    Webhelp: More doc updates
-
-  • David Cramer: docsrc/readme.xml
-
-    Webhelp: Documentation updates.
-
-  • David Cramer: template/content; Makefile; Makefile.sample; build.xml;
-    template/search
-
-    Webhelp: Improving sample Makefile to allow for profiling params and other params, removing content dir from template and making related adjustments in Makefile and build.xml
-
-  • David Cramer: Makefile.sample
-
-    Attempting to include sample Makefile in webhelp output dir
-
-  • David Cramer: template/common/css/positioning.css
-
-    Webhelp: Do not display sidebar if js is disabled in browser since it will not be functional
-
-  • Jirka Kosek: build.xml
-
-    Xerces must be on the classpath in order to XInclude work
-
-  • David Cramer: Makefile
-
-    Adding generated files to various clean targets.
-
-  • David Cramer: build.properties
-
-    Webhelp: By default don't validate against dtd when using ant build
-
-  • David Cramer: Makefile
-
-    Webhelp: By default only exclude ix01.html from search in Makefile
-
-  • David Cramer: template/common/jquery/jquery-ui-1.8.2.custom.min.js;
-    template/common/jquery⋯
-
-    Webhelp: Reverting last commit
-
-  • David Cramer: template/common/jquery/jquery-ui-1.8.2.custom.min.js;
-    template/common/jquery⋯
-
-    Webhelp: Removing two more unused jquery files
-
-  • David Cramer: template/common/jquery/jquery-1.4.2.min.js
-
-    Webhelp: Removing old, unused jquery file
-
-  • David Cramer: xsl/webhelp-common.xsl
-
-    Webhelp: Fix header logo link
-
-  • David Cramer: xsl/webhelp-common.xsl
-
-    Webhelp: Fix bad link to favicon.ico
-
-  • David Cramer: template/common/jquery/jquery-1.7.2.min.js; template/common/
-    main.js; templat⋯
-
-    First part of the GSoC 2012 work by Arun and Visitha:
-
-    Visitha Baddegama
-    Remove content folder from Webhelp output
-    Build Webhelp using GNU Make/without ant
-    Support a parameterized list of files to exclude while indexing
-    Improve information message for browser with JavaScript disabled
-    Support searching for terms with punctuation like build.xml
-
-    Arun Bharadwaj
-    Make it possible to include the doc title in head/title and
-     not in the search results
-    Improve performance in IE 8/9
-    Expandable TOC pane
-    Information message for browser with JavaScript disabled
-
-  • David Cramer: xsl/webhelp-common.xsl
-
-    Use user.head.title to add title to webhelp pages,
-    but do not yet add the book title to the page title.
-
-  • David Cramer: xsl/webhelp-common.xsl
-
-    Webhelp: Revert 9433. We need to fix the indexer before we can include the document title in the html/head/title
-
-  • David Cramer: xsl/webhelp-common.xsl
-
-    Webhelp: Append document title to html/head/title
-
-  • David Cramer: xsl/webhelp-common.xsl
-
-    Webhelp: fix missing reference to ie.css
-
-Params
-
-The following changes have been made to the params code since the 1.77.1
-release.
-
-  • Robert Stayton: page.height.portrait.xml; page.width.portrait.xml
-
-    Add USlegal and USlegallandscape.
-
-  • Robert Stayton: force.blank.pages.xml
-
-    Improve the description.
-
-  • Robert Stayton: page.margin.outer.xml; writing.mode.xml; double.sided.xml;
-    page.margin.inn⋯
-
-    Improve the description.
-
-  • Robert Stayton: force.blank.pages.xml
-
-    New param to control generating blank even-numbered pages.
-
-  • Robert Stayton: passivetex.extensions.xml
-
-    Indicate that passivetex is no longer supported.
-
-  • Robert Stayton: footnote.properties.xml
-
-    Fix bug #3555628 where a footnote inside a blockquote inherits the end-indent from the blockquote.
-
-  • stefan: foil.page-sequence.properties.xml; handoutnotes.properties.xml;
-    slidy.duration.xml⋯
-
-    Merge Slides GSoC project to trunk.
-
-  • Robert Stayton: activate.external.olinks.xml
-
-    Add parameter 'activate.external.olinks' to allow making
-    external olinks inactive, as for epub output.
-
-Profiling
-
-The following changes have been made to the profiling code since the 1.77.1
-release.
-
-  • Robert Stayton: xsl2profile.xsl
-
-    Test for @xml:id as well as @id for $rootid.
-
-Tools
-
-The following changes have been made to the tools code since the 1.77.1
-release.
-
-  • David Cramer: bin/docbook-xsl-update
-
-    s/VERSION/VERSION.xsl/ again.
-
-  • David Cramer: xsl/build/xsl-param-link.xsl; xsl/build/make-xsl-params.xsl
-
-    Slides: Change html to xhtml passim.
-
-Template
-
-The following changes have been made to the template code since the 1.77.1
-release.
-
-  • Jirka Kosek: titlepage.xsl
-
-    Autoguess of proper parameter settings
-
-Release Notes: 1.77.1
-
-The following list summarizes the major changes that have been made since the
-1.76.1 release. It is followed by sections detailing changes to individual
-files from the SVN checkin logs, edited to remove housekeeping changes and bug
-fixes. See the NEWS.xml file for a complete unedited list of SVN changes.
-
-  • Gentext
-
-    webhelp
-
-        Many improvements to the generated text for webhelp output.
-
-  • Common
-
-    Support more media types
-
-        Expanded list of supported filename extensions for media to include
-        video and audio, mostly for HTML5 and EPUB3 outputs.
-
-    Topic element
-
-        Add basic support for new topic element, which is available in DocBook
-        5.1. Generally a topic element will be used with assembly and may be
-        transformed to some other hierarchical element during processing, but
-        it can also be formatted as a plain topic.
-
-  • FO
-
-    Add para.properties attribute-set
-
-        Add a para.properties attribute-set that applies only to para elements.
-        That allows still using normal.para.spacing attribute-set for many
-        block elements for uniform spacing, but allows separate formatting of
-        para elements.
-
-    List of titles in article
-
-        Add support for List of Tables, List of Figures, etc. for articles and
-        other component-level elements. Includes a new template for each in
-        autotoc.xsl, new attribute-sets in titlepage.xsl, and new entries in
-        the titlepage.templates.xml file tu support customization.
-
-    Customizing links in FO
-
-        Add template mode simple.xlink.properties to allow easy customization
-        of formatting of links generated from elements that use the xlink
-        attributes. This extends link formatting beyond that of xref, link, and
-        olink which use xref.properties attribute-set.
-
-    Table caption
-
-        The caption element in an HTML table is now handled like a title in a
-        CALS table, using the formal.object.title template with all its
-        features, including placement. Now caption template in mode="htmlTable"
-        does nothing, because caption handled by formal.object.title template.
-        Also adds support for table caption element in a CALS table, placing it
-        after the table.
-
-    Graphics attribute handling
-
-        Refactored the big process.image template to use individual templates
-        such as image.width for most attributes to allow easier customization
-        of individual properties.
-
-    Side regions
-
-        Add support for side page regions in addition to header and footer
-        regions. This feature lets you add running content to the side margins,
-        and by default the content is rotated 90 degrees. Adds new templates
-        named running.side.content, region.inner and region.outer; new template
-        modes region.inner.mode and region.outer.mode; new parameters named
-        region.inner.extent, region.outer.extent, body.margin.inner,
-        body.margin.outer, and side.region.precedence; and new attribute-sets
-        named inner.region.content.properties, outer.region.content.properties,
-        region.inner.properties, and region.outer.properties.
-
-    Callout formatting
-
-        Add new attribute-sets for calloutlist.
-
-    Topic element
-
-        Add basic support for formatting a topic element, which is available in
-        DocBook 5.1.
-
-  • HTML
-
-    HTML5
-
-        Add variables to the base HTML stylesheets that can be adjusted for the
-        HTML5 stylesheets.
-
-    Insert Javascript reference
-
-        Add support for html.script param to insert reference to a Javascript
-        file.
-
-    Namespace for titlepage mechanism.
-
-        Titlepage mechanism is now namespace aware to support XHTML.
-
-    Chunked filename prefix
-
-        New param named chunked.filename.prefix lets you add a filename prefix
-        to each chunked file. This replaces the buggy practice of adding such a
-        prefix to the base.dir param. Now the base.dir param will always have a
-        trailing slash added if it is not present, so you no longer have to
-        remember to add it to the param value.
-
-    Generate id attributes
-
-        The stylesheet param generate.id.attributes already existed but was
-        incompletely implemented. Now when it is set to 1, only id attributes
-        should be output, not <a name> named anchors.
-
-    Generate consistent id attributes
-
-        New generate.consistent.ids parameter which allows generating a more
-        stable id values based on XPath rather than the generate-id() function,
-        which may not produce consistent values between runs. Stable output ids
-        allow you to make stable links to generated content from the outside.
-
-    Topic element
-
-        Add basic support for formatting a topic element, which is available in
-        DocBook 5.1. Generally a topic element will be used with assembly and
-        may be transformed to some other hierarchical element during
-        processing, but it can also be formatted as a plain topic.
-
-  • Webhelp
-
-    Webhelp refactored
-
-        Webhelp templates refactored to better support customization.
-
-    Added documentation.
-
-        More and better documentation added.
-
-    Webhelp generated text
-
-        Many improvements to the generated text for webhelp output.
-
-  • XHTML5
-
-    New stylesheets to generate HTML5 output, in an XML serialization. These
-    templates are a customization layer on top of the XHTML stylesheet files.
-
-  • EPUB3
-
-    New stylesheets to generate EPUB3 output. These templates are a
-    customization layer on top of the xhtml5 stylesheet files.
-
-  • Assembly
-
-    New assembly.xsl stylesheet to convert a DocBook 5.1 assembly into a
-    standard DocBook 5 document. Also includes a topic-maker-chunk.xsl
-    stylesheet that can convert a DocBook 5 book or article document into an
-    assembly with a collection of modular files, including converting some
-    elements to topic files.
-
-Gentext
-
-The following changes have been made to the gentext code since the 1.76.1
-release.
-
-  • stefanhinz: locale/de.xml
-
-    Translated German WebHelp strings
-
-  • David Cramer: locale/zh.xml; locale/en.xml; locale/fr.xml; locale/de.xml;
-    locale/ja.xml
-
-    Webhelp: Update non-en gentext strings
-
-  • Robert Stayton: locale/en.xml
-
-    Add topic to title-numbered context.
-
-  • Robert Stayton: locale/en.xml
-
-    Add basic topic element templates.
-
-  • Mauritz Jeanson: locale/el.xml
-
-    Updated gentext for quotation marks. Fixes bug #3512440.
-
-  • Jirka Kosek: locale/cs.xml
-
-    Adding missing context for webhelp
-
-  • David Cramer: locale/en.xml
-
-    Fixing syntax of webhelp gentext entries
-
-  • David Cramer: locale/en.xml
-
-    Moving webhelp gentext strings into a context
-
-  • tom_schr: locale/zh.xml; locale/en.xml; locale/cs.xml; locale/fr.xml;
-    locale/de.xml; local⋯
-
-    Moved language specific of WebHelp to gentext/locale/ as discussed with
-    Stefan following the "minimal intrusive approach". :)
-    In the long run, maybe moving the text into a context, not sure.
-
-  • Jirka Kosek: locale/ru.xml
-
-    Aligned capitalization of first letters with English original
-
-Common
-
-The following changes have been made to the common code since the 1.76.1
-release.
-
-  • Robert Stayton: common.xsl
-
-    In "select.mediaobject.index" template, add selection of videoobject
-    and audioobject since now supported in HTML5.
-
-  • Robert Stayton: labels.xsl; titles.xsl; entities.ent; targets.xsl;
-    subtitles.xsl; gentext.⋯
-
-    Add basic support for new <topic> element.
-
-  • Robert Stayton: common.xsl
-
-    Fix handling of mediatypes for video and audio files, mostly for HTML5 and EPUB3 outputs.
-
-  • Robert Stayton: olink.xsl
-
-    Generate error message if olink data in targetset is in a namespace.
-
-  • Robert Stayton: common.xsl
-
-    Add support for generate.consistent.ids parameter.
-
-  • Robert Stayton: subtitles.xsl
-
-    Add verbose param to subtitle.markup templates to allow its
-    error message to be ignored.
-    Add that param to fop1.xsl application of subtitle.markup
-    to avoid unnecessary error message in document information.
-
-  • Robert Stayton: labels.xsl
-
-    Add empty templates for glossdiv, glosslist, and glossentry in
-    mode="label.markup".
-
-FO
-
-The following changes have been made to the fo code since the 1.76.1 release.
-
-  • Robert Stayton: graphics.xsl
-
-    qualify caption template to mediaobject/caption so not confused with table/caption.
-
-  • Robert Stayton: table.xsl
-
-    Add template to process table/caption element.
-
-  • Robert Stayton: titlepage.xsl; autotoc.xsl; component.xsl; xref.xsl;
-    titlepage.templates.x⋯
-
-    Add basic support for new <topic> element.
-
-  • Robert Stayton: graphics.xsl
-
-    Fix handling of mediatypes for video and audio files, mostly for HTML5 and EPUB3 outputs.
-
-  • Robert Stayton: titlepage.xsl
-
-    Add default style att-sets for component.list.of.titles, etc.
-
-  • Robert Stayton: autotoc.xsl; component.xsl; titlepage.templates.xml
-
-    Add make.component.tocs to support lists of tables, etc. for
-    article and other components.  Added component.list.of.tables to
-    titlepage.templates.xml to format the title.
-
-  • Robert Stayton: param.xweb; param.ent
-
-    Add new para.properties attribute-set for paragraphs.
-
-  • Robert Stayton: inline.xsl
-
-    Add template mode 'simple.xlink.properties' to allow
-    easy customization of formatting of links generated
-    from elements other than xref, link, and olink using
-    the xlink attributes.
-
-  • Robert Stayton: param.xweb; param.ent
-
-    Add table.caption.properties to format table captions.
-
-  • Robert Stayton: table.xsl
-
-    Add support for caption in a CALS table.
-
-  • Robert Stayton: graphics.xsl; math.xsl
-
-    Refactored the 'process.image' template to create modular
-    templates for each attribute so they can be individually
-    customized.  Also merged in support for embedded svg and
-    mml content so they can have image attributes too.
-
-  • Robert Stayton: param.xweb; param.ent
-
-    Check in new params for FO side regions in page masters.
-
-  • Robert Stayton: titlepage.xsl; titlepage.templates.xml
-
-    Add support for itermset in info elements, using titlepage mechanism
-    to ensure entries are placed inside page-sequence.
-
-  • Robert Stayton: pagesetup.xsl
-
-    Add support for side body margins and side static content regions.
-    Fixes bug 3389931.
-
-  • Robert Stayton: param.xweb; param.ent; task.xsl
-
-    Add attribute-set task.properties to task element to
-    support customization.
-
-  • Robert Stayton: lists.xsl; param.xweb; param.ent
-
-    Add new attribute-sets calloutlist.properties and callout.properties
-    to  better support customization of calloutlists, fixing bug 3160341.
-
-  • Jirka Kosek: Makefile
-
-    Titlepage mechanism is now namespace aware to support XHTML. Please note that when generating titlepage template stylesheets you have to pass FO or XHTML namespace inside ns parameter. For HTML parameter should be empty.
-
-  • Robert Stayton: graphics.xsl
-
-    Allow selection by role for multiple imageobject elements
-    within an imageobjectco, which since Docbook 5 allows multiple imageobjects.
-
-  • Mauritz Jeanson: titlepage.xsl
-
-    Added template for collabname. Fixes bug #3414436.
-
-  • David Cramer: verbatim.xsl
-
-    Support the keep-together processing-instruction on programlisting, screen, synopsis, and literallayout. Tracker id #3396906.
-
-  • Robert Stayton: pagesetup.xsl
-
-    Pass the pageclass, sequence, and gentext-key to the template
-    named header.footer.widths to enable further customization
-    based on page master.
-
-  • Jirka Kosek: xref.xsl
-
-    hyphenation of URL content must be disabled for link, not only for ulink because od DB5
-
-  • Jirka Kosek: xref.xsl
-
-    URLs shouldn't be hyphenated as normal text
-
-  • Jirka Kosek: callout.xsl
-
-    Added support for alternative circled numbers
-
-  • Mauritz Jeanson: axf.xsl; fop1.xsl; xep.xsl
-
-    Added support for author/orgname in document metadata. Closes bug #3132862.
-
-  • Robert Stayton: component.xsl
-
-    Add template for article/colophon to avoid nested page-sequence.
-
-HTML
-
-The following changes have been made to the html code since the 1.76.1 release.
-
-  • Robert Stayton: xref.xsl
-
-    Add support for using info/title as well as title in target element.
-
-  • Robert Stayton: component.xsl
-
-    Enable support for html5 features, including using <section> instead of
-    <div> for certain elements, and setting heading level to <h1> for chapters.
-    These features are not changed in the base html stylesheet for backwards
-    compatibility.
-
-  • Robert Stayton: docbook.css.xml
-
-    Add style for footnote rule.
-
-  • Robert Stayton: biblio-iso690.xsl
-
-    Add support for subtitle inside info.
-
-  • Robert Stayton: docbook.xsl
-
-    Add call to new 'root.attributes' placeholder template to allow
-    adding attributes to the <html> output element.
-
-  • Robert Stayton: inline.xsl; titlepage.xsl; formal.xsl; division.xsl;
-    toc.xsl; sections.xsl⋯
-
-    Finish implementation of generate.id.attributes for all elements
-    using the template named id.attribute.
-
-  • Robert Stayton: autotoc.xsl; chunktoc.xsl; titlepage.xsl; chunk-code.xsl;
-    changebars.xsl; ⋯
-
-    Add basic support for new <topic> element.
-
-  • Robert Stayton: graphics.xsl
-
-    Fix handling of mediatypes for video and audio files, mostly for HTML5 and EPUB3 outputs.
-
-  • Robert Stayton: callout.xsl; verbatim.xsl
-
-    Restore programlisting to use <pre> instead of <div> and instead
-    wrap callout img elements in <span> to make valid HTML.
-
-  • Robert Stayton: graphics.xsl
-
-    Turn off img longdesc attribute because not supported by browsers.
-
-  • Robert Stayton: footnote.xsl
-
-    Move square brackets and <sup> inside <a> element for footnote
-    marks to fix display problems in some browsers.
-
-  • Robert Stayton: param.xweb; param.ent
-
-    Add new params html.script and html.script.type to support
-    Javascript references.
-
-  • Robert Stayton: chunk-common.xsl; chunktoc.xsl; titlepage.xsl; chunker.xsl;
-    chunk-code.xsl⋯
-
-    Add support for chunked.filename.prefix param.
-    Make sure base.dir value has a trailing slash in
-    the chunk.base.dir internal param used by the templates.
-
-  • Robert Stayton: formal.xsl; htmltbl.xsl
-
-    Now handles caption in html markup table like title,
-    so formal.object.title is used with all its features, including
-    formatting and placement.
-    Added htmlTable.with.caption template to handle the wrapper, and
-    left htmlTable template unchanged.
-    Now caption template in mode="htmlTable" does nothing, because
-    caption handled by formal.object.title template.
-
-  • Robert Stayton: html.xsl
-
-    Turn off generating the title attribute for block and hierarchical elements.
-    Should only be used for inline elements, usually using the alt element.
-    Also used for links to show the target title.
-
-  • Robert Stayton: lists.xsl
-
-    The spacing="compact" attribute on lists in HTML no longer outputs compact="compact"
-    (or just "compact" in the case of Saxon 6), since that attribute is
-    deprecated and improperly supported.  Instead, the output uses a
-    multiple class attribute such as class="orderedlist compact".
-    Use CSS to style such lists without margin above.
-
-  • Robert Stayton: graphics.xsl
-
-    Allow selection by role for multiple imageobject elements
-    within an imageobjectco, which since Docbook 5 allows multiple imageobjects.
-
-  • Robert Stayton: pi.xsl
-
-    Improve doc descriptions of dbhtml filename and dir.
-
-  • Robert Stayton: autoidx.xsl
-
-    Add setindex to context param in mode="reference" to better
-    support setindex.
-
-  • Robert Stayton: autotoc.xsl
-
-    Support set as child of set in set.toc template.
-
-  • Robert Stayton: qandaset.xsl
-
-    Change question and title templates to replace hard-coded
-    class="local-name()" with mode="class.attribute" to support customization
-    of class values.
-
-  • Norman Walsh: chunktoc.xsl
-
-    Separate book appendixes from article appendixes (so that they can be customized independently)
-
-  • Mauritz Jeanson: graphics.xsl
-
-    Added condition to prevent "Failed to interpret image" messages (SVG is not supported
-    by the graphic size extension).
-
-Epub
-
-The following changes have been made to the epub code since the 1.76.1 release.
-
-  • Robert Stayton: docbook.xsl
-
-    Replace $base.dir with $chunk.base.dir to ensure trailing slash in place.
-
-HTMLHelp
-
-The following changes have been made to the htmlhelp code since the 1.76.1
-release.
-
-  • Robert Stayton: htmlhelp-common.xsl
-
-    Change $base.dir to $chunk.base.dir to ensure trailing slash in place.
-
-Eclipse
-
-The following changes have been made to the eclipse code since the 1.76.1
-release.
-
-  • Robert Stayton: eclipse.xsl; eclipse3.xsl
-
-    Use $chunk.base.dir instead of $base.dir to ensure trailing slash is in place.
-
-JavaHelp
-
-The following changes have been made to the javahelp code since the 1.76.1
-release.
-
-  • Robert Stayton: javahelp.xsl
-
-    Change $base.dir to $chunk.base.dir to ensure trailing slash is present.
-
-  • Mauritz Jeanson: javahelp.xsl
-
-    Replaced empty header.navigation and footer.navigation templates with parameter suppress.navigation=1,
-    which simplifies customization. See bug #3310904.
-
-Webhelp
-
-The following changes have been made to the webhelp code since the 1.76.1
-release.
-
-  • David Cramer: template/common/css/positioning.css
-
-    Webhelp: Adding print-only css rules
-
-  • David Cramer: template/common/main.js
-
-    Webhelp: Arun's fix for bug where heading was partially hidden by header in some situations.
-
-  • David Cramer: xsl/webhelp-common.xsl
-
-    Webhelp: turn off autolabeling by default
-
-  • David Cramer: xsl/webhelp.xsl
-
-    Webhelp: Import xhtml base stylesheets
-
-  • David Cramer: docsrc/readme.xml
-
-    Webhelp: Link to the DocBook reference docs from the webhelp readme
-
-  • David Cramer: xsl/webhelp-common.xsl
-
-    Webhelp: Use gentext value for noscript warning
-
-  • David Cramer: Makefile
-
-    Webhelp: Delete tempfile after DocBook xsl build
-
-  • David Cramer: xsl/webhelp.xsl
-
-    Webhelp: moving parameters into the standard location so they will be part of the parameter reference
-
-  • David Cramer: xsl/webhelp.xsl; xsl/webhelp-common.xsl
-
-    Webhelp: moving parameters into the standard location so they will be part of the parameter reference
-
-  • David Cramer: template/common/main.js
-
-    Webhelp: tweaking scrolldown offset for anchors
-
-  • David Cramer: docsrc/images; docsrc/images/sample.jpg; docsrc/readme.xml;
-    template/content⋯
-
-    Webhelp: updating docs. Ant version, install instructions, handling of images.
-
-  • David Cramer: xsl/webhelp.xsl
-
-    Patch from Arun Bharadwaj to display message if JavaScript is disabled
-
-  • David Cramer: template/content/search/nwSearchFnt.js
-
-    Patch from Arun Bharadwaj to strip quotes from search query strings
-
-  • Robert Stayton: xsl/webhelp.xsl
-
-    Add basic support for new <topic> element.
-
-  • Jirka Kosek: xsl/webhelp.xsl
-
-    Put back old extensibility point.
-
-    Guys, please don't remove existing extensibility points like named templates, it will break existing customizations.
-
-  • David Cramer: xsl/webhelp.xsl
-
-    Moving webhelp gentext strings into a context
-
-  • tom_schr: param.ent
-
-    Disabled branding and brandname entities for the time being
-
-  • tom_schr: param.xweb; param.ent
-
-    Prepared WebHelp reference documentation :)
-    Not clear about parameters brandname and branding: Should they renamed
-    to "webhelp.branding" and "webhelp.brandname"?
-    Currently, docsrc/reference.xml contains only a comment for the WebHelp
-    ref doc to be non-intrusive.
-    Idea is to enable it when it is ready
-
-  • tom_schr: xsl/webhelp.xsl
-
-    Moved language specific of WebHelp to gentext/locale/ as discussed with
-    Stefan following the "minimal intrusive approach". :)
-    In the long run, maybe moving the text into a context, not sure.
-
-  • David Cramer: template/common/css/positioning.css
-
-    Webhelp: Lower the minimum width of content pane
-
-  • kasunbg: xsl/webhelp.xsl; template/common/main.js
-
-    If an user moved to another page by clicking on a toc link, and then clicked on #searchDiv,
-    search should be performed if the cookie textToSearch is not empty.
-
-  • David Cramer: xsl/webhelp.xsl
-
-    Webhelp: Left align titles in nav header. Display  for all but the topmost page
-
-  • David Cramer: template/content/search/stemmers/en_stemmer.js; docsrc/
-    xinclude-test.xml
-
-    Webhelp: Cleanup related to en_stemmer.js changes
-
-  • David Cramer: template/common/css/positioning.css
-
-    Webhelp: Don't put borders around qandaset list
-
-  • David Cramer: template/common/main.js
-
-    Webhelp: Avoid unnecessary scroll ups when anchor is clicked on
-
-  • David Cramer: build.properties
-
-    Webhelp: Show footer nav by default
-
-  • David Cramer: build.properties; build.xml
-
-    Webhelp: Support setting suppress.footer.navigation from build.properties
-
-  • David Cramer: build.properties; build.xml
-
-    Webhelp: Support admon.graphics param in build.properties
-
-  • David Cramer: docsrc/xinclude-test.xml; docsrc/readme.xml
-
-    Webhelp: Adding xinclude example to the demo/readme doc
-
-  • David Cramer: template/common/css/positioning.css
-
-    Webhelp: Remove border around table used to format callout list
-
-  • David Cramer: xsl/webhelp.xsl; template/common/images/admon/tip.png;
-    template/common/image⋯
-
-    Webhelp: Support admon graphics (still off by default)
-
-  • David Cramer: xsl/webhelp.xsl; template/common/css/positioning.css
-
-    Webhelp: Turn on navfooter and fix related css
-
-  • David Cramer: xsl/webhelp.xsl
-
-    Webhelp: Fix error about undeclared doc.title param
-
-  • David Cramer: docsrc/readme.xml
-
-    Webhelp: Adding some test search terms to the readme
-
-  • David Cramer: template/content/search/stemmers/en_stemmer.js
-
-    Handle exceptional cases listed in the Porter 2 stemming algo
-
-  • David Cramer: template/content/search/stemmers/en_stemmer.js
-
-    Webhelp: adding special case word 'say' to en js stemmer
-
-  • David Cramer: template/content/search/stemmers/en_stemmer.js
-
-    Webhelp: Refine stemming of terms that end in (only stem if there's a consonant before the -y)
-
-  • David Cramer: template/content/search/stemmers/en_stemmer.js; template/
-    content/search/nwSe⋯
-
-    Webhelp: fixed bug where words like key, day, and nucleus, were not found due to differences in the way the client stemmer and indexer stemmed words
-
-  • David Cramer: build.xml
-
-    Webhelp: Support xinclude and two-pass profiling in build.xml
-
-  • David Cramer: xsl/webhelp.xsl
-
-    Fix bad link to default topic.
-
-  • kasunbg: docsrc/readme.xml
-
-    Automatically limit the size of the search description to something 140 characters
-
-  • kasunbg: xsl/webhelp.xsl
-
-    removing outline in 'contents' and 'search' buttons that is visible when clicked. tabindex for SIDEBAR button.
-
-  • kasunbg: xsl/webhelp.xsl; build.xml
-
-    Webhelp ant script changes - HTML transformation support for WebHelp - Uses Tagsoup for parsing the bad html.
-    tagsoup-1.2.1.jar is added to trunk/xsl-webhelpindexer/lib/
-
-  • kasunbg: xsl/webhelp.xsl
-
-    proper support for saxon xhtml transformation.
-
-  • kasunbg: template/common/images/callouts/10.png; template/common/images/
-    callouts/11.png; t⋯
-
-    webhelp - adding callouts
-
-  • kasunbg: xsl/webhelp.xsl; template/common/main.js; template/common/css/
-    positioning.css
-
-    webhelp - animations for show/hide Sidebar
-
-  • kasunbg: build.properties
-
-    commenting about brand and brandname
-
-  • kasunbg: Makefile
-
-    parameterized MAKE for webhelp
-
-  • kasunbg: xsl/webhelp.xsl; template/common/css/positioning.css;
-    build.properties; build.xml
-
-    webhelp xsl customization - logo
-
-  • kasunbg: template/content/search/nwSearchFnt.js
-
-    remove some JS warninings
-
-  • kasunbg: template/content/search/nwSearchFnt.js
-
-    Fix for missing "No results found for..." bug
-
-  • kasunbg: xsl/webhelp.xsl
-
-    commented about the importance of the order of css contents. Order is important between the in-html-file css and the linked css files. Some css declarations in jquery-ui-1.8.2.custom.css are over-ridden. If that's a concern, just remove the additional css contents inside these default jquery css files. I thought of keeping them intact for easier maintenance.
-
-  • Jirka Kosek: xsl/webhelp.xsl; template/common/css/positioning.css
-
-    Minor cleanup, added extensibility hook, some styling moved into CSS for easier customization
-
-  • David Cramer: template/content/search/nwSearchFnt.js
-
-    Removing onclick that came from Oxygen's dita stuff
-
-  • kasunbg: docsrc/readme.xml
-
-    webhelp - documenting about features
-
-  • kasunbg: template/common/css/positioning.css
-
-    webhelp search text box
-
-  • kasunbg: template/common/css/positioning.css
-
-    adding header background image
-
-  • kasunbg: xsl/webhelp.xsl; template/common/images/header-bg.png
-
-    new header background image
-
-  • kasunbg: xsl/webhelp.xsl; template/common/css/positioning.css
-
-    fix left navigation
-
-  • kasunbg: template/common/css/positioning.css
-
-    some css
-
-  • kasunbg: build.xml
-
-    Adding html.extension property
-
-  • kasunbg: template/common/css/positioning.css; build.properties; build.xml
-
-    webhelp - Adding enable.stemming, toc.file build properties
-
-  • David Cramer: template/common/css/positioning.css
-
-    Make the webhelp banner slightly larger.
-
-  • David Cramer: template/common/main.js; template/common/css/positioning.css
-
-    Adjust colors and positioning of header and search/toc tabs
-
-  • David Cramer: xsl/webhelp.xsl
-
-    Only put doc title in header
-
-  • David Cramer: template/common/css/positioning.css; template/common/images/
-    main_bg_fade.png
-
-    Adjusting default color of the header
-
-  • kasunbg: xsl/webhelp.xsl; template/common/css/positioning.css
-
-    adjustments to header title. Now output in Opera looks good.
-
-  • kasunbg: template/common/images/sidebar.png; template/content/search/
-    punctuation.props; te⋯
-
-    deleting svn:executable flag from webhelp files
-
-  • kasunbg: xsl/webhelp.xsl; template/common/css/positioning.css; template/
-    common/images/sear⋯
-
-    Customized the left navagation headers; Contents and Search.
-    Adding custom css for the current redmond ui of jquery-ui. These override jquery-ui's default css customizations. These are supposed to take precedence.
-
-  • kasunbg: docsrc/readme.xml
-
-    typo fix
-
-  • kasunbg: template/common/images/next-arrow.png; xsl/webhelp.xsl; template/
-    common/main.js; ⋯
-
-    UI improvements.
-            Moved search highligher to search tab.
-            Added nice icons for navigation buttons etc.
-            Removed footer navigation
-            Corrected tree colorings
-            Overall, some css magic
-
-  • David Cramer: docsrc/readme.xml
-
-    Added listitem thinking SyncRO Soft for their contributions.
-
-  • kasunbg: build.xml
-
-    support for default classpath for Gentoo Linux
-
-  • kasunbg: docsrc/readme.xml
-
-    webhelp - some updates to the documentation about search
-
-  • kasunbg: template/common/css/positioning.css
-
-    Fix for issue 'Keep "search" & "contents" titles always visible in webhelp - ID: 3403438'
-
-  • David Cramer: template/common/images/starsSmall.png
-
-    Changed icons used to show search weightings from stars to boxes so they won't look like user ratings
-
-  • David Cramer: xsl/webhelp.xsl; template/common/main.js; template/common/
-    images/starsSmall.⋯
-
-    Merged Oxygen webhelp improvements (search weightings etc) into trunk: -r9031:9039
-
-  • kasunbg: docsrc/readme.xml
-
-    webhelp documentation - search indexing, faq
-
-  • kasunbg: docsrc/readme.xml
-
-    update webhelp documentation
-
-  • David Cramer: xsl/webhelp.xsl
-
-    Fixed bug where webhelp.default.topic was not being used if it was set
-
-  • David Cramer: xsl/webhelp.xsl; template/content/search/nwSearchFnt.js
-
-    Localize string in nwSearchFnt.js file
-
-  • David Cramer: xsl/webhelp.xsl
-
-    Added tabindex attributes to make tab order in UI more logical in webhelp.
-
-  • David Cramer: template/common/main.js
-
-    Fixed bug where anchors in pages landed beneath the banner.
-
-  • kasunbg: xsl/webhelp.xsl
-
-    Added more comments to the xsl/webhelp/xsl/webhelp.xsl file. Removed some clutter.
-
-  • David Cramer: template/common/main.js
-
-    Fixed problem reported in IE 8. See tracker id # 373747.
-
-  • David Cramer: xsl/webhelp.xsl
-
-    Addressed tracker #3247166 by removing hard-coded reference to ch01.html.
-
-  • kasunbg: build.xml
-
-    Changed the webhelp build.xml to reflect the changes to xsl-webhelpindexer.
-    Added classpaths for xercesImpl and xml-api jars to the indexer. Paths added for *nix environments, need to look at how the current system behaves in Windows. Discussion: http://lists.oasis-open.org/archives/docbook-apps/201011/msg00116.html
-
-  • kasunbg: template/common/images/loading.gif; template/common/jquery/
-    treeview/jquery.treevi⋯
-
-    webhelp: Removing some unnecessary JQuery JS files
-
-  • kasunbg: template/common/main.js
-
-    webhelp: Usability improvement - when click on a node in the TOC tree, the child nodes will auto populate now.
-
-  • kasunbg: xsl/webhelp.xsl
-
-    Added google translated localizations for Japanese, German, French, and Chinese. The translations might not be pretty accurate.
-    Better translations are appreciated.
-
-  • kasunbg: docsrc/readme.xml; template/content/images; template/content/
-    images/sample.jpg
-
-    Added documentation for how to add images to WebHelp
-
-  • Jirka Kosek: xsl/webhelp.xsl
-
-    Added more customization hooks
-    Search code output only when search tab is active
-    Added cs localization
-
-  • Jirka Kosek: xsl/webhelp.xsl
-
-    Added parameter webhelp.common.dir for specifying location of common files (JS+CSS)
-    Added hooks for adding additional user defined tabs
-
-Params
-
-The following changes have been made to the params code since the 1.76.1
-release.
-
-  • David Cramer: webhelp.indexer.language.xml
-
-    Webhelp: Fixing list of supported languages
-
-  • David Cramer: webhelp.indexer.language.xml
-
-    Webhelp: Correct language code in docs for Chinese
-
-  • Mauritz Jeanson: admon.graphics.extension.xml
-
-    Added list of graphics formats.
-
-  • Mauritz Jeanson: passivetex.extensions.xml
-
-    Updated link.
-
-  • tom_schr: webhelp.indexer.language.xml; webhelp.default.topic.xml;
-    webhelp.tree.cookie.id.⋯
-
-    Prepared WebHelp reference documentation :)
-    Not clear about parameters brandname and branding: Should they renamed
-    to "webhelp.branding" and "webhelp.brandname"?
-    Currently, docsrc/reference.xml contains only a comment for the WebHelp
-    ref doc to be non-intrusive.
-    Idea is to enable it when it is ready
-
-  • Robert Stayton: glossary.collection.xml
-
-    Add info about relative paths.
-
-  • Robert Stayton: para.properties.xml
-
-    Special attribute-set for para only.
-
-  • Robert Stayton: table.caption.properties.xml
-
-    To format table captions.
-
-  • Robert Stayton: html.script.type.xml; html.script.xml
-
-    Add support for specifying javascript references like css references.
-
-  • Robert Stayton: body.margin.outer.xml; region.outer.extent.xml;
-    body.margin.inner.xml; reg⋯
-
-    Add support for side regions in FO output.
-
-  • Robert Stayton: chunked.filename.prefix.xml
-
-    New param chunked.filename.prefix to separate any such prefix from
-    the base.dir param, which helps fix bug 3087359.
-
-  • Robert Stayton: generate.consistent.ids.xml
-
-    New param to support replacing generate-id() with xsl:number
-    for more consistent id values.
-
-  • Robert Stayton: task.properties.xml
-
-    Allow task to be customized more easily.
-
-  • Robert Stayton: calloutlist.properties.xml; callout.properties.xml
-
-    Support better customization of callout lists.
-
-  • Jirka Kosek: callout.unicode.start.character.xml
-
-    Added support for alternative circled numbers
-
-  • David Cramer: example.properties.xml
-
-    Made example.properties use keep-together='auto' like table.properies to avoid problems where example/programlisting takes more than one page
-
-  • Mauritz Jeanson: graphicsize.extension.xml
-
-    Added info about supported image formats.
-
-Highlighting
-
-The following changes have been made to the highlighting code since the 1.76.1
-release.
-
-  • Jirka Kosek: csharp-hl.xml
-
-    Added LINQ keywords
-
-  • Jirka Kosek: delphi-hl.xml
-
-    Additional keywords from Yuri Zhilin
-
-Profiling
-
-The following changes have been made to the profiling code since the 1.76.1
-release.
-
-  • David Cramer: profile-mode.xsl
-
-    When profile.* params only consist of space characters, then ignore them.
-
-Lib
-
-The following changes have been made to the lib code since the 1.76.1 release.
-
-  • Robert Stayton: lib.xweb
-
-    Added two utility templates to make lib.xsl work
-    without reference to other modules since it is used
-    that way with profiling/xsl2profile.xsl.
-
-  • Robert Stayton: lib.xweb
-
-    Fix trim.common.uri.paths to first resolve any ../ in
-    the paths.
-
-Template
-
-The following changes have been made to the template code since the 1.76.1
-release.
-
-  • Jirka Kosek: titlepage.xsl
-
-    Titlepage mechanism is now namespace aware to support XHTML. Please note that when generating titlepage template stylesheets you have to pass FO or XHTML namespace inside ns parameter. For HTML parameter should be empty.
-
-Extensions
-
-The following changes have been made to the extensions code since the 1.76.1
-release.
-
-  • kasunbg: Makefile
-
-    webhelp - Adding enable.stemming, toc.file build properties
-
-  • David Cramer: Makefile
-
-    Attempt to convince Makefile that webhelpindexer is dirty
-
-XSL-Saxon
-
-The following changes have been made to the xsl-saxon code since the 1.76.1
-release.
-
-  • Mauritz Jeanson: src/com/nwalsh/saxon/Verbatim.java; src/com/nwalsh/saxon/
-    FormatGraphicCal⋯
-
-    Added fixes to ensure that generated XHTML markup for callouts is in the proper namespace.
-
-Release Notes: 1.77.1
-
-The following is a list of changes that have been made since the 1.77.0
-release.
-
-FO
-
-The following changes have been made to the fo code since the 1.77.0 release.
-
-  • Robert Stayton: docbook.xsl
-
-    Import the VERSION.xsl file instead of VERSION so mimetype is interpreted correctly
-    from the filename.
-
-  • Robert Stayton: block.xsl
-
-    In sidebar, turn off space before first para if there is no title.
-
-  • Robert Stayton: math.xsl
-
-    Restored templates for mml:* elements that were accidentally deleted.
-
-HTML
-
-The following changes have been made to the html code since the 1.77.0 release.
-
-  • Robert Stayton: docbook.xsl
-
-    Import the VERSION.xsl file instead of VERSION so mimetype is interpreted correctly
-    from the filename.
-
-  • Robert Stayton: sections.xsl
-
-    Use $div.element variable in place of div to support html5 section element.
-    output
-
-  • Robert Stayton: autoidx.xsl
-
-    Fix bug 3528673, missing "separator" param on template with
-    match="indexterm" mode="reference".  That param is passed
-    for endofrange processing to output the range separator.
-
-Roundtrip
-
-The following changes have been made to the roundtrip code since the 1.77.0
-release.
-
-  • Robert Stayton: dbk2ooo.xsl; dbk2pages.xsl; dbk2wordml.xsl; dbk2wp.xsl
-
-    Import the VERSION.xsl file instead of VERSION so mimetype is interpreted correctly
-    from the filename.
-
-Slides
-
-The following changes have been made to the slides code since the 1.77.0
-release.
-
-  • Robert Stayton: html/slides-common.xsl
-
-    Import the VERSION.xsl file instead of VERSION so mimetype is interpreted correctly
-    from the filename.
-
-Website
-
-The following changes have been made to the website code since the 1.77.0
-release.
-
-  • Robert Stayton: website-common.xsl
-
-    Import the VERSION.xsl file instead of VERSION so mimetype is interpreted correctly
-    from the filename.
-
-Webhelp
-
-The following changes have been made to the webhelp code since the 1.77.0
-release.
-
-  • kasunbg: docsrc/readme.xml
-
-    updated webhelp documentation
-
-  • kasunbg: template/content/search/nwSearchFnt.js; xsl/webhelp-common.xsl
-
-    Removed the script htmlFileList.js since it's content is in htmlFileInfoList.js
-
-  • Robert Stayton: xsl/webhelp-common.xsl
-
-    In the <h1> output, replace call to 'get.doc.title' with
-    mode="title.markup" because get.doc.title returns only
-    the string value of the title, losing any markup such
-    as <trademark> or <superscript>.
-
-  • kasunbg: template/common/css/positioning.css; template/content/search/
-    nwSearchFnt.js
-
-    Remove unnecessary bits of code from webhelp
-
-  • David Cramer: docsrc/readme.xml
-
-    Webhelp: Minor edits to the readme
-
-  • David Cramer: xsl/webhelp.xsl; xsl/titlepage.templates.xsl; xsl/
-    titlepage.templates.xml
-
-    Webhelp: Suppress abstracts from titlepages. These are used to create the search result summary sentence and should not be shown
-
-  • David Cramer: build.xml
-
-    Webhelp: calculate path to profile.xsl from main build.xml file
-
-Release Notes: 1.76.1
-
-The following is a list of changes that have been made since the 1.76.0
-release.
-
-FO
-
-The following changes have been made to the fo code since the 1.76.0 release.
-
-  • Robert Stayton: docbook.xsl; xref.xsl; fop1.xsl
-
-    Apply patch to support named destination in fop1.xsl, per Sourceforge
-    bug report #3029845.
-
-HTML
-
-The following changes have been made to the html code since the 1.76.0 release.
-
-  • Keith Fahlgren: highlight.xsl
-
-    Implementing handling for <b> and <i>: transform to <strong> and <em> for XHTML outputs and do not use in the highliting output (per Mauritz Jeanson)
-
-Params
-
-The following changes have been made to the params code since the 1.76.0
-release.
-
-  • Robert Stayton: draft.mode.xml
-
-    Change default for draft.mode to 'no'.
-
-Release Notes: 1.76.0
-
-This release includes important bug fixes and adds the following significant
-feature changes:
-
-Webhelp
-
-    A new browser-based, cross-platform help format with full-text search and
-    other features typically found in help systems. See webhelp/docs/content/
-    ch01.html for more information and a demo.
-
-Gentext
-
-    Many updates and additions to translation/locales thanks to Red Hat, the
-    Fedora Project, and other contributors.
-
-Common
-
-    Faster localization support, as language files are loaded on demand.
-
-FO
-
-    Support for SVG content in imagedata added.
-
-HTML
-
-    Output improved when using 'make.clean.html' and a stock CSS file is now
-    provided.
-
-EPUB
-
-    A number of improvements to NCX, cover and image selection, and XHTML 1.1
-    element choices
-
-The following is a list of changes that have been made since the 1.75.2
-release.
-
-Gentext
-
-The following changes have been made to the gentext code since the 1.75.2
-release.
-
-  • rlandmann: locale/fa.xml
-
-                Update to Persian translation from the Fedora Project
-
-
-  • rlandmann: locale/nds.xml
-
-                Locale for Low German
-
-
-  • Mauritz Jeanson: locale/ka.xml; Makefile
-
-                Added support for Georgian based on patch #2917147.
-
-
-  • rlandmann: locale/nl.xml; locale/ja.xml
-
-                Updated translations from Red Hat and the Fedora Project
-
-
-  • rlandmann: locale/bs.xml; locale/ru.xml; locale/hr.xml
-
-                Updated locales from Red Hat and the Fedora Project
-
-
-  • rlandmann: locale/pt.xml; locale/cs.xml; locale/es.xml; locale/bg.xml;
-    locale/nl.xml; loca⋯
-
-                Updated translations from Red Hat and the Fedora Project
-
-
-  • rlandmann: locale/as.xml; locale/bn_IN.xml; locale/ast.xml; locale/ml.xml;
-    locale/te.xml; ⋯
-
-                New translations from Red Hat and the Fedora Project
-
-
-  • rlandmann: locale/pt.xml; locale/ca.xml; locale/da.xml; locale/sr.xml;
-    locale/ru.xml; loca⋯
-
-                Updated translations from Red Hat and the Fedora Project
-
-
-Common
-
-The following changes have been made to the common code since the 1.75.2
-release.
-
-  • Mauritz Jeanson: common.xsl
-
-                Fixed bug in output-orderedlist-starting-number template (@startingnumber did not work for FO).
-
-
-  • Mauritz Jeanson: gentext.xsl
-
-                Added fix to catch ID also of descendants of listitem. Closes bug #2955077.
-
-
-  • Jirka Kosek: l10n.xsl
-
-                Stripped down, faster version of gentext.template is used when there is no localization customization.
-
-
-  • Mauritz Jeanson: stripns.xsl
-
-                Added fix that preserves link/@role (makes links in the reference documentation
-    with @role="tcg" work).
-
-
-  • Mauritz Jeanson: l10n.xsl
-
-                Fixed bugs related to manpages and L10n.
-
-
-  • Jirka Kosek: entities.ent; autoidx-kosek.xsl
-
-                Upgraded to use common entities. Fixed bug when some code used @sortas and some not for grouping/sorting of indexterms.
-
-
-  • Jirka Kosek: l10n.xsl; l10n.dtd; l10n.xml; autoidx-kosek.xsl
-
-                Refactored localization support. Language files are loaded on demand. Speedup is about 30%.
-
-
-  • Jirka Kosek: l10n.xsl
-
-                Added xsl:keys for improved performance of localization texts look up. Performance gain around 15%.
-
-
-  • Mauritz Jeanson: titles.xsl
-
-                Fixed bug #2912677 (error with xref in title).
-
-
-  • Robert Stayton: olink.xsl
-
-                Fix bug in xrefstyle "title" handling introduced with
-    the 'insert.targetdb.data' template.
-
-
-  • Robert Stayton: gentext.xsl
-
-                Fix bug in xref to equation without title to use context="xref-number" instead
-    of "xref-number-and-title".
-
-
-  • Robert Stayton: labels.xsl
-
-                Number all equations in one sequence, with or without title.
-
-
-  • Robert Stayton: entities.ent
-
-                Fix bug #2896909 where duplicate @sortas on indexterms caused
-    some indexterms to drop out of index.
-
-
-  • Robert Stayton: stripns.xsl
-
-                Expand the "Stripping namespace ..." message to advise users to
-    use the namespaced stylesheets.
-
-
-  • Robert Stayton: stripns.xsl
-
-                need a local version of $exsl.node.set.available variable because
-    this module imported many places.
-
-
-  • Mauritz Jeanson: olink.xsl
-
-                Added /node() to the select expression that is used to compute the title text
-    so that no <ttl> elements end up in the output. Closes bug #2830119.
-
-
-FO
-
-The following changes have been made to the fo code since the 1.75.2 release.
-
-  • Robert Stayton: table.xsl
-
-                Fix bug 2979166 able - Attribute @rowheader not working
-
-
-  • Mauritz Jeanson: inline.xsl
-
-                Improved glossterm auto-linking by using keys. The old code was inefficient when processing documents
-    with many inline glossterms.
-
-
-  • Robert Stayton: titlepage.xsl
-
-                Fix bug 2805530 author/orgname not appearing on title page.
-
-
-  • Mauritz Jeanson: graphics.xsl
-
-                Added support for SVG content in imagedata (inspired by patch #2909154).
-
-
-  • Mauritz Jeanson: table.xsl
-
-                Removed superfluous test used when computing column-width. Closes bug #3000898.
-
-
-  • Mauritz Jeanson: inline.xsl
-
-                Added missing <xsl:call-template name="anchor"/>. Closes bug #2998567.
-
-
-  • Mauritz Jeanson: lists.xsl
-
-                Added table-layout="fixed" on segmentedlist table (required by XSL spec when  proportional-column-width() is used).
-
-
-  • Jirka Kosek: autoidx-kosek.xsl
-
-                Upgraded to use common entities. Fixed bug when some code used @sortas and some not for grouping/sorting of indexterms.
-
-
-  • Jirka Kosek: index.xsl
-
-                Upgraded to use common entities. Fixed bug when some code used @sortas and some not for grouping/sorting of indexterms.
-
-
-  • Robert Stayton: xref.xsl
-
-                Fix bug in olink template when an olink has an id.
-    Add warning message with id value when trying to link
-    to an element that has no generated text.
-
-
-  • Mauritz Jeanson: refentry.xsl
-
-                Fixed bug #2930968 (indexterm in refmeta not handled correctly).
-
-
-  • Robert Stayton: block.xsl
-
-                fix bug 2949567 title in revhistory breaks FO transform.
-
-
-  • Robert Stayton: glossary.xsl
-
-                Output id attributes on glossdiv blocks so they can be added to
-    xrefs or TOC.
-
-
-  • Jirka Kosek: xref.xsl
-
-                Enabled hyphenation of URLs when ulink content is the same as link target
-
-
-  • Robert Stayton: table.xsl
-
-                Apply patch to turn off row recursion if no @morerows attributes present.
-    This will enable very large tables without row spanning to
-    process without running into recursion limits.
-
-
-  • Robert Stayton: formal.xsl
-
-                Format equation without title using table layout with equation number
-    next to the equation.
-
-
-  • Robert Stayton: param.xweb; param.ent
-
-                Add equation.number.properties.
-
-
-HTML
-
-The following changes have been made to the html code since the 1.75.2 release.
-
-  • Mauritz Jeanson: block.xsl
-
-                Modified acknowledgements template to avoid invalid output (<p> in <p>).
-
-
-  • Mauritz Jeanson: titlepage.xsl
-
-                Added default sidebar attribute-sets.
-
-
-  • Robert Stayton: table.xsl
-
-                Fix bug 2979166 able - Attribute @rowheader not working
-
-
-  • Robert Stayton: footnote.xsl
-
-                Fix bug 3033191 footnotes in html tables.
-
-
-  • Mauritz Jeanson: inline.xsl
-
-                Improved glossterm auto-linking by using keys. The old code was inefficient when processing documents
-    with many inline glossterms.
-
-
-  • Robert Stayton: docbook.css.xml; verbatim.xsl
-
-                Fix bug 2844927 Validity error for callout bugs.
-
-
-  • Robert Stayton: formal.xsl
-
-                Convert formal.object.heading to respect make.clean.html param.
-
-
-  • Robert Stayton: titlepage.templates.xml; block.xsl
-
-                Fix bug 2840768 sidebar without title inserts empty b tag.
-
-
-  • Mauritz Jeanson: docbook.xsl
-
-                Moved the template that outputs <base> so that the base URI also applies to relative CSS paths that come later.
-    See patch #2896121.
-
-
-  • Jirka Kosek: autoidx-kosek.xsl
-
-                Upgraded to use common entities. Fixed bug when some code used @sortas and some not for grouping/sorting of indexterms.
-
-
-  • Robert Stayton: chunk-code.xsl
-
-                fix bug 2948363 generated filename for refentry not unique, when
-    used in a set.
-
-
-  • Robert Stayton: component.xsl
-
-                Fix missing "Chapter n" label when use chapter/info/title.
-
-
-  • Robert Stayton: table.xsl
-
-                Row recursion turned off if no @morerows attributes in the table.
-    This will prevent failure on long table (with no @morerows) due
-    to excessive depth of recursion.
-
-
-  • Robert Stayton: autotoc.xsl; docbook.css.xml
-
-                Support make.clean.html in autotoc.xsl.
-
-
-  • Robert Stayton: docbook.css.xml; block.xsl
-
-                Add support for make.clean.html setting in block elements.
-
-
-  • Robert Stayton: docbook.css.xml
-
-                Stock CSS styles for DocBook HTML output when 'make.clean.html' is non-zero.
-
-
-  • Robert Stayton: html.xsl
-
-                Add templates for generating CSS files and links to them.
-
-
-  • Robert Stayton: param.xweb
-
-                Fix bugs in new entity references.
-
-
-  • Robert Stayton: chunk-common.xsl
-
-                List of Equations now includes on equations with titles.
-
-
-  • Robert Stayton: table.xsl
-
-                If a colspec has a colname attribute, add it to the HTML col
-    element as a class attribute so it can be styled.
-
-
-  • Robert Stayton: formal.xsl
-
-                Fix bug 2825842 where table footnotes not appearing in HTML-coded table.
-
-
-  • Robert Stayton: chunktoc.xsl
-
-                Fix bug #2834826 where appendix inside part was not chunked as it should be.
-
-
-  • Mauritz Jeanson: chunktoc.xsl
-
-                Added missing namespace declarations. Closes bug #2890069.
-
-
-  • Mauritz Jeanson: footnote.xsl
-
-                Updated the template for footnote paras to use the 'paragraph' template. Closes bug #2803739.
-
-
-  • Keith Fahlgren: inline.xsl; lists.xsl
-
-                Remove <b> and <i> elements "discouraged in favor of style sheets" from
-    XHTML, XHTML 1.1 (and therefore EPUB) outputs by changing html2xhtml.xsl.
-
-    Fixes bug #2873153: No <b> and <i> tags in XHTML/EPUB
-
-    Added regression to EPUB specs:
-
-
-  • Mauritz Jeanson: inline.xsl
-
-                Fixed bug #2844916 (don't output @target if ulink.target is empty).
-
-
-  • Keith Fahlgren: autoidx.xsl
-
-                Fix a bug when using index.on.type: an 'index symbols' section was created
-    even if that typed index didn't include any symbols (they were in the other types).
-
-
-Manpages
-
-The following changes have been made to the manpages code since the 1.75.2
-release.
-
-  • Mauritz Jeanson: other.xsl
-
-                Modified the write.stubs template so that the section directory name is not output twice. Should fix bug #2831602.
-    Also ensured that $lang is added to the .so path (when man.output.lang.in.name.enabled=1).
-
-
-  • Mauritz Jeanson: docbook.xsl; other.xsl
-
-                Fixed bug #2412738 (apostrophe escaping) by applying the submitted patch.
-
-
-  • Norman Walsh: block.xsl; endnotes.xsl
-
-                Fix bug where simpara in footnote didn't work. Patch by Jonathan Nieder, jrnieder@gmail.com
-
-
-  • dleidert: lists.xsl
-
-                Fix two indentation issues: In the first case there is no corresponding .RS
-    macro (Debian #519438, sf.net 2793873). In the second case an .RS instead of
-    the probably intended .sp leads to an indentation bug (Debian #527309,
-    sf.net #2642139).
-
-
-Epub
-
-The following changes have been made to the epub code since the 1.75.2 release.
-
-  • Keith Fahlgren: bin/spec/examples/AMasqueOfDays.epub; docbook.xsl; bin/spec
-    /epub_spec.rb
-
-                Resolve some actual regressions in date output spotted by more recent versions of epubcheck
-
-
-  • Keith Fahlgren: docbook.xsl
-
-                Updated mediaobject selection code that better uses roles (when available); based on contributons by  Glenn McDonald
-
-
-  • Keith Fahlgren: bin/spec/epub_regressions_spec.rb; docbook.xsl
-
-                Ensure that NCX documents are always outputted with a default namespace
-    to prevent problems with the kindlegen machinery
-
-
-  • Keith Fahlgren: bin/spec/epub_regressions_spec.rb; bin/spec/files/
-    partintro.xml; docbook.x⋯
-
-                Adding support for partintros with sect2s, 3s, etc
-
-
-  • Keith Fahlgren: docbook.xsl
-
-                Adding param to workaround horrific ADE bug with the inability to process <br>
-
-
-  • Keith Fahlgren: docbook.xsl
-
-                Add support for authorgroup/author in OPF metadata (via Michael Wiedmann)
-
-
-  • Keith Fahlgren: bin/spec/epub_regressions_spec.rb
-
-                Remove <b> and <i> elements "discouraged in favor of style sheets" from
-    XHTML, XHTML 1.1 (and therefore EPUB) outputs by changing html2xhtml.xsl.
-
-    Fixes bug #2873153: No <b> and <i> tags in XHTML/EPUB
-
-    Added regression to EPUB specs:
-
-
-  • Keith Fahlgren: bin/lib/docbook.rb; bin/spec/files/DejaVuSerif-Italic.otf;
-    docbook.xsl; bi⋯
-
-                This resolves bug #2873142, Please add support for multiple embedded fonts
-
-
-    If you navigate to a checkout of DocBook-XSL and go to:
-    xsl/epub/bin/spec/files
-    You can now run the following command:
-
-    ../../dbtoepub -f DejaVuSerif.otf -f DejaVuSerif-Italic.otf -c test.css
-    -s test_cust.xsl orm.book.001.xml
-
-    In dbtoepub, the following option can be used more than once:
-    -f, --font [OTF FILE] Embed OTF FILE in .epub.
-
-    The underlying stylesheet now accepts a comma-separated list of font file
-    names rather than just one as the RENAMED epub.embedded.fonts ('s' added).
-
-    The runnable EPUB spec now includes:
-    - should be valid .epub after including more than one embedded font
-
-
-  • Keith Fahlgren: docbook.xsl
-
-                Improve the selection of cover images when working in DocBook 4.x land (work in progress)
-
-
-  • Keith Fahlgren: bin/spec/epub_regressions_spec.rb; docbook.xsl
-
-                Improve the quality of the OPF spine regression by ensuring that the spine
-    elements for deeply nested refentries are in order and adjacent to their
-    opening wrapper XHTML chunk.
-
-
-  • Keith Fahlgren: bin/spec/epub_regressions_spec.rb; docbook.xsl; bin/spec/
-    files/orm.book.00⋯
-
-                Add more careful handling of refentries to ensure that they always appear in the opf:spine.
-    This was only a problem when refentries were pushed deep into the hierarchy (like inside
-    a sect2), but presented navigational problems for many reading systems (despite the
-    correct NCX references). This may *not* be the best solution, but attacking a better
-    chunking strategy for refentries was too big a nut to crack at this time.
-
-
-Eclipse
-
-The following changes have been made to the eclipse code since the 1.75.2
-release.
-
-  • Mauritz Jeanson: eclipse3.xsl
-
-                Added a stylesheet module that generates plug-ins conforming to the standard (OSGi-based) Eclipse 3.x
-    architecture. The main difference to the older format is that metadata is stored in a separate
-    manifest file. The module imports and extends the existing eclipse.xsl module. Based on code
-    contributed in patch #2624668.
-
-
-Params
-
-The following changes have been made to the params code since the 1.75.2
-release.
-
-  • Robert Stayton: draft.watermark.image.xml
-
-                Fix bug 2922488 draft.watermark.image pointing to web resource.
-    Now the value is images/draft.png, and may require customization
-    for local resolution.
-
-
-  • Mauritz Jeanson: equation.number.properties.xml
-
-                Corrected refpurpose.
-
-
-  • Norman Walsh: paper.type.xml
-
-                Added USlegal and USlegallandscape paper types.
-
-
-  • Jirka Kosek: highlight.xslthl.config.xml
-
-                Added note about specifying location as URL
-
-
-  • Robert Stayton: docbook.css.source.xml; generate.css.header.xml;
-    custom.css.source.xml; ma⋯
-
-                Params to support generated CSS files.
-
-
-  • Robert Stayton: equation.number.properties.xml
-
-                New attribute set for numbers appearing next to equations.
-
-
-XSL-Xalan
-
-The following changes have been made to the xsl-xalan code since the 1.75.2
-release.
-
-  • dleidert: nbproject/genfiles.properties; nbproject/build-impl.xml
-
-                Rebuild netbeans build files after adding missing Netbeans configuration to allow easier packaging for Debian.
-
-
-Release Notes: 1.75.2
-
-The following is a list of changes that have been made since the 1.75.1
-release.
-
-Gentext
-
-The following changes have been made to the gentext code since the 1.75.1
-release.
-
-  • dleidert: locale/ja.xml
-
-    Improved Japanese translation for Note(s). Closes bug #2823965.
-
-  • dleidert: locale/pl.xml
-
-    Polish alphabet contains O with acute accent, not with grave accent. Closes bug #2823964.
-
-  • Robert Stayton: locale/ja.xml
-
-    Fix translation of "index", per bug report 2796064.
-
-  • Robert Stayton: locale/is.xml
-
-    New Icelandic locale file.
-
-Common
-
-The following changes have been made to the common code since the 1.75.1
-release.
-
-  • Norman Walsh: stripns.xsl
-
-    Support more downconvert cases
-
-  • Robert Stayton: titles.xsl
-
-    Make sure title inside info is used if no other title.
-
-FO
-
-The following changes have been made to the fo code since the 1.75.1 release.
-
-  • Robert Stayton: pi.xsl
-
-    Turn off dbfo-need for fop1.extensions also, per bug #2816141.
-
-HTML
-
-The following changes have been made to the html code since the 1.75.1 release.
-
-  • Mauritz Jeanson: titlepage.xsl
-
-    Output "Copyright" heading in XHTML too.
-
-  • Mauritz Jeanson: titlepage.xsl
-
-    Added stylesheet.result.type test for copyright. Closes bug #2813289.
-
-  • Norman Walsh: htmltbl.xsl
-
-    Remove ambiguity wrt @span, @rowspan, and @colspan
-
-Manpages
-
-The following changes have been made to the manpages code since the 1.75.1
-release.
-
-  • Mauritz Jeanson: endnotes.xsl
-
-    Added normalize-space() for ulink content. Closes bug #2793877.
-
-  • Mauritz Jeanson: docbook.xsl
-
-    Added stylesheet.result.type test for copyright. Closes bug #2813289.
-
-Epub
-
-The following changes have been made to the epub code since the 1.75.1 release.
-
-  • Keith Fahlgren: bin/dbtoepub; bin/lib/docbook.rb
-
-    Corrected bugs caused by path and file assumptions were not met
-
-  • Keith Fahlgren: bin/lib/docbook.rb; docbook.xsl
-
-    Cleaning up hardcoded values into parameters and fixing Ruby library to pass them properly; all thanks to patch from Liza Daly
-
-Profiling
-
-The following changes have been made to the profiling code since the 1.75.1
-release.
-
-  • Robert Stayton: profile.xsl
-
-    Fix bug 2815493 missing exsl.node.set.available parameter.
-
-XSL-Saxon
-
-The following changes have been made to the xsl-saxon code since the 1.75.1
-release.
-
-  • Mauritz Jeanson: src/com/nwalsh/saxon/ColumnUpdateEmitter.java; src/com/
-    nwalsh/saxon/Colum⋯
-
-    Added fixes so that colgroups in the XHTML namespace are processed properly.
-
-XSL-Xalan
-
-The following changes have been made to the xsl-xalan code since the 1.75.1
-release.
-
-  • Mauritz Jeanson: nbproject/project.xml
-
-    Added missing NetBeans configuration.
-
-Release Notes: 1.75.1
-
-This release includes bug fixes.
-
-The following is a list of changes that have been made since the 1.75.0
-release.
-
-FO
-
-The following changes have been made to the fo code since the 1.75.0 release.
-
-  • Keith Fahlgren: block.xsl
-
-    Switching to em dash for character before attribution in epigraph; resolves Bug #2793878
-
-  • Robert Stayton: lists.xsl
-
-    Fixed bug 2789947, id attribute missing on simplelist fo output.
-
-HTML
-
-The following changes have been made to the html code since the 1.75.0 release.
-
-  • Keith Fahlgren: block.xsl
-
-    Switching to em dash for character before attribution in epigraph; resolves Bug #2793878
-
-  • Robert Stayton: lists.xsl
-
-    Fixed bug 2789678: apply-templates line accidentally deleted.
-
-Epub
-
-The following changes have been made to the epub code since the 1.75.0 release.
-
-  • Keith Fahlgren: bin/spec/epub_regressions_spec.rb; docbook.xsl
-
-    Added regression and fix to correct "bug" with namespace-prefixed container elements in META-INF/container.xml ; resolves Issue #2790017
-
-  • Keith Fahlgren: bin/spec/epub_regressions_spec.rb; bin/spec/files/
-    onegraphic.xinclude.xml;⋯
-
-    Another attempt at flexible named entity and XInclude processing
-
-  • Keith Fahlgren: bin/lib/docbook.rb
-
-    Tweaking solution to Bug #2750442 following regression reported by Michael Wiedmann.
-
-Params
-
-The following changes have been made to the params code since the 1.75.0
-release.
-
-  • Mauritz Jeanson: highlight.source.xml
-
-    Updated documentation to reflect changes made in r8419.
-
-Release Notes: 1.75.0
-
-This release includes important bug fixes and adds the following significant
-feature changes:
-
-Gentext
-
-    Modifications to translations have been made.
-
-Common
-
-    Added support for some format properties on tables using HTML table markup.
-
-    Added two new qanda.defaultlabel values so that numbered sections and
-    numbered questions can be distinguished. Satisfies Feature Request #
-    1539045.
-
-    Added code to handle acknowledgements in book and part. The element is
-    processed similarly to dedication. All acknowledgements will appear as
-    front matter, after any dedications.
-
-FO
-
-    The inclusion of highlighting code has been simplified.
-
-    Add support for pgwide on informal objects.
-
-    Added a new parameter, bookmarks.collapse, that controls the initial state
-    of the bookmark tree. Closes FR #1792326.
-
-    Add support for more dbfo processing instructions.
-
-    Add new variablelist.term.properties to format terms, per request #
-    1968513.
-
-    Add support for @width on screen and programlisting, fixes bug #2012736.
-
-    Add support for writing-mode="rl-tb" (right-to-left) in FO outputs.
-
-    Add writing.mode param for FO output.
-
-HTML
-
-    Convert all calls to class.attribute to calls to common.html.attributes to
-    support dir, lang, and title attributes in html output for all elements.
-    Fulfills feature request #1993833.
-
-    Inclusion of highlighting code was simplified. Only one import is now
-    necessary.
-
-    Add new param index.links.to.section.
-
-    Add support for the new index.links.to.section param which permits precise
-    links to indexterms in HTML output rather than to the section title.
-
-ePub
-
-    Slightly more nuanced handling of imageobject alternatives and better
-    support in dbtoepub for XIncludes and ENTITYs to resolve Issue #2750442
-    reported by Raphael Hertzog.
-
-    Added a colon after an abstract/title when mapping into the dc:description
-    for OPF metadata in ePub output to help the flat text have more
-    pseudo-semantics (sugestions from Michael Wiedmann)
-
-    Added DocBook subjectset -> OPF dc:subject mapping and tests
-
-    Added DocBook date -> OPF dc:date mapping and tests
-
-    Added DocBook abstract -> OPF dc:description mapping and tests
-
-    Added --output option to dbtoepub based on user request
-
-HTMLHelp
-
-    Add support for generating olink target database for htmlhelp files.
-
-Params
-
-    Add default setting for @rules attribute on HTML markup tables.
-
-    Added a new parameter, bookmarks.collapse, that controls the initial state
-    of the bookmark tree. When the parameter has a non-zero value (the
-    default), only the top-level bookmarks are displayed initially. Otherwise,
-    the whole tree of bookmarks is displayed. This is implemented for FOP 0.9X.
-    Closes FR #1792326.
-
-    Add new variablelist.term.properties to format terms, per request #
-    1968513.
-
-    Add two new qanda.defaultlabel values so that numbered sections and
-    numbered questions can be distinguished. Satisfies Feature Request #
-    1539045.
-
-    Add param to control whether an index entry links to a section title or to
-    the precise location of the indexterm.
-
-    New attribute list for glossentry in glossary.
-
-    New parameter to support @width on programlisting and screen.
-
-    Add attribute-sets for formatting glossary terms and defs.
-
-Highlighting
-
-    Inclusion of highlighting code was simplified. Only one import is now
-    necessary.
-
-The following is a list of changes that have been made since the 1.74.3
-release.
-
-Gentext
-
-The following changes have been made to the gentext code since the 1.74.3
-release.
-
-  • Robert Stayton: locale/sv.xml; locale/ja.xml; locale/pl.xml
-
-    Check in translations of Legalnotice submitted on mailing list.
-
-  • Robert Stayton: locale/es.xml
-
-    Fix spelling errors in Acknowledgements entries.
-
-  • Robert Stayton: locale/es.xml
-
-    Check in translations for 4 elements submitted through docbook-apps
-    message of 14 April 2009.
-
-  • David Cramer: locale/zh.xml; locale/ca.xml; locale/ru.xml; locale/ga.xml;
-    locale/gl.xml; l⋯
-
-    Internationalized punctuation in glosssee and glossseealso
-
-  • Robert Stayton: Makefile
-
-    Check in fixes for DSSSL gentext targets from submitted patch #1689633.
-
-  • Robert Stayton: locale/uk.xml
-
-    Check in major update submitted with bug report #2008524.
-
-  • Robert Stayton: locale/zh_tw.xml
-
-    Check in fix to Note string submitted in bug #2441051.
-
-  • Robert Stayton: locale/ru.xml
-
-    Checkin typo fix submitted in bug #2453406.
-
-Common
-
-The following changes have been made to the common code since the 1.74.3
-release.
-
-  • Robert Stayton: gentext.xsl
-
-    Fix extra generated space when xrefstyle includes 'nopage'.
-
-  • Robert Stayton: table.xsl
-
-    Add support for some format properties on tables using
-    HTML table markup.  These include:
-      - frame attribute on table (or uses $default.table.frame parameter).
-      - rules attribute on table (or uses $default.table.rules parameter).
-      - align attribute on td and th
-      - valign attribute on td and th
-      - colspan on td and th
-      - rowspan on td and th
-      - bgcolor on td and th
-
-  • Robert Stayton: olink.xsl
-
-    Add placeholder template to massage olink hot text to make
-    customization easier, per Feature Request 1828608.
-
-  • Robert Stayton: targets.xsl
-
-    Add support for collecting olink targets from a glossary
-    generated from a glossary.collection.
-
-  • Robert Stayton: titles.xsl
-
-    Handle firstterm like glossterm in mode="title.markup".
-
-  • Robert Stayton: titles.xsl
-
-    Add match on info/title in title.markup templates where missing.
-
-  • Mauritz Jeanson: titles.xsl
-
-    Changed "ancestor::title" to "(ancestor::title and (@id or @xml:id))".
-    This enables proper formatting of inline elements in titles in TOCs,
-    as long as these inlines don't have id or xml:id attributes.
-
-  • Robert Stayton: labels.xsl
-
-    Add two new qanda.defaultlabel values so that numbered sections
-    and numbered questions can be distinguished.  Satisfies
-    Feature Request #1539045.
-
-  • Robert Stayton: stripns.xsl; pi.xsl
-
-    Convert function-available(exsl:node-set) to use the new param
-    so Xalan bug is isolated.
-
-  • Mauritz Jeanson: titles.xsl
-
-    Added fixes for bugs #2112656 and #1759205:
-    1. Reverted mistaken commits r7485 and r7523.
-    2. Updated the template with match="link" and mode="no.anchor.mode" so that
-    @endterm is used if it exists and if the link has no content.
-
-  • Mauritz Jeanson: titles.xsl
-
-    Added code to handle acknowledgements in book and part. The element is processed
-    similarly to dedication. All acknowledgements will appear as front matter, after
-    any dedications.
-
-  • Robert Stayton: olink.xsl
-
-    Fix bug #2018717 use.local.olink.style uses wrong gentext context.
-
-  • Robert Stayton: olink.xsl
-
-    Fix bug #1787167 incorrect hot text for some olinks.
-
-  • Robert Stayton: common.xsl
-
-    Fix bug #1669654 Broken output if copyright <year> contains a range.
-
-  • Robert Stayton: labels.xsl
-
-    Fix bug in labelling figure inside appendix inside article inside book.
-
-FO
-
-The following changes have been made to the fo code since the 1.74.3 release.
-
-  • Jirka Kosek: highlight.xsl
-
-    Inclusion of highlighting code was simplified. Only one import is now necessary.
-
-  • Robert Stayton: fop1.xsl
-
-    Add the new fop extensions namespace declaration, in case FOP
-    extension functions are used.
-
-  • Robert Stayton: formal.xsl
-
-    Add support for pgwide on informal objects.
-
-  • Robert Stayton: docbook.xsl
-
-    Fixed spurious closing quote on line 134.
-
-  • Robert Stayton: docbook.xsl; autoidx-kosek.xsl; autoidx.xsl
-
-    Convert function-available for node-set() to use
-    new $exsl.node.set.available param in test.
-
-  • David Cramer: xref.xsl
-
-    Suppress extra space after xref when xrefstyle='select: label nopage' (#2740472)
-
-  • Mauritz Jeanson: pi.xsl
-
-    Fixed doc bug for row-height.
-
-  • David Cramer: glossary.xsl
-
-    Internationalized punctuation in glosssee and glossseealso
-
-  • Robert Stayton: param.xweb; param.ent; htmltbl.xsl; table.xsl
-
-    Add support for some format properties on tables using
-    HTML table markup.  These include:
-      - frame attribute on table (or uses $default.table.frame parameter).
-      - rules attribute on table (or uses $default.table.rules parameter).
-      - align attribute on td and th
-      - valign attribute on td and th
-      - colspan on td and th
-      - rowspan on td and th
-      - bgcolor on td and th
-
-  • Robert Stayton: table.xsl
-
-    Add support bgcolor in td and th
-    elements in HTML table markup.
-
-  • Robert Stayton: htmltbl.xsl
-
-    Add support for colspan and rowspan and bgcolor in td and th
-    elements in HTML table markup.
-
-  • Robert Stayton: param.xweb
-
-    Fix working of page-master left and right margins.
-
-  • Mauritz Jeanson: param.xweb; param.ent; fop1.xsl
-
-    Added a new parameter, bookmarks.collapse, that controls the initial state of the bookmark tree. When the parameter has a non-zero value (the default), only the top-level bookmarks are displayed initially. Otherwise, the whole tree of bookmarks is displayed.  This is implemented for FOP 0.9X. Closes FR #1792326.
-
-  • Robert Stayton: table.xsl; pi.xsl
-
-    Add support for dbfo row-height processing instruction, like that in dbhtml.
-
-  • Robert Stayton: lists.xsl
-
-    Add support for dbfo keep-together processing instruction for
-    entire list instances.
-
-  • Robert Stayton: lists.xsl; block.xsl
-
-    Add support fo dbfo keep-together processing instruction to
-    more blocks like list items and paras.
-
-  • Robert Stayton: lists.xsl; param.xweb; param.ent
-
-    Add new variablelist.term.properties to format terms, per request # 1968513.
-
-  • Robert Stayton: inline.xsl
-
-    In simple.xlink, rearrange order of processing.
-
-  • Robert Stayton: xref.xsl
-
-    Handle firstterm like glossterm in mode="xref-to".
-
-  • Robert Stayton: glossary.xsl; xref.xsl; pi.xsl; footnote.xsl
-
-    Implement simple.xlink for glosssee and glossseealso so they can use
-    other types of linking besides otherterm.
-
-  • Robert Stayton: qandaset.xsl
-
-    Add two new qanda.defaultlabel values so that numbered sections and numbered questions can be distinguished.  Satisfies Feature Request #1539045.
-
-  • Robert Stayton: titlepage.xsl
-
-    For the book title templates, I changed info/title to book/info/title
-    so other element's titles will not be affected.
-
-  • Robert Stayton: xref.xsl; verbatim.xsl
-
-    Use param exsl.node.set.available to test for function.
-
-  • Robert Stayton: param.xweb; param.ent; footnote.xsl
-
-    Start using new param exsl.node.set.available to work around Xalan bug.
-
-  • Robert Stayton: titlepage.templates.xml
-
-    Add comment on use of t:predicate for editor to prevent
-    extra processing of multiple editors. Fixes bug 2687842.
-
-  • Robert Stayton: xref.xsl; autoidx.xsl
-
-    An indexterm primary, secondary, or tertiary element with an id or xml:id
-    now outputs that ID, so that index entries can be cross referenced to.
-
-  • Mauritz Jeanson: synop.xsl
-
-    Added modeless template for ooclass|oointerface|ooexception.
-    Closes bug #1623468.
-
-  • Robert Stayton: xref.xsl
-
-    Add template with match on indexterm in mode="xref-to" to fix bug 2102592.
-
-  • Robert Stayton: xref.xsl
-
-    Now xref to qandaentry will use the label element in a question for
-    the link text if it has one.
-
-  • Robert Stayton: inline.xsl
-
-    Add id if specified from @id to output for quote and phrase so
-    they can be xref'ed to.
-
-  • Robert Stayton: xref.xsl
-
-    Add support for xref to phrase, simpara, anchor, and quote.
-    This assumes the author specifies something using xrefstyle since
-    the elements don't have ordinary link text.
-
-  • Robert Stayton: toc.xsl
-
-    Fix bug in new toc templates.
-
-  • Mauritz Jeanson: titlepage.xsl; component.xsl; division.xsl; xref.xsl;
-    titlepage.templates⋯
-
-    Added code to handle acknowledgements in book and part. The element is processed
-    similarly to dedication. All acknowledgements will appear as front matter, after
-    any dedications.
-
-  • Robert Stayton: toc.xsl
-
-    Rewrite toc templates to support an empty toc or populated toc
-    in all permitted contexts.  Same for lot elements.
-    This fixes bug #1595969 for FO outputs.
-
-  • Robert Stayton: index.xsl
-
-    Fix indents for seealsoie so they are consistent.
-
-  • Mauritz Jeanson: param.xweb
-
-    Removed duplicate (monospace.font.family).
-
-  • Robert Stayton: param.xweb; param.ent
-
-    Add glossentry.list.item.properties.
-
-  • Robert Stayton: param.xweb; param.ent
-
-    Add monospace.verbatim.font.width param to support @width on programlisting.
-
-  • Robert Stayton: verbatim.xsl
-
-    Put programlisting in fo:block-container with writing-mode="lr-tb"
-    when text direction is right to left because all program languages
-    are left-to-right.
-
-  • Robert Stayton: verbatim.xsl
-
-    Add support for @width on screen and programlisting, fixes bug #2012736.
-
-  • Robert Stayton: xref.xsl
-
-    Fix bug #1973585 xref to para with xrefstyle not handled correctly.
-
-  • Mauritz Jeanson: block.xsl
-
-    Added support for acknowledgements in article.
-    Support in book/part remains to be added.
-
-  • Robert Stayton: xref.xsl
-
-    Fix bug #1787167 incorrect hot text for some olinks.
-
-  • Robert Stayton: fo.xsl
-
-    Add writing-mode="tb-rl" as well since some XSL-FO processors support it.
-
-  • Robert Stayton: autotoc.xsl; lists.xsl; glossary.xsl; fo.xsl; table.xsl;
-    pagesetup.xsl
-
-    Add support for writing-mode="rl-tb" (right-to-left) in FO outputs.
-    Changed instances of margin-left to margin-{$direction.align.start}
-    and margin-right to margin-{$direction.align.end}. Those direction.align
-    params are computed from the writing mode value in each locale's
-    gentext key named 'writing-mode', introduced in 1.74.3 to add
-    right-to-left support to HTML outputs.
-
-  • Robert Stayton: param.xweb; param.ent
-
-    Add attribute-sets for formatting glossary terms and defs.
-
-  • Robert Stayton: param.xweb; param.ent
-
-    Add writing.mode param for FO output.
-
-  • Robert Stayton: autotoc.xsl
-
-    Fix bug 1546008: in qandaentry in a TOC, use its blockinfo/titleabbrev or blockinfo/title
-    instead of question, if available. For DocBook 5, use the info versions.
-
-  • Keith Fahlgren: verbatim.xsl
-
-    Add better pointer to README for XSLTHL
-
-  • Keith Fahlgren: verbatim.xsl
-
-    More tweaking the way that XSLTHL does or does not get called
-
-  • Keith Fahlgren: verbatim.xsl
-
-    Alternate attempt at sanely including/excluding XSLTHT code
-
-HTML
-
-The following changes have been made to the html code since the 1.74.3 release.
-
-  • Robert Stayton: lists.xsl
-
-    Removed redundant lang and title attributes on list element inside
-    div element for lists.
-
-  • Robert Stayton: inline.xsl; titlepage.xsl; division.xsl; toc.xsl;
-    sections.xsl; table.xsl;⋯
-
-    Convert all calls to class.attribute to calls to common.html.attributes
-    to support dir, lang, and title attributes in html output for all elements.
-    Fulfills feature request #1993833.
-
-  • Robert Stayton: chunk-common.xsl
-
-    Fix bug #2750253 wrong links in list of figures in chunk.html
-    when target html is in a subdirectory and dbhtml filename used.
-
-  • Jirka Kosek: highlight.xsl
-
-    Inclusion of highlighting code was simplified. Only one import is now necessary.
-
-  • Robert Stayton: chunk-common.xsl; chunktoc.xsl; docbook.xsl;
-    chunk-changebars.xsl; autoidx⋯
-
-    Convert function-available for node-set() to use
-    new $exsl.node.set.available param in test.
-
-  • Mauritz Jeanson: pi.xsl
-
-    Fixed doc bug for row-height.
-
-  • David Cramer: glossary.xsl
-
-    Internationalized punctuation in glosssee and glossseealso
-
-  • Robert Stayton: lists.xsl; html.xsl; block.xsl
-
-    More elements get common.html.attributes.
-    Added locale.html.attributes template which does the lang,
-    dir, and title attributes, but not the class attribute
-    (used on para, for example).
-
-  • Robert Stayton: lists.xsl
-
-    Replace more literal class atts with mode="class.attribute" to support
-    easier customization.
-
-  • Robert Stayton: glossary.xsl
-
-    Support olinking in glosssee and glossseealso.
-
-  • Robert Stayton: inline.xsl
-
-    In simple.xlink, rearrange order of processing.
-
-  • Robert Stayton: xref.xsl
-
-    Handle firstterm like glossterm in mode="xref-to".
-
-  • Robert Stayton: lists.xsl; html.xsl; block.xsl
-
-    Added template named common.html.attributes to output
-    class, title, lang, and dir for most elements.
-    Started adding it to some list and block elements.
-
-  • Robert Stayton: qandaset.xsl
-
-    Add two new qanda.defaultlabel values so that numbered sections
-    and numbered questions can be distinguished.  Satisfies
-    Feature Request #1539045.
-
-  • Robert Stayton: param.xweb; chunk-code.xsl; param.ent; xref.xsl;
-    chunkfast.xsl; verbatim.x⋯
-
-    Use new param exsl.node.set.available to test, handles Xalan bug.
-
-  • Robert Stayton: autoidx.xsl
-
-    Use named anchors for primary, secondary, and tertiary ids so
-    duplicate entries with different ids can still have an id output.
-
-  • Robert Stayton: param.xweb; param.ent
-
-    Add new param index.links.to.section.
-
-  • Robert Stayton: xref.xsl; autoidx.xsl
-
-    Pass through an id on primary, secondary, or tertiary to
-    the index entry, so that one could link to an index entry.
-    You can't link to the id on an indexterm because that is
-    used to place the main anchor in the text flow.
-
-  • Robert Stayton: autoidx.xsl
-
-    Add support for the new index.links.to.section param which permits
-    precise links to indexterms in HTML output rather than to
-    the section title.
-
-  • Mauritz Jeanson: synop.xsl
-
-    Added modeless template for ooclass|oointerface|ooexception.
-    Closes bug #1623468.
-
-  • Robert Stayton: qandaset.xsl
-
-    Make sure a qandaset has an anchor, even when it has no title,
-    because it may be referenced in a TOC or xref.
-    Before, the anchor was output by the title, but there was no
-    anchor if there was no title.
-
-  • Robert Stayton: xref.xsl
-
-    Add a template for indexterm with mode="xref-to" to fix bug 2102592.
-
-  • Robert Stayton: xref.xsl
-
-    Now xref to qandaentry will use the label element in a question for
-    the link text if it has one.
-
-  • Robert Stayton: qandaset.xsl; html.xsl
-
-    Create separate templates for computing label of question and answer
-    in a qandaentry, so such can be used for the alt text of an xref
-    to a qandaentry.
-
-  • Robert Stayton: inline.xsl; xref.xsl
-
-    Now support xref to phrase, simpara, anchor, and quote,
-    most useful when an xrefstyle is used.
-
-  • Robert Stayton: toc.xsl
-
-    Rewrite toc templates to support an empty toc or populated toc
-    in all permitted contexts.  Same for lot elements.
-    This fixes bug #1595969 for HTML outputs.
-
-  • Mauritz Jeanson: titlepage.xsl; component.xsl; division.xsl; xref.xsl;
-    titlepage.templates⋯
-
-    Added code to handle acknowledgements in book and part. The element is processed
-    similarly to dedication. All acknowledgements will appear as front matter, after
-    any dedications.
-
-  • Robert Stayton: index.xsl
-
-    Rewrote primaryie, secondaryie and tertiaryie templates to handle
-    nesting of elements and seeie and seealsoie, as reported in
-    bug # 1168912.
-
-  • Robert Stayton: autotoc.xsl
-
-    Fix simplesect in toc problem.
-
-  • Robert Stayton: verbatim.xsl
-
-    Add support for @width per bug report #2012736.
-
-  • Robert Stayton: formal.xsl; htmltbl.xsl
-
-    Fix bug #1787140 HTML tables not handling attributes correctly.
-
-  • Robert Stayton: param.xweb
-
-    Move writing-mode param.
-
-  • Keith Fahlgren: refentry.xsl
-
-    Remove a nesting of <p> inside <p> for refclass (made XHTML* invalid, made HTML silly)
-
-  • Robert Stayton: table.xsl
-
-    Fix bug #1945872 to allow passthrough of colwidth values to
-    HTML table when no tablecolumns.extension is available and
-    when no instance of * appears in the table's colspecs.
-
-  • Mauritz Jeanson: block.xsl
-
-    Added support for acknowledgements in article.
-    Support in book/part remains to be added.
-
-  • Robert Stayton: chunk-common.xsl
-
-    Fix bug #1787167 incorrect hot text for some olinks.
-
-  • Robert Stayton: qandaset.xsl
-
-    Fix bug 1546008: in qandaentry in a TOC, use its blockinfo/titleabbrev or blockinfo/title
-    instead of question, if available. For DocBook 5, use the info versions.
-
-  • Robert Stayton: chunktoc.xsl
-
-    Add support for generating olink database when using chunktoc.xsl.
-
-  • Keith Fahlgren: verbatim.xsl
-
-    Add better pointer to README for XSLTHL
-
-  • Keith Fahlgren: verbatim.xsl
-
-    Another stab at fixing the stupid XSLTHT includes across processors (Saxon regression reported by Sorin Ristache)
-
-  • Keith Fahlgren: verbatim.xsl
-
-    More tweaking the way that XSLTHL does or does not get called
-
-  • Keith Fahlgren: verbatim.xsl
-
-    Alternate attempt at sanely including/excluding XSLTHT code
-
-Manpages
-
-The following changes have been made to the manpages code since the 1.74.3
-release.
-
-  • Robert Stayton: table.xsl
-
-    Convert function-available test for node-set() function to
-    test of $exsl.node.set.available param.
-
-  • Mauritz Jeanson: lists.xsl
-
-    Added a template for bibliolist. Closes bug #1815916.
-
-ePub
-
-The following changes have been made to the epub code since the 1.74.3 release.
-
-  • Keith Fahlgren: bin/spec/epub_regressions_spec.rb; bin/spec/files/
-    onegraphic.xinclude.xml;⋯
-
-    Slightly more nuanced handling of imageobject alternatives and better support in dbtoepub for XIncludes and ENTITYs to resolve Issue #2750442 reported by Raphael Hertzog.
-
-  • Keith Fahlgren: docbook.xsl
-
-    Add a colon after an abstract/title when mapping into the dc:description for OPF metadata in ePub output to help the flat text have more pseudo-semantics (sugestions from Michael Wiedmann)
-
-  • Keith Fahlgren: bin/spec/epub_regressions_spec.rb; docbook.xsl; bin/spec/
-    files/de.xml
-
-    Correctly set dc:language in OPF metadata when i18nizing. Closes Bug #2755150
-
-  • Keith Fahlgren: bin/spec/epub_regressions_spec.rb; docbook.xsl
-
-    Corrected namespace declarations for literal XHTML elements to make them serialize "normally"
-
-  • Keith Fahlgren: docbook.xsl
-
-    Be a little bit more nuanced about dates
-
-  • Keith Fahlgren: docbook.xsl; bin/spec/epub_realbook_spec.rb; bin/spec/files
-    /orm.book.001.x⋯
-
-    Add DocBook subjectset -> OPF dc:subject mapping and tests
-
-  • Keith Fahlgren: docbook.xsl; bin/spec/epub_realbook_spec.rb; bin/spec/files
-    /orm.book.001.x⋯
-
-    Add DocBook date -> OPF dc:date mapping and tests
-
-  • Keith Fahlgren: docbook.xsl; bin/spec/epub_realbook_spec.rb; bin/spec/files
-    /orm.book.001.x⋯
-
-    Add DocBook abstract -> OPF dc:description mapping and tests
-
-  • Robert Stayton: docbook.xsl
-
-    Check in patch submitted by user to add opf:file-as attribute
-    to dc:creator element.
-
-  • Keith Fahlgren: bin/dbtoepub
-
-    Adding --output option to dbtoepub based on user request
-
-  • Keith Fahlgren: docbook.xsl; bin/spec/epub_spec.rb
-
-    Cleaning and regularizing the generation of namespaced nodes for OPF, NCX, XHTML and other outputted filetypes (hat tip to bobstayton for pointing out the silly, incorrect code)
-
-  • Keith Fahlgren: bin/spec/epub_regressions_spec.rb; bin/spec/files/
-    refclass.xml
-
-    Remove a nesting of <p> inside <p> for refclass (made XHTML* invalid, made HTML silly)
-
-  • Keith Fahlgren: bin/spec/epub_regressions_spec.rb; bin/spec/files/
-    blockquotepre.xml
-
-    Added regression test and fix for XHTML validation problem with <a>s added inside <blockquote>; This potentially causes another problem (where something is referenced by has no anchor, but someone reporting that should cause the whole <a id='thing'/> thing to be reconsidered with modern browsers in mind.
-
-HTMLHelp
-
-The following changes have been made to the htmlhelp code since the 1.74.3
-release.
-
-  • Robert Stayton: htmlhelp-common.xsl
-
-    Add support for generating olink target database for htmlhelp files.
-
-Params
-
-The following changes have been made to the params code since the 1.74.3
-release.
-
-  • Robert Stayton: default.table.rules.xml
-
-    Add default setting for @rules attribute on HTML markup tables.
-
-  • Mauritz Jeanson: bookmarks.collapse.xml
-
-    Added a new parameter, bookmarks.collapse, that controls the initial state
-    of the bookmark tree. When the parameter has a non-zero value (the default),
-    only the top-level bookmarks are displayed initially. Otherwise, the whole
-    tree of bookmarks is displayed.
-
-    This is implemented for FOP 0.9X. Closes FR #1792326.
-
-  • Robert Stayton: variablelist.term.properties.xml
-
-    Add new variablelist.term.properties to format terms, per
-    request # 1968513.
-
-  • Robert Stayton: qanda.defaultlabel.xml
-
-    Add two new qanda.defaultlabel values so that numbered sections
-    and numbered questions can be distinguished.  Satisfies
-    Feature Request #1539045.
-
-  • Robert Stayton: index.links.to.section.xml
-
-    Change default to 1 to match past behavior.
-
-  • Robert Stayton: exsl.node.set.available.xml
-
-    Isolate this text for Xalan bug regarding exsl:node-set available.
-    If it is ever fixed in Xalan, just fix it here.
-
-  • Robert Stayton: index.links.to.section.xml
-
-    Add param to control whether an index entry links to
-    a section title or to the precise location of the
-    indexterm.
-
-  • Robert Stayton: glossentry.list.item.properties.xml
-
-    New attribute list for glossentry in glossary.
-
-  • Robert Stayton: monospace.verbatim.font.width.xml
-
-    New parameter to support @width on programlisting and screen.
-
-  • Mauritz Jeanson: highlight.source.xml
-
-    Updated and reorganized the description.
-
-  • Robert Stayton: page.margin.outer.xml; page.margin.inner.xml
-
-    Add caveat about XEP bug when writing-mode is right-to-left.
-
-  • Robert Stayton: article.appendix.title.properties.xml; writing.mode.xml;
-    body.start.indent⋯
-
-    Change 'left' to 'start' and 'right' to 'end' to support right-to-left
-    writing mode.
-
-  • Robert Stayton: glossdef.block.properties.xml;
-    glossdef.list.properties.xml; glossterm.blo⋯
-
-    Add attribute-sets for formatting glossary terms and defs.
-
-  • Robert Stayton: glossterm.separation.xml
-
-    Clarify the description.
-
-  • Robert Stayton: make.year.ranges.xml
-
-    Now handles year element containing a comma or dash without error.
-
-Highlighting
-
-The following changes have been made to the highlighting code since the 1.74.3
-release.
-
-  • Jirka Kosek: README
-
-    Inclusion of highlighting code was simplified. Only one import is now necessary.
-
-  • Keith Fahlgren: README
-
-    Adding XSLTHL readme
-
-  • Keith Fahlgren: common.xsl
-
-    Alternate attempt at sanely including/excluding XSLTHT code
-
-XSL-Saxon
-
-The following changes have been made to the xsl-saxon code since the 1.74.3
-release.
-
-  • Mauritz Jeanson: src/com/nwalsh/saxon/Text.java
-
-    Added a fix that prevents output of extra blank line.
-    Hopefully this closes bug #894805.
-
-XSL-Xalan
-
-The following changes have been made to the xsl-xalan code since the 1.74.3
-release.
-
-  • Mauritz Jeanson: src/com/nwalsh/xalan/Text.java
-
-    Added a fix that prevents output of extra blank line.
-    Hopefully this closes bug #894805.
-
-Release Notes: 1.74.3
-
-This release fixes some bugs in the 1.74.2 release.
-
-See highlighting/README for XSLTHL usage instructions.
-
-Release Notes: 1.74.2
-
-This release fixes some bugs in the 1.74.1 release.
-
-Release Notes: 1.74.1
-
-This release includes important bug fixes and adds the following significant
-feature changes:
-
-Gentext
-
-    Kirghiz locale added and Chinese translations have been simplified.
-
-    Somme support for gentext and right-to-left languages has been added.
-
-FO
-
-    Various bugs have been resolved.
-
-    Support for a new processing instruction: dbfo funcsynopsis-style has been
-    added.
-
-    Added new param email.mailto.enabled for FO output. Patch from Paolo
-    Borelli.
-
-    Support for documented metadata in fop1 mode has been added.
-
-Highlighting
-
-    Support for the latest version of XSLTHL 2.0 and some new language syntaxes
-    have been added to a variety of outputs.
-
-Manpages
-
-    Added man.output.better.ps.enabled param (zero default). It non-zero, no
-    such markup is embedded in generated man pages, and no enhancements are
-    included in the PostScript output generated from those man pages by the man
-    -Tps command.
-
-HTML
-
-    Support for writing.mode to set text direction and alignment based on
-    document locale has been added.
-
-    Added a new top-level stylesheet module, chunk-changebars.xsl, to be used
-    for generating chunked output with highlighting based on change
-    (@revisionflag) markup. The module imports/includes the standard chunking
-    and changebars templates and contains additional logic for chunked output.
-    See FRs #1015180 and #1819915.
-
-ePub
-
-    Covers now look better in Adobe Digital Editions thanks to a patch from
-    Paul Norton of Adobe
-
-    Cover handling now more generic (including limited DocBook 5.0 cover
-    support thanks to patch contributed by Liza Daly.
-
-    Cover markup now carries more reliably into files destined for .mobi and
-    the Kindle.
-
-    dc:identifiers are now generated from more types of numbering schemes.
-
-    Both SEO and semantic structure of chunked ePub output by ensuring that we
-    always send out one and only one h1 in each XHTML chunk.
-
-    Primitive support for embedding a single font added.
-
-    Support for embedding a CSS customizations added.
-
-Roundtrip
-
-    Support for imagedata-metadata and table as images added.
-
-    Support for imagedata-metadata and legalnotice as images added.
-
-Params
-
-    man.output.better.ps.enabled added for Manpages output
-
-    writing.mode.xml added to set text direction.
-
-    Added new param email.mailto.enabled for FO output. Patch from Paolo
-    Borelli. Closes #2086321.
-
-    highlight.source upgraded to support the latest version of XSLTHL 2.0.
-
-The following is a list of changes that have been made since the 1.74.0
-release.
-
-Gentext
-
-The following changes have been made to the gentext code since the 1.74.0
-release.
-
-  • Michael(tm) Smith: locale/ky.xml; Makefile
-
-    new Kirghiz locale from Ilyas Bakirov
-
-  • Mauritz Jeanson: locale/en.xml
-
-    Added "Acknowledgements".
-
-  • Dongsheng Song: locale/zh_cn.xml
-
-    Simplified Chinese translation.
-
-  • Robert Stayton: locale/lv.xml; locale/ca.xml; locale/pt.xml; locale/tr.xml;
-    locale/af.xml;⋯
-
-    Add writing-mode gentext string to support right-to-left languages.
-
-FO
-
-The following changes have been made to the fo code since the 1.74.0 release.
-
-  • David Cramer: footnote.xsl
-
-    Added a check to confirm that a footnoteref's linkend points to a footnote. Stylesheets stop processing if not and provide a useful error message.
-
-  • Mauritz Jeanson: spaces.xsl
-
-    Convert spaces to fo:leader also in elements in the DB 5 namespace.
-
-  • Mauritz Jeanson: pi.xsl; synop.xsl
-
-    Added support for a new processing instruction: dbfo funcsynopsis-style.
-    Closes bug #1838213.
-
-  • Michael(tm) Smith: inline.xsl; param.xweb; param.ent
-
-    Added new param email.mailto.enabled for FO output.
-    Patch from Paolo Borelli. Closes #2086321.
-
-  • Mauritz Jeanson: docbook.xsl
-
-    Added support for document metadata for fop1 (patch #2067318).
-
-  • Jirka Kosek: param.ent; param.xweb; highlight.xsl
-
-    Upgraded to support the latest version of XSLTHL 2.0
-     -- nested markup in highlited code is now processed
-     -- it is no longer needed to specify path XSLTHL configuration file using Java property
-     -- support for new languages, including Perl, Python and Ruby was added
-
-HTML
-
-The following changes have been made to the html code since the 1.74.0 release.
-
-  • Robert Stayton: param.xweb; docbook.xsl; param.ent; html.xsl
-
-    Add support for writing.mode to set text direction and alignment based on document locale.
-
-  • Mauritz Jeanson: chunk-changebars.xsl
-
-    Added a new top-level stylesheet module, chunk-changebars.xsl, to be
-    used for generating chunked output with highlighting based on change
-    (@revisionflag) markup. The module imports/includes the standard chunking
-    and changebars templates and contains additional logic for chunked output.
-    See FRs #1015180 and #1819915.
-
-Manpages
-
-The following changes have been made to the manpages code since the 1.74.0
-release.
-
-  • Michael(tm) Smith: docbook.xsl
-
-    Put the following at the top of generated roff for each page:
-      \" t
-    purpose is to explicitly tell AT&T troff that the page needs to be
-    pre-processed through tbl(1); groff can figure it out
-    automatically, but apparently AT&T troff needs to be explicitly told
-
-ePub
-
-The following changes have been made to the epub code since the 1.74.0 release.
-
-  • Keith Fahlgren: docbook.xsl
-
-    Patch from Paul Norton of Adobe to get covers to look better in Adobe Digital Editions
-
-  • Keith Fahlgren: bin/spec/epub_regressions_spec.rb; bin/spec/files/
-    v5cover.xml; bin/spec/sp⋯
-
-    Patch contributed by Liza Daly to make ePub cover handling more generic. Additionally
-    DocBook 5.0's <cover> now has some limited support:
-
-    - should reference a cover in the OPF guide for a DocBook 5.0 test document
-
-  • Keith Fahlgren: bin/spec/files/isbn.xml; bin/spec/files/issn.xml; bin/spec/
-    files/biblioid.⋯
-
-    Liza Daly reported that the dc:identifer-generation code was garbage (she was right).
-
-    Added new tests:
-    - should include at least one dc:identifier
-    - should include an ISBN as URN for dc:identifier if an ISBN was in the metadata
-    - should include an ISSN as URN for dc:identifier if an ISSN was in the metadata
-    - should include an biblioid as a dc:identifier if an biblioid was in the metadata
-    - should include a URN for a biblioid with @class attribute as a dc:identifier if an biblioid was in the metadata
-
-  • Keith Fahlgren: docbook.xsl; bin/spec/epub_spec.rb
-
-    Improve both SEO and  semantic structure of chunked ePub output by ensuring that
-    we always send out one and only one h1 in each XHTML chunk.
-
-    DocBook::Epub
-    - should include one and only one <h1> in each HTML file in rendered ePub files
-    for <book>s
-    - should include one and only one <h1> in each HTML file in rendered ePub files
-    for <book>s even if they do not have section markup
-
-  • Keith Fahlgren: docbook.xsl; bin/spec/epub_realbook_spec.rb; bin/spec/files
-    /orm.book.001.x⋯
-
-    Adding better support for covers in epub files destined for .mobi and the Kindle
-
-  • Keith Fahlgren: bin/dbtoepub; bin/lib/docbook.rb; bin/spec/files/
-    DejaVuSerif.otf; docbook.⋯
-
-    Adding primitive support for embedding a single font
-
-  • Keith Fahlgren: bin/dbtoepub; bin/lib/docbook.rb; bin/spec/files/
-    test_cust.xsl; bin/spec/e⋯
-
-    Adding support for user-specified customization layers in dbtoepub
-
-  • Keith Fahlgren: bin/dbtoepub; bin/spec/epub_regressions_spec.rb; bin/lib/
-    docbook.rb; bin/s⋯
-
-    Adding CSS support to .epub target & dbtoepub:
-        -c, --css [FILE]                 Use FILE for CSS on generated XHTML.
-
-
-    DocBook::Epub
-    ...
-    - should include a CSS link in HTML files when a CSS file has been provided
-    - should include CSS file in .epub when a CSS file has been provided
-    - should include a CSS link in OPF file when a CSS file has been provided
-
-Roundtrip
-
-The following changes have been made to the roundtrip code since the 1.74.0
-release.
-
-  • Steve Ball: blocks2dbk.xsl; template.xml; template.dot
-
-    added support for imagedata-metadata
-    added support for table as images
-
-  • Steve Ball: blocks2dbk.xsl; normalise2sections.xsl; sections2blocks.xsl
-
-    Improved support for personname inlines.
-
-  • Steve Ball: blocks2dbk.xsl; blocks2dbk.dtd; template.xml
-
-    Added support for legalnotice.
-
-  • Steve Ball: blocks2dbk.xsl; wordml2normalise.xsl
-
-    added support for orgname in author
-
-  • Steve Ball: specifications.xml; supported.xml; blocks2dbk.xsl;
-    wordml2normalise.xsl; dbk2w⋯
-
-    Updated specification.
-    to-DocBook: add cols attribute to tgroup
-    from-DocBook: fix for blockquote title
-
-Params
-
-The following changes have been made to the params since the 1.74.0 release.
-
-  • The change was to add man.output.better.ps.enabled parameter, with its
-    default value set to zero. If the value of the man.output.better.ps.enabled
-    parameter is non-zero, certain markup is embedded in each generated man
-    page such that PostScript output from the man -Tps command for that page
-    will include a number of enhancements designed to improve the quality of
-    that output. If man.output.better.ps.enabled is zero (the default), no such
-    markup is embedded in generated man pages, and no enhancements are included
-    in the PostScript output generated from those man pages by the man -Tps
-    command. WARNING: The enhancements provided by this parameter rely on
-    features that are specific to groff (GNU troff) and that are not part of
-    "classic" AT&T troff or any of its derivatives. Therefore, any man pages
-    you generate with this parameter enabled will be readable only on systems
-    on which the groff (GNU troff) program is installed, such as GNU/Linux
-    systems. The pages will not not be readable on systems on with the classic
-    troff (AT&T troff) command is installed. NOTE: The value of this parameter
-    only affects PostScript output generated from the man command. It has no
-    effect on output generated using the FO backend. TIP: You can generate
-    PostScript output for any man page by running the following command: man
-    FOO -Tps > FOO.ps You can then generate PDF output by running the following
-    command: ps2pdf FOO.ps
-
-  • Robert Stayton: writing.mode.xml
-
-    writing mode param used to set text direction.
-
-  • Michael(tm) Smith: email.mailto.enabled.xml
-
-    Added new param email.mailto.enabled for FO output.
-    Patch from Paolo Borelli. Closes #2086321.
-
-  • Jirka Kosek: highlight.source.xml; highlight.xslthl.config.xml
-
-    Upgraded to support the latest version of XSLTHL 2.0
-     -- nested markup in highlited code is now processed
-     -- it is no longer needed to specify path XSLTHL configuration file using Java property
-     -- support for new languages, including Perl, Python and Ruby was added
-
-Highlighting
-
-The following changes have been made to the highlighting code since the 1.74.0
-release.
-
-  • Jirka Kosek: cpp-hl.xml; c-hl.xml; tcl-hl.xml; php-hl.xml; common.xsl;
-    perl-hl.xml; delphi⋯
-
-    Upgraded to support the latest version of XSLTHL 2.0
-     -- nested markup in highlited code is now processed
-     -- it is no longer needed to specify path XSLTHL configuration file using Java property
-     -- support for new languages, including Perl, Python and Ruby was added
-
-Release Notes: 1.74.0
-
-This release includes important bug fixes and adds the following significant
-feature changes:
-
-.epub target
-
-    Paul Norton (Adobe) and Keith Fahlgren(O'Reilly Media) have donated code
-    that generates .epub documents from DocBook input. An alpha-reference
-    implementation in Ruby has also been provided.
-
-    .epub is an open standard of the The International Digital Publishing Forum
-    (IDPF), a the trade and standards association for the digital publishing
-    industry.
-
-    Read more about this target in epub/README
-
-XHTML 1.1 target
-
-    To support .epub output, a strict XHTML 1.1 target has been added. The
-    stylesheets for this output are generated and are quite similar to the
-    XHTML target.
-
-Gentext updates
-
-    A number of locales have been updated.
-
-Roundtrip improvements
-
-    Table, figure, template syncronization, and character style improvements
-    have been made for WordML & Pages. Support added for OpenOffice.org.
-
-First implementation of a libxslt extension
-
-    A stylesheet extension for libxslt, written in Python, has been added. The
-    extension is a function for adjusting column widths in CALS tables. See
-    extensions/README.LIBXSLT for more information.
-
-The following is a list of changes that have been made since the 1.73.2
-release.
-
-Gentext
-
-The following changes have been made to the gentext code since the 1.73.2
-release.
-
-  • Michael(tm) Smith: locale/id.xml
-
-    Checked in changes to Indonesion locale submitted by Euis Luhuanam a long time ago.
-
-  • Michael(tm) Smith: locale/lt.xml
-
-    Added changes to Lithuanian locate submitted a long time back by Nikolajus Krauklis.
-
-  • Michael(tm) Smith: locale/hu.xml
-
-    fixed error in lowercase.alpha definition in Hungarian locale
-
-  • Michael(tm) Smith: locale/nb.xml
-
-    Corrected language code for nb locale, and restored missing "startquote" key.
-
-  • Michael(tm) Smith: locale/ja.xml
-
-    Committed changes to ja locale file, from Akagi Kobayashi. Adds bracket quotes around many xref instances that did not have them
-    before.
-
-  • Michael(tm) Smith: Makefile
-
-    "no" locale is now "nb"
-
-  • Michael(tm) Smith: locale/nb.xml
-
-    Update Norwegian Bokmål translation. Thanks to Hans F. Nordhaug.
-
-  • Michael(tm) Smith: locale/no.xml; locale/nb.xml
-
-    per message from Hans F. Nordhaug, correct identifier for
-    Norwegian Bokmål is "nb" (not "no") and has been for quite some
-    time now...
-
-  • Michael(tm) Smith: locale/ja.xml
-
-    Converted ja.xml source file to use real unicode characters so
-    that the actual glyphs so up when you edit it in a text editor
-    (instead of the character references).
-
-  • Michael(tm) Smith: locale/ja.xml
-
-    Checked in changes to ja.xml locale file. Thanks to Akagi Kobayashi.
-
-  • Michael(tm) Smith: locale/it.xml
-
-    Changes from Federico Zenith
-
-  • Dongsheng Song: locale/zh_cn.xml
-
-    Added missing translations.
-
-Common
-
-The following changes have been made to the common code since the 1.73.2
-release.
-
-  • Michael(tm) Smith: l10n.xsl
-
-    Added new template "l10.language.name" for retrieving the
-    English-language name of the lang setting of the current document.
-    Closes #1916837. Thanks to Simon Kennedy.
-
-  • Michael(tm) Smith: refentry.xsl
-
-    fixed syntax error
-
-  • Michael(tm) Smith: refentry.xsl
-
-    fixed a couple of typos
-
-  • Michael(tm) Smith: refentry.xsl
-
-    refined handling of cases where refentry "source" or "manual"
-    metadata is missing or when we use fallback content instead. We
-    now report a Warning if we use fallback content.
-
-  • Michael(tm) Smith: refentry.xsl
-
-    don't use refmiscinfo@class=date value as fallback for refentry
-    "source" or "manual" metadata fields
-
-  • Michael(tm) Smith: refentry.xsl
-
-    Made reporting of missing refentry metadata more quiet:
-
-      - we no longer report anything if usable-but-not-preferred
-        metadata is found; we just quietly use whatever we manage to
-        find
-
-      - we now only report missing "source" metadata if the refentry
-        is missing BOTH "source name" and "version" metadata; if it
-        has one but not the other, we use whichever one it has and
-        don't report anything as missing
-
-    The above changes were made because testing with some "real world"
-    source reveals that some authors are intentionally choosing to use
-    "non preferred" markup for some metadata, and also choosing to
-    omit "source name" or "version" metadata in there DocBook XML. So
-    it does no good to give them pedantic reminders about what they
-    already know...
-
-    Also, changed code to cause "fixme" text to be inserted in output
-    in particular cases:
-
-      - if we can't manage to find any "source" metadata at all, we
-        now put fixme text into the output
-
-      - if we can't manage to find any "manual" metadata a all, we
-        now put fixme text into the output
-
-    The "source" and "manual" metadata is necessary information, so
-    buy putting the fixme stuff in the output, we alert users to the
-    need problem of it being missing.
-
-  • Michael(tm) Smith: refentry.xsl
-
-    When generating manpages output, we no longer report anything if
-    the refentry source is missing date or pubdate content. In
-    practice, many users intentionally omit the date from the source
-    because they explicitly want it to be generated.
-
-  • Michael(tm) Smith: l10n.xml
-
-    further change needed for switch from no locale to nb.
-
-  • Michael(tm) Smith: common.xsl
-
-    Added support for orgname in authorgroup. Thanks to Camille
-    Bégnis.
-
-  • Michael(tm) Smith: Makefile
-
-    "no" locale is now "nb"
-
-  • Mauritz Jeanson: stripns.xsl
-
-    Removed the template matching "ng:link|db:link" (in order to make @xlink:show
-    work with <link> elements). As far as I can tell, this template is no longer needed.
-
-  • Mauritz Jeanson: entities.ent
-
-    Moved declaration of comment.block.parents entity to common/entities.ent.
-
-  • Mauritz Jeanson: titles.xsl
-
-    Added an update the fix made in revision 7528 (handling of xref/link in no.anchor.mode mode).
-    Having xref in title is not a problem as long as the target is not an ancestor element.
-    Closes bug #1838136.
-
-    Note that an xref that is in a title and whose target is an ancestor element is still not
-    rendered in the TOC. This could be considered a bug, but on the other hand I cannot really
-    see the point in having such an xref in a document.
-
-  • Mauritz Jeanson: titles.xsl
-
-    Added a "not(ancestor::title)" test to work around "too many nested
-    apply-templates" problems when processing xrefs or links in no.anchor.mode mode.
-    Hopefully, this closes bug #1811721.
-
-  • Mauritz Jeanson: titles.xsl
-
-    Removed old template matching "link" in no.anchor.mode mode.
-
-  • Mauritz Jeanson: titles.xsl
-
-    Process <link> in no.anchor.mode mode with the same template as <xref>.
-    Closes bug #1759205 (Empty link in no.anchor.mode mode).
-
-  • Mauritz Jeanson: titles.xsl
-
-    In no.anchor.mode mode, do not output anchors for elements that are descendants
-    of <title>. Previously, having inline elements with @id/@xml:id in <title>s
-    resulted in anchors both in the TOC and in the main flow. Closes bug #1797492.
-
-FO
-
-The following changes have been made to the fo code since the 1.73.2 release.
-
-  • Mauritz Jeanson: pi.xsl
-
-    Updated documentation for keep-together.
-
-  • Mauritz Jeanson: task.xsl
-
-    Enabled use of the keep-together PI on task elements.
-
-  • Robert Stayton: index.xsl
-
-    FOP1 requires fo:wrapper for inline index entries, not fo:inline.
-
-  • Robert Stayton: index.xsl
-
-    Fixed non-working inline.or.block template for indexterm wrappers.
-    Add fop1 to list of processors using inline.or.block.
-
-  • Mauritz Jeanson: table.xsl
-
-    Fixed bug #1891965 (colsep in entytbl not working).
-
-  • Mauritz Jeanson: titlepage.xsl
-
-    Added support for title in revhistory. Closes bug #1842847.
-
-  • Mauritz Jeanson: pi.xsl
-
-    Small doc cleanup (dbfo float-type).
-
-  • Mauritz Jeanson: titlepage.xsl
-
-    Insert commas between multiple copyright holders.
-
-  • Mauritz Jeanson: autotoc.xsl; division.xsl
-
-    Added modifications to support nested set elements. See bug #1853172.
-
-  • David Cramer: glossary.xsl
-
-    Added normalize-space to xsl:sorts to avoid missorting of glossterms due to stray leading spaces.
-
-  • David Cramer: glossary.xsl
-
-    Fixed bug #1854199: glossary.xsl should use the sortas attribute on glossentry
-
-  • Mauritz Jeanson: inline.xsl
-
-    Added a template for citebiblioid. The hyperlink target is the parent of the referenced biblioid,
-    and the "hot text" is the biblioid itself enclosed in brackets.
-
-  • Mauritz Jeanson: inline.xsl
-
-    Moved declaration of comment.block.parents entity to common/entities.ent.
-
-  • Mauritz Jeanson: docbook.xsl
-
-    Updated message about unmatched element.
-
-  • Mauritz Jeanson: param.xweb
-
-    Added link to profiling chapter of TCG.
-
-  • Mauritz Jeanson: refentry.xsl
-
-    Fixed typo (refsynopsysdiv -> refsynopsisdiv).
-
-  • David Cramer: fop.xsl; fop1.xsl; ptc.xsl; xep.xsl
-
-    Added test to check generate.index param when generating pdf bookmarks
-
-  • Mauritz Jeanson: graphics.xsl
-
-    Added support for MathML in imagedata.
-
-  • Michael(tm) Smith: math.xsl
-
-    Removed unnecessary extra test condition in test express that
-    checks for passivetex.
-
-  • Michael(tm) Smith: math.xsl
-
-    Don't use fo:instream-foreign-object if we are processing with
-    passivetex. Closes #1806899. Thanks to Justus Piater.
-
-  • Mauritz Jeanson: component.xsl
-
-    Added code to output a TOC for an appendix in an article when
-    generate.toc='article/appendix toc'. Closes bug #1669658.
-
-  • Dongsheng Song: biblio-iso690.xsl
-
-    Change encoding from "windows-1250" to "UTF-8".
-
-  • Mauritz Jeanson: pi.xsl
-
-    Updated documentation for dbfo_label-width.
-
-  • Mauritz Jeanson: lists.xsl
-
-    Added support for the dbfo_label-width PI in calloutlists.
-
-  • Robert Stayton: biblio.xsl
-
-    Support finding glossary database entries inside bibliodivs.
-
-  • Robert Stayton: formal.xsl
-
-    Complete support for <?dbfo pgwide="1"?> for informal
-    elements too.
-
-  • Mauritz Jeanson: table.xsl
-
-    In the table.block template, added a check for the dbfo_keep-together PI, so that
-    a table may break (depending on the PI value) at a page break. This was needed
-    since the outer fo:block that surrounds fo:table has keep-together.within-column="always"
-    by default, which prevents the table from breaking. Closes bug #1740964 (Titled
-    table does not respect dbfo PI).
-
-  • Mauritz Jeanson: pi.xsl
-
-    Added a few missing @role="tcg".
-
-  • Mauritz Jeanson: inline.xsl
-
-    Use normalize-space() in glossterm comparisons (as in html/inline.xsl).
-
-  • Mauritz Jeanson: autoidx.xsl
-
-    Removed the [&scope;] predicate from the target variable in the template with name="reference".
-    This filter was the cause of missing index backlinks when @zone and @type were used on indexterms,
-    with index.on.type=1. Closes bug #1680836.
-
-  • Michael(tm) Smith: inline.xsl; xref.xsl; footnote.xsl
-
-    Added capability in FO output for displaying URLs for all
-    hyperlinks (elements marked up with xlink:href attributes) in the
-    same way as URLs for ulinks are already handled (which is to say,
-    either inline or as numbered footnotes).
-
-    Background on this change:
-    DocBook 5 allows "ubiquitous" linking, which means you can make
-    any element a hyperlink just by adding an xlink:href attribute to
-    it, with the value set to an external URL. That's in contrast to
-    DocBook 4, which only allows you to use specific elements (e.g.,
-    the link and ulink elements) to mark up hyperlinks.
-
-    The existing FO stylesheets have a mechanism for handling display
-    of URLs for hyperlinks that are marked up with ulink, but they did
-    not handle display of URLs for elements that were marked up with
-    xlink:href attributes. This change adds handling for those other
-    elements, enabling the URLs they link to be displayed either
-    inline or as numbered footnotes (depending on what values the user
-    has the ulink.show and ulink.footnotes params set to).
-
-    Note that this change only adds URL display support for elements
-    that call the simple.xlink template -- which currently is most
-    (but not all) inline elements.
-
-    This change also moves the URL display handling out of the ulink
-    template and into a new "hyperlink.url.display" named template;
-    the ulink template and the simple.xlink named template now both
-    call the hyperlink.url.display template.
-
-    Warning: In the stylesheet code that determines what footnote
-    number to assign to each footnote or external hyperlink, there is
-    an XPath expression for determining whether a particular
-    xlink:href instance is an external hyperlink; that expression is
-    necessarily a bit complicated and further testing may reveal that
-    it doesn't handle all cases as expected -- so some refinements to
-    it may need to be done later.
-
-    Closes #1785519. Thanks to Ken Morse for reporting and
-    troubleshooting the problem.
-
-HTML
-
-The following changes have been made to the html code since the 1.73.2 release.
-
-  • Keith Fahlgren: inline.xsl; synop.xsl
-
-    Work to make HTML and XHTML targets more valid
-
-  • Keith Fahlgren: table.xsl
-
-    Add better handling for tables that have footnotes in the titles
-
-  • Keith Fahlgren: biblio.xsl
-
-    Add anchors to bibliodivs
-
-  • Keith Fahlgren: formal.xsl; Makefile; htmltbl.xsl
-
-    Initial checkin/merge of epub target from work provided by Paul Norton of Adobe
-    and Keith Fahlgren of O'Reilly.
-
-    This change includes new code for generating the XHTML 1.1 target sanely.
-
-  • Mauritz Jeanson: biblio.xsl
-
-    Added code for creating URLs from biblioids with @class="doi" (representing Digital
-    Object Identifiers). See FR #1934434 and http://doi.org.
-
-    To do: 1) Add support for FO output. 2) Figure out how @class="doi" should be handled
-    for bibliorelation, bibliosource and citebiblioid.
-
-  • Norman Walsh: formal.xsl
-
-    Don't use xsl:copy because it forces the resulting element to be in the same namespace as the source element; in the XHTML stylesheets, that's wrong. But the HTML-to-XHTML converter does the right thing with literal result elements, so use one of them.
-
-  • Michael(tm) Smith: Makefile
-
-    Added checks and hacks to various makefiles to enable building
-    under Cygwin. This stuff is ugly and maybe not worth the mess and
-    trouble, but does seem to work as expected and not break anything
-    else.
-
-  • Michael(tm) Smith: docbook.xsl
-
-    added "exslt" namespace binding to html/docbook.xsl file (in
-    addition to existing "exsl" binding. reason is because lack of it
-    seems to cause processing problems when using the profiled
-    version of the stylsheet
-
-  • Norman Walsh: chunk-common.xsl
-
-    Rename link
-
-  • Mauritz Jeanson: table.xsl
-
-    Added a fix to make rowsep apply to the last row of thead in entrytbl.
-
-  • Michael(tm) Smith: synop.xsl
-
-    Simplified and streamlined handling of output for ANSI-style
-    funcprototype output, to correct a problem that was causing type
-    data to be lost in the output parameter definitions. For example,
-    for an instance like this:
-      <paramdef>void *<parameter>dataptr</parameter>[]</paramdef>
-    ... the brackets (indicating an array type) were being dropped.
-
-  • Michael(tm) Smith: synop.xsl
-
-    Changed HTML handling of K&R-style paramdef output. The parameter
-    definitions are no longer output in a table (though the prototype
-    still is). The reason for the change is that the
-    kr-tabular-funcsynopsis-mode template was causing type data to be
-    lost in the output parameter definitions. For example, for an
-    instance like this:
-      <paramdef>void *<parameter>dataptr</parameter>[]</paramdef>
-    ... the brackets (indicating an array type) were being dropped.
-    The easiest way to deal with the problem is to not try to chop up
-    the parameter definitions and display them in table format, but to
-    instead just output them as-is. May not look quite as pretty, but
-    at least we can be sure no information is being lost...
-
-  • Michael(tm) Smith: pi.xsl
-
-    updated wording of doc for funcsynopsis-style PI
-
-  • Michael(tm) Smith: param.xweb; param.ent; synop.xsl
-
-    Removed the funcsynopsis.tabular.threshold param. It's no longer
-    being used in the code and hasn't been since mid 2006.
-
-  • Mauritz Jeanson: graphics.xsl
-
-    Added support for the img.src.path parameter for SVG graphics. Closes bug #1888169.
-
-  • Mauritz Jeanson: chunk-common.xsl
-
-    Added missing space.
-
-  • Norman Walsh: component.xsl
-
-    Fix bug where component titles inside info elements were not handled properly
-
-  • Michael(tm) Smith: pi.xsl
-
-    Moved dbhtml_stop-chunking embedded doc into alphabetical order,
-    fixed text of TCG section it see-also'ed.
-
-  • David Cramer: pi.xsl
-
-    Added support for <?dbhtml stop-chunking?> processing instruction
-
-  • David Cramer: chunk-common.xsl; pi.xsl
-
-    Added support for <?dbhtml stop-chunking?> processing instruction
-
-  • David Cramer: glossary.xsl
-
-    Fixed bug #1854199: glossary.xsl should use the sortas attribute on glossentry. Also added normalize-space to avoid missorting due to stray leading spaces.
-
-  • Mauritz Jeanson: inline.xsl
-
-    Added a template for citebiblioid. The hyperlink target is the parent of the referenced biblioid,
-    and the "hot text" is the biblioid itself enclosed in brackets.
-
-  • Mauritz Jeanson: inline.xsl
-
-    Added support for @xlink:show in the simple.xlink template. The "new" and "replace"
-    values are supported (corresponding to values of "_blank" and "_top" for the
-    ulink.target parameter). I have assumed that @xlink:show should override ulink.target
-    for external URI links. This closes bugs #1762023 and #1727498.
-
-  • Mauritz Jeanson: inline.xsl
-
-    Moved declaration of comment.block.parents entity to common/entities.ent.
-
-  • Mauritz Jeanson: param.xweb
-
-    Added link to profiling chapter of TCG.
-
-  • Dongsheng Song: biblio-iso690.xsl
-
-    Change encoding from "windows-1250" to "UTF-8".
-
-  • Robert Stayton: biblio.xsl
-
-    Add support in biblio collection to entries in bibliodivs.
-
-  • Mauritz Jeanson: pi.xsl
-
-    Added missing @role="tcg".
-
-  • Mauritz Jeanson: chunk-common.xsl; titlepage.xsl
-
-    Refactored legalnotice/revhistory chunking, so that the use.id.as.filename
-    parameter as well as the dbhtml_filename PI are taken into account. A new named
-    template in titlepage.xsl is used to compute the filename.
-
-  • Mauritz Jeanson: chunk-common.xsl; titlepage.xsl
-
-    An update to the fix for bug #1790495 (r7433):
-    The "ln-" prefix is output only when the legalnotice doesn't have an
-    @id/@xml:id, in which case the stylesheets generate an ID value,
-    resulting in a filename like "ln-7e0fwgj.html". This is useful because
-    without the prefix, you wouldn't know that the file contained a legalnotice.
-    The same logic is also applied to revhistory, using an "rh-" prefix.
-
-  • Mauritz Jeanson: autoidx.xsl
-
-    Removed the [&scope;] predicate from the target variable in the template with name="reference".
-    This filter was the cause of missing index backlinks when @zone and @type were used on indexterms,
-    with index.on.type=1. Closes bug #1680836.
-
-  • Mauritz Jeanson: titlepage.xsl
-
-    Added 'ln-' prefix to the name of the legalnotice chunk, in order to match the
-    <link href"..."> that is output by make.legalnotice.head.links (chunk-common.xsl).
-    Modified the href attribute on the legalnotice link.
-    Closes bug #1790495.
-
-Manpages
-
-The following changes have been made to the manpages code since the 1.73.2
-release.
-
-  • Michael(tm) Smith: other.xsl
-
-    slightly adjusted spacing around admonition markers
-
-  • Michael(tm) Smith: refentry.xsl; utility.xsl
-
-    make sure refsect3 titles are preceded by a line of space, and
-    make the indenting of their child content less severe
-
-  • Michael(tm) Smith: block.xsl
-
-    only indent verbatim environments in TTY output, not in non-TTY/PS
-
-  • Michael(tm) Smith: block.xsl
-
-    made another adjustment to correct vertical alignment of admonition marker
-
-  • Michael(tm) Smith: block.xsl; other.xsl
-
-    Adjusted/corrected alignment of adominition marker in PS/non-TTY output.
-
-  • Michael(tm) Smith: endnotes.xsl
-
-    For PS/non-TTY output, display footnote/endnote numbers in
-    superscript.
-
-  • Michael(tm) Smith: table.xsl; synop.xsl; utility.xsl
-
-    Changed handling of hanging indents for cmdsynopsis, funcsynopsis,
-    and synopfragment such that they now look correct in non-TTY/PS
-    output. We now use the groff \w escape to hang by the actual width
-    -- in the current font -- of the command, funcdef, or
-    synopfragment references number (as opposed to hanging by the
-    number of characters). This rendering in TTY output remains the
-    same, since the width in monospaced TTY output is the same as the
-    number of characters.
-
-    Also, created new synopsis-block-start and synopsis-block-end
-    templates to use for cmdsynopsis and funcsynopsis instead of the
-    corresponding verbatim-* templates.
-
-    Along with those changes, also corrected a problem that caused the
-    content of synopfragment to be dropped, and made a
-    vertical-spacing change to adjust spacing around table titles and
-    among sibling synopfragment instances.
-
-  • Michael(tm) Smith: other.xsl
-
-    use common l10.language.name template to retrieve English-language name
-
-  • Michael(tm) Smith: synop.xsl; inline.xsl
-
-    added comment in code explaining why we don't put filename output
-    in italic (despite the fact that man guidelines say we should)
-
-  • Michael(tm) Smith: inline.xsl
-
-    put filename output in monospace instead of italic
-
-  • Michael(tm) Smith: synop.xsl
-
-    put cmdsynopsis in monospace
-
-  • Michael(tm) Smith: inline.xsl
-
-    removed template match for literal. template matches for monospace
-    inlines are all imported from the HTML stylesheet
-
-  • Michael(tm) Smith: block.xsl
-
-    don't indent verbatim environments that are descendants of
-    refsynopsisdiv, not put backgrounds behind them
-
-  • Michael(tm) Smith: inline.xsl
-
-    set output of the literal element in monospace. this causes all
-    inline monospace instances in the git man pages to be set in
-    monospace (since DocBook XML source for git docs is generated with
-    asciidoc and asciidoc consistently outputs only <literal> for
-    inline monospace (not <command> or <code> or anything else).
-    Of course this only affects non-TTY output...
-
-  • Michael(tm) Smith: utility.xsl
-
-    Added inline.monoseq named template.
-
-  • Michael(tm) Smith: utility.xsl
-
-    don't bother using a custom register to store the previous
-    font-family value when setting blocks of text in code font; just
-    use \F[] .fam with no arg to switch back
-
-  • Michael(tm) Smith: endnotes.xsl
-
-    put links in blue in PS output (note that this matches how groff
-    renders content marked up with the .URL macro)
-
-  • Michael(tm) Smith: endnotes.xsl; param.xweb; param.ent
-
-    removed man.links.are.underlined and added man.font.links. Also,
-    changed the default font formatting for links to bold.
-
-  • Michael(tm) Smith: endnotes.xsl; param.xweb; param.ent
-
-    Added new param man.base.url.for.relative.links .. specifies a
-    base URL for relative links (for ulink, @xlink:href, imagedata,
-    audiodata, videodata) shown in the generated NOTES section of
-    man-page output. The value of man.base.url.for.relative.links is
-    prepended to any relative URI that is a value of ulink url,
-    xlink:href, or fileref attribute.
-
-    If you use relative URIs in link sources in your DocBook refentry
-    source, and you leave man.base.url.for.relative.links unset, the
-    relative links will appear "as is" in the NOTES section of any
-    man-page output generated from your source. That's probably not
-    what you want, because such relative links are only usable in the
-    context of HTML output. So, to make the links meaningful and
-    usable in the context of man-page output, set a value for
-    man.base.url.for.relative.links that points
-    to the online version of HTML output generated from your DocBook
-    refentry source. For example:
-
-      <xsl:param name="man.base.url.for.relative.links"
-      >http://www.kernel.org/pub/software/scm/git/docs/</xsl:param>
-
-  • Michael(tm) Smith: info.xsl
-
-    If a source refentry contains a Documentation or DOCUMENTATION
-    section, don't report it as having missing AUTHOR information.
-    Also, if missing a contrib/personblurb for a person or org, report
-    pointers to http://docbook.sf.net/el/personblurb and to
-    http://docbook.sf.net/el/contrib
-
-  • Michael(tm) Smith: info.xsl
-
-    If we encounter an author|editor|othercredit instance that lacks a
-    personblurb or contrib, report it to the user (because that means
-    we have no information about that author|editor|othercredit to
-    display in the generated AUTHOR|AUTHORS section...)
-
-  • Michael(tm) Smith: info.xsl; docbook.xsl; other.xsl
-
-    if we can't find any usable author data, emit a warning and insert
-    a fixme in the output
-
-  • Michael(tm) Smith: info.xsl
-
-    fixed bug in indenting of output for contrib instances in AUTHORS
-    section. Thanks to Daniel Leidert and the fglrx docs for exposing
-    the bug.
-
-  • Michael(tm) Smith: block.xsl
-
-    for a para or simpara that is the first child of a callout,
-    suppress the .sp or .PP that would normally be output (because in
-    those cases, the output goes into a table cell, and the .sp or .PP
-    markup causes a spurious linebreak before it when displayed
-
-  • Michael(tm) Smith: lists.xsl
-
-    Added support for rendering co callouts and calloutlist instances.
-    So you can now use simple callouts -- marking up programlisting
-    and such with co instances -- and have the callouts displayed in
-    man-page output. ("simple callouts" means using co@id and
-    callout@arearefs pointing to co@id instances; in man/roff output,
-    we can't/don't support markup that uses areaset and area)
-
-  • Michael(tm) Smith: block.xsl
-
-    only put a line of space after a verbatim if it's followed by a
-    text node or a paragraph
-
-  • Michael(tm) Smith: utility.xsl
-
-    put verbatim environments in slightly smaller font in non-TTY
-    output
-
-  • Michael(tm) Smith: lists.xsl
-
-    minor whitespace-only reformatting of lists.xsl source
-
-  • Michael(tm) Smith: lists.xsl
-
-    Made refinements/fixes to output of orderedlist and itemizedlist
-    -- in part, to get mysql man pages to display correctly. This
-    change causes a "\c" continuation marker to be added between
-    listitem markers and contents (to ensure that the content remains
-    on the same line as the marker when displayed)
-
-  • Michael(tm) Smith: block.xsl
-
-    put a line of vertical space after all verbatim output that has
-    sibling content following it (not just if that sibling content is
-    a text node)
-
-  • Michael(tm) Smith: block.xsl
-
-    refined spacing around titles for admonitions
-
-  • Michael(tm) Smith: block.xsl; other.xsl
-
-    Deal with case of verbatim environments that have a linebreak
-    after the opening tag. Assumption is that users generally don't
-    want that linebreak to appear in output, so we do some groff
-    hackery to mess with vertical spacing and close the space.
-
-  • Michael(tm) Smith: inline.xsl
-
-    indexterm instances now produce groff comments like this:
-
-      .\" primary: secondary: tertiary
-
-    remark instances, if non-empty, now produce groff comments
-
-  • Michael(tm) Smith: charmap.groff.xsl; other.xsl
-
-    convert no-break space character to groff "\ \&" (instead of just
-    "\ "). the reason is that if a space occurs at the end of a line,
-    our processing causes it to be eaten. a real-world case of this is
-    the mysql(1) man page. appending the "\&" prevents that
-
-  • Michael(tm) Smith: block.xsl
-
-    output "sp" before simpara output, not after it (outputting it
-    after results in undesirable whitespace in particular cases; for
-    example, in the hg/mercurial docs
-
-  • Michael(tm) Smith: table.xsl; synop.xsl; utility.xsl
-
-    renamed from title-preamble to pinch.together and replaced "sp -1"
-    between synopsis fragments with call to pinch.together instead
-
-  • Michael(tm) Smith: table.xsl
-
-    use title-preamble template for table titles (instead of "sp -1"
-    hack), and "sp 1" after all tables (instead of just "sp"
-
-  • Michael(tm) Smith: utility.xsl
-
-    created title-preamble template for suppressing line spacing after
-    headings
-
-  • Michael(tm) Smith: info.xsl
-
-    further refinement of indenting in AUTHORS section
-
-  • Michael(tm) Smith: block.xsl; other.xsl
-
-    refined handling of admonitions
-
-  • Michael(tm) Smith: lists.xsl
-
-    Use RS/RE in another place where we had IP ""
-
-  • Michael(tm) Smith: info.xsl
-
-    Replace (ab)use of IP with "sp -1" in AUTHORS section with RS/RE
-    instead.
-
-  • Michael(tm) Smith: table.xsl; synop.xsl; info.xsl
-
-    changed all instances of ".sp -1n" to ".sp -1"
-
-  • Michael(tm) Smith: other.xsl
-
-    add extra line before SH heads only in non-TTY output
-
-  • Michael(tm) Smith: block.xsl
-
-    Reworked output for admonitions (caution, important, note, tip,
-    warning). In TTY output, admonitions now get indented. In non-TTY
-    output, a colored marker (yellow) is displayed next to them.
-
-  • Michael(tm) Smith: other.xsl
-
-    Added BM/EM macros for putting a colored marker in margin next to
-    a block of text.
-
-  • Michael(tm) Smith: utility.xsl
-
-    created make.bold.title template by moving title-bolding part out
-    from nested-section-title template. This allows the bolding to
-    also be used by the template for formatting admonitions
-
-  • Michael(tm) Smith: info.xsl
-
-    put .br before copyright contents to prevent them from getting run in
-
-  • Michael(tm) Smith: refentry.xsl; other.xsl; utility.xsl
-
-    made point size of output for Refsect2 and Refsect3 heads bigger
-
-  • Michael(tm) Smith: other.xsl
-
-    put slightly more space between SH head and underline in non-TTY
-    output
-
-  • Michael(tm) Smith: param.xweb; param.ent; other.xsl
-
-    Added the man.charmap.subset.profile.english parameter and refined
-    the handling of charmap subsets to differentiate between English
-    and non-English source.
-
-    This way charmap subsets are now handled is this:
-
-    If the value of the man.charmap.use.subset parameter is non-zero,
-    and your DocBook source is not written in English (that is, if its
-    lang or xml:lang attribute has a value other than en), then the
-    character-map subset specified by the man.charmap.subset.profile
-    parameter is used instead of the full roff character map.
-
-    Otherwise, if the lang or xml:lang attribute on the root element
-    in your DocBook source or on the first refentry element in your
-    source has the value en or if it has no lang or xml:lang
-    attribute, then the character-map subset specified by the
-    man.charmap.subset.profile.english parameter is used instead of
-    man.charmap.subset.profile.
-
-    The difference between the two subsets is that
-    man.charmap.subset.profile provides mappings for characters in
-    Western European languages that are not part of the Roman
-    (English) alphabet (ASCII character set).
-
-  • Michael(tm) Smith: other.xsl
-
-    Various updates, mainly related to uppercasing SH titles:
-
-      - added a "Language: " metadata line to the top comment area of
-        output man pages, to indicate the language the page is in
-
-      - added a "toupper" macro of doing locale-aware uppercasing of
-        SH titles and cross-references to SH titles; the mechanism
-        relies on the uppercase.alpha and lowercase.alpha DocBook
-        gentext keys to do locale-aware uppercasing based on the
-        language the page is written in
-
-      - added a "string.shuffle" template, which provides a library
-        function for "shuffling" two strings together into a single
-        string; it takes the first character for the first string, the
-        first character from second string, etc. The only current use
-        for it is to generate the argument for the groff tr request
-        that does string uppercasing.
-
-      - added make.tr.uppercase.arg and make.tr.normalcase.arg named
-        templates for use in generating groff code for uppercasing and
-        "normal"-casing SH titles
-
-      - made the BB/BE "background drawing" macros have effect only in
-        non-TTY output
-
-      - output a few comments in the top part of source
-
-  • Michael(tm) Smith: utility.xsl
-
-    removed some leftover kruft
-
-  • Michael(tm) Smith: refentry.xsl
-
-    To create the name(s) for each man page, we now replace any spaces
-    in the refname(s) with underscores. This ensures that tools like
-    lexgrog(1) will be able to parse the name (lexgrog won't parse
-    names that contain spaces).
-
-  • Michael(tm) Smith: docbook.xsl
-
-    Put a comment into source of man page to indicate where the main
-    content starts. (We now have a few of macro definitions at the
-    start of the source, so putting this comment in helps those that
-    might be viewing the source.)
-
-  • Michael(tm) Smith: refentry.xsl
-
-    refined mechanism for generating SH titles
-
-  • Michael(tm) Smith: charmap.groff.xsl
-
-    Added zcaron, Zcaron, scaron, and Scaron to the groff character map.
-    This means that generated Finnish man pages will no longer contain
-    any raw accented characters -- they'll instead by marked up with
-    groff escapes.
-
-  • Michael(tm) Smith: other.xsl; utility.xsl
-
-    corrected a regression I introduced about a year ago that caused
-    dots to be output just as "\." -- instead needs to be "\&." (which
-    is what it will be now, after this change)
-
-  • Michael(tm) Smith: refentry.xsl
-
-    Changed backend handling for generating titles for SH sections and
-    for cross-references to those sections. This should have no effect
-    on TTY output (behavior should remain the same hopefully) but
-    results in titles in normal case (instead of uppercase) in PS
-    output.
-
-  • Michael(tm) Smith: info.xsl
-
-    use make.subheading template to make subheadings for AUTHORS and
-    COPYRIGHT sections (instead of harcoding roff markup)
-
-  • Michael(tm) Smith: block.xsl
-
-    put code font around programlisting etc.
-
-  • Michael(tm) Smith: synop.xsl; docbook.xsl
-
-    embed custom macro definitions in man pages, plus wrap synopsis in
-    code font
-
-  • Michael(tm) Smith: endnotes.xsl
-
-    use the make.subheading template to generated SH subheading for
-    endnotes section.
-
-  • Michael(tm) Smith: lists.xsl
-
-    Added some templates for generating if-then-else conditional
-    markup in groff, so let's use those instead of hard-coding it in
-    multiple places...
-
-  • Michael(tm) Smith: other.xsl; utility.xsl
-
-    Initial checkin of some changes related to making PS/PDF output
-    from "man -l -Tps" look better. The current changes:
-
-      - render synopsis and verbatim sections in a monospace/code font
-
-      - put a light-grey background behind all programlisting, screen,
-        and literallayout instances
-
-      - prevent SH heads in PS output from being rendered in uppercase
-        (as they are in console output)
-
-      - also display xrefs to SH heads in PS output in normal case
-        (instead of uppercase)
-
-      - draw a line under SH heads in PS output
-
-    The changes made to the code to support the above features were:
-
-      - added some embedded/custom macros: one for conditionally
-        upper-casing SH x-refs, one for redefining the SH macro
-        itself, with some conditional handling for PS output, and
-        finally a macro for putting a background/screen (filled box)
-        around a block of text (e.g., a program listing) in PS output
-
-      - added utility templates for wrapping blocks of text in code
-        font; also templates for inline code font
-
-  • Robert Stayton: refentry.xsl
-
-    refpurpose nodes now get apply-templates instead of just normalize-space().
-
-  • Michael(tm) Smith: lists.xsl
-
-    Fixed alignment of first lined of text for each listitem in
-    orderedlist output for TTY. Existing code seemed to have been
-    causing an extra undesirable space to appear.
-
-  • Michael(tm) Smith: lists.xsl
-
-    Wrapped some roff conditionals around roff markup for orderedlist
-    and itemizedlist output, so that the lists look acceptable in PS
-    output as well as TTY.
-
-  • Michael(tm) Smith: pi.xsl; synop.xsl; param.xweb; param.ent
-
-    Added the man.funcsynopsis.style parameter. Has the same effect in
-    manpages output as the funcsynopsis.style parameter has in HTML
-    output -- except that its default value is 'ansi' instead of 'kr'.
-
-  • Michael(tm) Smith: synop.xsl
-
-    Reworked handling of K&R funcprototype output. It no longer relies
-    on the HTML kr-tabular templates, but instead just does direct
-    transformation to roff. For K&R output, it displays the paramdef
-    output in an indented list following the prototype.
-
-  • Michael(tm) Smith: synop.xsl
-
-    Properly integrated handling for K&R output into manpages
-    stylesheet. The choice between K&R output and ANSI output is
-    currently controlled through use of the (HTML) funcsynopsis.style
-    parameter. Note that because the mechanism does currently rely on
-    funcsynopsis.style, the default in manpages output is now K&R
-    (because that's the default of that param). But I suppose I ought
-    to create a man.funcsynopsis.style and make the default for that
-    ANSI (to preserve the existing default behavior).
-
-  • Michael(tm) Smith: docbook.xsl
-
-    added manpages/pi.xsl file
-
-  • Michael(tm) Smith: .cvsignore; pi.xsl
-
-    Added "dbman funcsynopsis-style" PI and incorporated it into the
-    doc build.
-
-  • Michael(tm) Smith: refentry.xsl
-
-    Fixed regression that caused an unescaped dash to be output
-    between refname and refpurpose content. Closes bug #1894244.
-    Thanks to Daniel Leidert.
-
-  • Michael(tm) Smith: other.xsl
-
-    Fixed problem with dots being escaped in filenames of generated
-    man files. Closes #1827195. Thanks to Daniel Leidert.
-
-  • Michael(tm) Smith: inline.xsl
-
-    Added support for processing structfield (was appearing in roff
-    output surrounded by HTML <em> tags; fixed so that it gets roff
-    ital markup). Closes bug #1858329.  Thanks to Sam Varshavchik.
-
-Epub
-
-The following changes have been made to the epub code since the 1.73.2 release.
-
-  • Keith Fahlgren: bin/spec/README; bin/spec/epub_realbook_spec.rb
-
-    'Realbook' spec now passes
-
-  • Keith Fahlgren: bin/dbtoepub; README; bin/spec/README; bin/lib/docbook.rb;
-    bin/spec/epub_r⋯
-
-    Very primitive Windows support for dbtoepub reference implementation; README for running tests and for the .epub target in general; shorter realbook test document (still fails for now)
-
-  • Keith Fahlgren: bin/dbtoepub; bin/spec/epub_regressions_spec.rb; bin/lib/
-    docbook.rb; bin/s⋯
-
-    Changes to OPF spine to not duplicate idrefs for documents with parts not at the root; regression specs for same
-
-  • Keith Fahlgren: docbook.xsl
-
-    Fixing linking to cover @id, distinct from other needs of cover-image-id (again, thanks to Martin Goerner)
-
-  • Keith Fahlgren: docbook.xsl
-
-    Updating the title of the toc element in the guide to be more explicit (thanks to Martin Goerner)
-
-  • Keith Fahlgren: bin/spec/examples/amasque_exploded/content.opf; bin/spec/
-    examples/amasque_⋯
-
-    Initial checkin/merge of epub target from work provided by Paul Norton of Adobe
-    and Keith Fahlgren of O'Reilly.
-
-  • Keith Fahlgren: docbook.xsl
-
-    == General epub test support
-
-    $ spec -O ~/.spec.opts spec/epub_spec.rb
-
-    DocBook::Epub
-    - should be able to be created
-    - should fail on a nonexistent file
-    - should be able to render to a file
-    - should create a file after rendering
-    - should have the correct mimetype after rendering
-    - should be valid .epub after rendering an article
-    - should be valid .epub after rendering an article without sections
-    - should be valid .epub after rendering a book
-    - should be valid .epub after rendering a book even if it has one graphic
-    - should be valid .epub after rendering a book even if it has many graphics
-    - should be valid .epub after rendering a book even if it has many duplicated graphics
-    - should report an empty file as invalid
-    - should confirm that a valid .epub file is valid
-    - should not include PDFs in rendered epub files as valid image inclusions
-    - should include a TOC link in rendered epub files for <book>s
-
-    Finished in 20.608395 seconds
-
-    15 examples, 0 failures
-
-
-    == Verbose epub test coverage against _all_ of the testdocs
-
-    Fails on only (errors truncated):
-    1)
-    'DocBook::Epub should be able to render a valid .epub for the test document /Users/keith/work/docbook-dev/trunk/xsl/epub/bin/spec/testdocs/calloutlist.003.xml [30]' FAILED
-    'DocBook::Epub should be able to render a valid .epub for the test document /Users/keith/work/docbook-dev/trunk/xsl/epub/bin/spec/testdocs/cmdsynopsis.001.xml [35]' FAILED
-    ....
-
-    Finished in 629.89194 seconds
-
-    224 examples, 15 failures
-
-    224 examples, 15 failures yields 6% failure rate
-
-HTMLHelp
-
-The following changes have been made to the htmlhelp code since the 1.73.2
-release.
-
-  • Mauritz Jeanson: htmlhelp-common.xsl
-
-    Added <xsl:with-param name="quiet" select="$chunk.quietly"/> to calls to
-    the write.chunk, write.chunk.with.doctype, and write.text.chunk templates.
-    This makes chunk.quietly=1 suppress chunk filename messages also for help
-    support files (which seems to be what one would expect). See bug #1648360.
-
-Eclipse
-
-The following changes have been made to the eclipse code since the 1.73.2
-release.
-
-  • David Cramer: eclipse.xsl
-
-    Use sortas attributes (if they exist) when sorting indexterms
-
-  • David Cramer: eclipse.xsl
-
-    Added support for indexterm/see in eclipse index.xml
-
-  • Mauritz Jeanson: eclipse.xsl
-
-    Added <xsl:with-param name="quiet" select="$chunk.quietly"/>
-    to helpidx template.
-
-  • David Cramer: eclipse.xsl
-
-    Generate index.xml file and add related goo to plugin.xml file. Does not yet support see and seealso.
-
-  • Mauritz Jeanson: eclipse.xsl
-
-    Added <xsl:with-param name="quiet" select="$chunk.quietly"/> to calls to
-    the write.chunk, write.chunk.with.doctype, and write.text.chunk templates.
-    This makes chunk.quietly=1 suppress chunk filename messages also for help
-    support files (which seems to be what one would expect). See bug #1648360.
-
-JavaHelp
-
-The following changes have been made to the javahelp code since the 1.73.2
-release.
-
-  • Mauritz Jeanson: javahelp.xsl
-
-    Added <xsl:with-param name="quiet" select="$chunk.quietly"/> to calls to
-    the write.chunk, write.chunk.with.doctype, and write.text.chunk templates.
-    This makes chunk.quietly=1 suppress chunk filename messages also for help
-    support files (which seems to be what one would expect). See bug #1648360.
-
-Roundtrip
-
-The following changes have been made to the roundtrip code since the 1.73.2
-release.
-
-  • Steve Ball: blocks2dbk.xsl; wordml2normalise.xsl
-
-    fix table/cell borders for wordml, fix formal figure, add emphasis-strong
-
-  • Mauritz Jeanson: supported.xml
-
-    Changed @cols to 5.
-
-  • Steve Ball: blocks2dbk.xsl; blocks2dbk.dtd; template.xml
-
-    added pubdate, fixed metadata handling in biblioentry
-
-  • Steve Ball: supported.xml
-
-    Added support for edition.
-
-  • Steve Ball: docbook-pages.xsl; wordml-blocks.xsl; docbook.xsl; wordml.xsl;
-    pages-normalise⋯
-
-    Removed stylesheets for old, deprecated conversion method.
-
-  • Steve Ball: specifications.xml; dbk2ooo.xsl; blocks2dbk.xsl; dbk2pages.xsl;
-    blocks2dbk.dtd⋯
-
-    Added support for Open Office, added edition element, improved list and table support in Word and Pages
-
-  • Steve Ball: normalise-common.xsl; blocks2dbk.xsl; dbk2pages.xsl;
-    template-pages.xml; templ⋯
-
-    Fixed bug in WordML table handling, improved table handling for Pages 08, synchronised WordML and Pages templates.
-
-  • Steve Ball: normalise-common.xsl; blocks2dbk.xsl; wordml2normalise.xsl;
-    dbk2wp.xsl
-
-    fix caption, attributes
-
-  • Steve Ball: specifications.xml; blocks2dbk.xsl; wordml2normalise.xsl;
-    blocks2dbk.dtd; temp⋯
-
-    Fixes to table and list handling
-
-  • Steve Ball: blocks2dbk.xsl
-
-    added support for explicit emphasis character styles
-
-  • Steve Ball: wordml2normalise.xsl
-
-    added support for customisation in image handling
-
-  • Steve Ball: blocks2dbk.xsl
-
-    Added inlinemediaobject support for metadata.
-
-  • Steve Ball: normalise-common.xsl; blocks2dbk.xsl; template.xml;
-    dbk2wordml.xsl; dbk2wp.xsl
-
-    Added support file. Added style locking. Conversion bug fixes.
-
-Slides
-
-The following changes have been made to the slides code since the 1.73.2
-release.
-
-  • Michael(tm) Smith: fo/Makefile; html/Makefile
-
-    Added checks and hacks to various makefiles to enable building
-    under Cygwin. This stuff is ugly and maybe not worth the mess and
-    trouble, but does seem to work as expected and not break anything
-    else.
-
-  • Jirka Kosek: html/plain.xsl
-
-    Added support for showing foil number
-
-Website
-
-The following changes have been made to the website code since the 1.73.2
-release.
-
-  • Michael(tm) Smith: extensions/saxon64/.classes/.gitignore; extensions/
-    xalan2/.classes/com/⋯
-
-    renamed a bunch more .cvsignore files to .gitignore (to facilitate use of git-svn)
-
-Params
-
-The following changes have been made to the params code since the 1.73.2
-release.
-
-  • Keith Fahlgren: epub.autolabel.xml
-
-    New parameter for epub, epub.autolabel
-
-  • Mauritz Jeanson: table.frame.border.color.xml; table.cell.padding.xml;
-    table.cell.border.t⋯
-
-    Added missing refpurposes and descriptions.
-
-  • Keith Fahlgren: ade.extensions.xml
-
-    Extensions to support Adobe Digital Editions extensions in .epub output.
-
-  • Mauritz Jeanson: fop.extensions.xml; fop1.extensions.xml
-
-    Clarified that fop1.extensions is for FOP 0.90 and later. Version 1 is not here yet...
-
-  • Michael(tm) Smith: man.links.are.underlined.xml;
-    man.endnotes.list.enabled.xml; man.font.l⋯
-
-    removed man.links.are.underlined and added man.font.links. Also,
-    changed the default font formatting for links to bold.
-
-  • Michael(tm) Smith: man.base.url.for.relative.links.xml
-
-    Added new param man.base.url.for.relative.links .. specifies a
-    base URL for relative links (for ulink, @xlink:href, imagedata,
-    audiodata, videodata) shown in the generated NOTES section of
-    man-page output. The value of man.base.url.for.relative.links is
-    prepended to any relative URI that is a value of ulink url,
-    xlink:href, or fileref attribute.
-
-    If you use relative URIs in link sources in your DocBook refentry
-    source, and you leave man.base.url.for.relative.links unset, the
-    relative links will appear "as is" in the NOTES section of any
-    man-page output generated from your source. That's probably not
-    what you want, because such relative links are only usable in the
-    context of HTML output. So, to make the links meaningful and
-    usable in the context of man-page output, set a value for
-    man.base.url.for.relative.links that points
-    to the online version of HTML output generated from your DocBook
-    refentry source. For example:
-
-      <xsl:param name="man.base.url.for.relative.links"
-      >http://www.kernel.org/pub/software/scm/git/docs/</xsl:param>
-
-  • Michael(tm) Smith: man.string.subst.map.xml
-
-    squeeze .sp\n.sp into a single .sp (to prevent a extra, spurious
-    line of whitespace from being inserted after programlisting etc.
-    in certain cases)
-
-  • Michael(tm) Smith: refentry.manual.fallback.profile.xml;
-    refentry.source.fallback.profile.⋯
-
-    don't use refmiscinfo@class=date value as fallback for refentry
-    "source" or "manual" metadata fields
-
-  • Michael(tm) Smith: man.charmap.subset.profile.xml; man.charmap.enabled.xml;
-    man.charmap.su⋯
-
-    made some further doc tweaks related to the
-    man.charmap.subset.profile.english param
-
-  • Michael(tm) Smith: man.charmap.subset.profile.xml; man.charmap.enabled.xml;
-    man.charmap.su⋯
-
-    Added the man.charmap.subset.profile.english parameter and refined
-    the handling of charmap subsets to differentiate between English
-    and non-English source.
-
-    This way charmap subsets are now handled is this:
-
-    If the value of the man.charmap.use.subset parameter is non-zero,
-    and your DocBook source is not written in English (that is, if its
-    lang or xml:lang attribute has a value other than en), then the
-    character-map subset specified by the man.charmap.subset.profile
-    parameter is used instead of the full roff character map.
-
-    Otherwise, if the lang or xml:lang attribute on the root element
-    in your DocBook source or on the first refentry element in your
-    source has the value en or if it has no lang or xml:lang
-    attribute, then the character-map subset specified by the
-    man.charmap.subset.profile.english parameter is used instead of
-    man.charmap.subset.profile.
-
-    The difference between the two subsets is that
-    man.charmap.subset.profile provides mappings for characters in
-    Western European languages that are not part of the Roman
-    (English) alphabet (ASCII character set).
-
-  • Michael(tm) Smith: man.charmap.subset.profile.xml
-
-    Added to default charmap used by manpages:
-
-      - the "letters" part of the 'C1 Controls And Latin-1 Supplement
-        (Latin-1 Supplement)' Unicode block
-      - Latin Extended-A block (but not all of the characters from
-        that block have mappings in groff, so some of them are still
-        passed through as-is)
-
-    The effects of this change are that in man pages generated for
-    most Western European languages and for Finnish, all characters
-    not part of the Roman alphabet are (e.g., "accented" characters)
-    are converted to groff escapes.
-
-    Previously, by default we passed through those characters as is
-    (and users needed to use the full charmap if they wanted to have
-    those characters converted).
-
-    As a result of this change, man pages generated for Western
-    European languages will be viewable in some environments in which
-    they are not viewable if the "raw" non-Roman characters are in them.
-
-  • Mauritz Jeanson: generate.legalnotice.link.xml;
-    generate.revhistory.link.xml
-
-    Added information on how the filename is computed.
-
-  • Mauritz Jeanson: default.table.width.xml
-
-    Clarified PI usage.
-
-  • Michael(tm) Smith: man.funcsynopsis.style.xml
-
-    Added the man.funcsynopsis.style parameter. Has the same effect in
-    manpages output as the funcsynopsis.style parameter has in HTML
-    output -- except that its default value is 'ansi' instead of 'kr'.
-
-  • Michael(tm) Smith: funcsynopsis.tabular.threshold.xml
-
-    Removed the funcsynopsis.tabular.threshold param. It's no longer
-    being used in the code and hasn't been since mid 2006.
-
-  • Mauritz Jeanson: table.properties.xml
-
-    Set keep-together.within-column to "auto". This seems to be the most sensible
-    default value for tables.
-
-  • Mauritz Jeanson: informal.object.properties.xml;
-    admon.graphics.extension.xml; informalequ⋯
-
-    Several small documentation fixes.
-
-  • Mauritz Jeanson: manifest.in.base.dir.xml
-
-    Wording fixes.
-
-  • Mauritz Jeanson: header.content.properties.xml;
-    footer.content.properties.xml
-
-    Added refpurpose.
-
-  • Mauritz Jeanson: ulink.footnotes.xml; ulink.show.xml
-
-    Updated for DocBook 5.
-
-  • Mauritz Jeanson: index.method.xml; glossterm.auto.link.xml
-
-    Spelling and wording fixes.
-
-  • Mauritz Jeanson: callout.graphics.extension.xml
-
-    Clarifed available graphics formats and extensions.
-
-  • Mauritz Jeanson: footnote.sep.leader.properties.xml
-
-    Corrected refpurpose.
-
-  • Jirka Kosek: footnote.properties.xml
-
-    Added more properties which make it possible to render correctly footnotes placed inside verbatim elements.
-
-  • Mauritz Jeanson: img.src.path.xml
-
-    img.src.path works with inlinegraphic too.
-
-  • Mauritz Jeanson: saxon.character.representation.xml
-
-    Added TCG link.
-
-  • Mauritz Jeanson: img.src.path.xml
-
-    Updated description of img.src.path. Bug #1785224 revealed that
-    there was a risk of misunderstanding how it works.
-
-Profiling
-
-The following changes have been made to the profiling code since the 1.73.2
-release.
-
-  • Jirka Kosek: xsl2profile.xsl
-
-    Added new rules to profile all content generated by HTML Help (including alias files)
-
-  • Robert Stayton: profile-mode.xsl
-
-    use mode="profile" instead of xsl:copy-of for attributes so
-    they can be more easily customized.
-
-Tools
-
-The following changes have been made to the tools code since the 1.73.2
-release.
-
-  • Michael(tm) Smith: make/Makefile.DocBook
-
-    various changes and additions to support making with asciidoc as
-    an input format
-
-  • Michael(tm) Smith: make/Makefile.DocBook
-
-    make dblatex the default PDF maker for the example makefile
-
-  • Michael(tm) Smith: xsl/build/html2roff.xsl
-
-    Reworked handling of K&R funcprototype output. It no longer relies
-    on the HTML kr-tabular templates, but instead just does direct
-    transformation to roff. For K&R output, it displays the paramdef
-    output in an indented list following the prototype.
-
-  • Mauritz Jeanson: xsl/build/make-xsl-params.xsl
-
-    Made attribute-sets members of the param list. This enables links to attribute-sets in the
-    reference documentation.
-
-  • Michael(tm) Smith: xsl/build/html2roff.xsl
-
-    use .BI handling in K&R funsynopsis output for manpages, just as
-    we do already of ANSI output
-
-  • Michael(tm) Smith: xsl/build/html2roff.xsl
-
-    Implemented initial support for handling tabular K&R output of
-    funcprototype in manpages output. Accomplished by adding more
-    templates to the intermediate HTML-to-roff stylesheet that the
-    build uses to create the manpages/html-synop.xsl stylesheet.
-
-  • Michael(tm) Smith: xsl/build/doc-link-docbook.xsl
-
-    Made the xsl/tools/xsl/build/doc-link-docbook.xsl stylesheet
-    import profile-docbook.xsl, so that we can do profiling of release
-    notes. Corrected some problems in the target for the release-notes
-    HTML build.
-
-Extensions
-
-The following changes have been made to the extensions code since the 1.73.2
-release.
-
-  • Keith Fahlgren: Makefile
-
-    Use DOCBOOK_SVN variable everywhere, please; build with PDF_MAKER
-
-  • Michael(tm) Smith: Makefile
-
-    moved extensions build targets from master xsl/Makefile to
-    xsl/extensions/Makefile
-
-  • Michael(tm) Smith: .cvsignore
-
-    re-adding empty extensions subdir
-
-XSL-Saxon
-
-The following changes have been made to the xsl-saxon code since the 1.73.2
-release.
-
-  • Michael(tm) Smith: VERSION
-
-    bring xsl2, xsl-saxon, and xsl-xalan VERSION files up-to-date with
-    recent change to snapshot build infrastructure
-
-  • Michael(tm) Smith: nbproject/build-impl.xml; nbproject/project.properties
-
-    Changed hard-coded file references in "clean" target to variable
-    references. Closes #1792043. Thanks to Daniel Leidert.
-
-  • Michael(tm) Smith: VERSION; Makefile
-
-    Did post-release wrap-up of xsl-saxon and xsl-xalan dirs
-
-  • Michael(tm) Smith: nbproject/build-impl.xml; VERSION; Makefile; test
-
-    More tweaks to get release-ready
-
-XSL-Xalan
-
-The following changes have been made to the xsl-xalan code since the 1.73.2
-release.
-
-  • Michael(tm) Smith: VERSION
-
-    bring xsl2, xsl-saxon, and xsl-xalan VERSION files up-to-date with
-    recent change to snapshot build infrastructure
-
-  • Michael(tm) Smith: nbproject/build-impl.xml
-
-    Changed hard-coded file references in "clean" target to variable
-    references. Closes #1792043. Thanks to Daniel Leidert.
-
-  • Michael(tm) Smith: Makefile; VERSION
-
-    Did post-release wrap-up of xsl-saxon and xsl-xalan dirs
-
-  • Michael(tm) Smith: Makefile; nbproject/build-impl.xml; VERSION
-
-    More tweaks to get release-ready
-
-XSL-libxslt
-
-The following changes have been made to the xsl-libxslt code since the 1.73.2
-release.
-
-  • Mauritz Jeanson: python/xslt.py
-
-    Print the result to stdout if no outfile has been given.
-    Some unnecessary semicolons removed.
-
-  • Mauritz Jeanson: python/xslt.py
-
-    Added a function that quotes parameter values (to ensure that they are interpreted as strings).
-    Replaced deprecated functions from the string module with string methods.
-
-  • Michael(tm) Smith: python/README; python/README.LIBXSLT
-
-    renamed xsl-libxslt/python/README to xsl-libxslt/python/README.LIBXSLT
-
-  • Mauritz Jeanson: python/README
-
-    Tweaked the text a little.
-
-Release Notes: 1.73.2
-
-This is solely a minor bug-fix update to the 1.73.1 release. It fixes a
-packaging error in the 1.73.1 package, as well as a bug in footnote handling in
-FO output.
-
-Release: 1.73.1
-
-This is mostly a bug-fix update to the 1.73.0 release.
-
-Gentext
-
-The following changes have been made to the gentext code since the 1.73.0
-release.
-
-  • Mauritz Jeanson: locale/de.xml
-
-    Applied patch #1766009.
-
-  • Michael(tm) Smith: locale/lv.xml
-
-    Added localization for ProductionSet.
-
-FO
-
-The following changes have been made to the fo code since the 1.73.0 release.
-
-  • Mauritz Jeanson: table.xsl
-
-    Modified the tgroup template so that, for tables with multiple tgroups,
-    a width attribute is output on all corresponding fo:tables. Previously,
-    there was a test prohibiting this (and a comment saying that outputting more
-    than one width attribute will cause an error). But this seems to be no longer
-    relevant; it is not a problem with FOP 0.93 or XEP 4.10. Closes bug #1760559.
-
-  • Mauritz Jeanson: graphics.xsl
-
-    Replaced useless <a> elements with warning messages (textinsert extension).
-
-  • Mauritz Jeanson: admon.xsl
-
-    Enabled generation of ids (on fo:wrapper) for indexterms in admonition titles, so that page
-    references in the index can be created. Closes bug #1775086.
-
-HTML
-
-The following changes have been made to the html code since the 1.73.0 release.
-
-  • Mauritz Jeanson: titlepage.xsl
-
-    Added <xsl:call-template name="process.footnotes"/> to abstract template
-    so that footnotes in info/abstract are processed. Closes bug #1760907.
-
-  • Michael(tm) Smith: pi.xsl; synop.xsl
-
-    Changed handling of HTML output for the cmdsynopsis and
-    funcsynopsis elements, such that a@id instances are generated for
-    them if they are descendants of any element containing a dbcmdlist
-    or dbfunclist PI. Also, update the embedded reference docs for the
-    dbcmdlist and dbfunclist PIs to make it clear that they can be
-    used within any element for which cmdsynopsis or funcsynopsis are
-    valid children.
-
-  • Michael(tm) Smith: formal.xsl
-
-    Reverted the part of revision 6952 that caused a@id anchors to be
-    generated for output of informal objects. Thanks to Sam Steingold
-    for reporting.
-
-  • Robert Stayton: glossary.xsl
-
-    Account for a glossary with no glossdiv or glossentry children.
-
-  • Mauritz Jeanson: titlepage.xsl
-
-    Modified legalnotice template so that the base.name parameter is calculated
-    in the same way as for revhistory chunks. Using <xsl:apply-templates
-    mode="chunk-filename" select="."/> did not work for single-page output since
-    the template with that mode is in chunk-code.xsl.
-
-  • Mauritz Jeanson: graphics.xsl
-
-    Updated support for SVG (must be a child of imagedata in DB 5).
-    Added support for MathML in imagedata.
-
-  • Mauritz Jeanson: pi.xsl
-
-    Added documentation for the dbhh PI (used for context-sensitive HTML Help).
-    (The two templates matching 'dbhh' are still in htmlhelp-common.xsl).
-
-Manpages
-
-The following changes have been made to the manpages code since the 1.73.0
-release.
-
-  • Michael(tm) Smith: endnotes.xsl
-
-    In manpages output, generate warnings about notesources with
-    non-para children only if the notesource is a footnote or
-    annotation. Thanks to Sam Steingold for reporting problems with
-    the existing handling.
-
-HTMLHelp
-
-The following changes have been made to the htmlhelp code since the 1.73.0
-release.
-
-  • Michael(tm) Smith: htmlhelp-common.xsl
-
-    Added single-pass namespace-stripping support to the htmlhelp,
-    eclipse, and javahelp stylesheets.
-
-Eclipse
-
-The following changes have been made to the eclipse code since the 1.73.0
-release.
-
-  • Michael(tm) Smith: eclipse.xsl
-
-    Added single-pass namespace-stripping support to the htmlhelp,
-    eclipse, and javahelp stylesheets.
-
-JavaHelp
-
-The following changes have been made to the javahelp code since the 1.73.0
-release.
-
-  • Michael(tm) Smith: javahelp.xsl
-
-    Added single-pass namespace-stripping support to the htmlhelp,
-    eclipse, and javahelp stylesheets.
-
-Roundtrip
-
-The following changes have been made to the roundtrip code since the 1.73.0
-release.
-
-  • Steve Ball: blocks2dbk.xsl; blocks2dbk.dtd; pages2normalise.xsl
-
-    Modularised blocks2dbk to allow customisation,
-    Added support for tables to pages2normalise
-
-Params
-
-The following changes have been made to the params code since the 1.73.0
-release.
-
-  • Robert Stayton: procedure.properties.xml
-
-    procedure was inheriting keep-together from formal.object.properties, but
-    a procedure does not need to be kept together by default.
-
-  • Dave Pawson: title.font.family.xml;
-    component.label.includes.part.label.xml; table.frame.b⋯
-
-    Regular formatting re-org.
-
-Release: 1.73.0
-
-This release includes important bug fixes and adds the following significant
-feature changes:
-
-New localizations and localization updates
-
-    We added two new localizations: Latvian and Esperanto, and made updates to
-    the Czech, Chinese Simplified, Mongolian, Serbian, Italian, and Ukrainian
-    localizations.
-
-ISO690 citation style for bibliography output.
-
-    Set the bibliography.style parameter to iso690 to use ISO690 style.
-
-New documentation for processing instructions (PI)
-
-    The reference documentation that ships with the release now includes
-    documentation on all PIs that you can use to control output from the
-    stylesheets.
-
-New profiling parameters for audience and wordsize
-
-    You can now do profiling based on the values of the audience and wordsize
-    attributes.
-
-Changes to man-page output
-
-    The manpages stylesheet now supports single-pass profiling and single-pass
-    DocBook 5 namespace stripping (just as the HTML and FO stylesheets also
-    do). Also, added handling for mediaobject & inlinemediaobject. (Each
-    imagedata, audiodata, or videodata element within a mediaobject or inline
-    mediaobject is now treated as a "notesource" and so handled in much the
-    same way as links and annotation/alt/footnote are in manpages output.) And
-    added the man.authors.section.enabled and man.copyright.section.enabled
-    parameters to enable control over whether output includes auto-generated
-    AUTHORS and COPYRIGHT sections.
-
-Highlighting support for C
-
-    The highlighting mechanism for generating syntax-highlighted code snippets
-    in output now supports C code listings (along with Java, PHP, XSLT, and
-    others).
-
-Experimental docbook-xsl-update script
-
-    We added an experimental docbook-xsl-update script, the purpose of which is
-    to facilitate easy sync-up to the latest docbook-xsl snapshot (by means of
-    rsync).
-
-Gentext
-
-The following changes have been made to the gentext code since the 1.72.0
-release.
-
-  • Michael(tm) Smith: locale/lv.xml; Makefile
-
-    Added Latvian localization file, from Girts Ziemelis.
-
-  • Dongsheng Song: locale/zh_cn.xml
-
-    Brought up to date with en.xml in terms of items. A few strings marked for translation.
-
-  • Jirka Kosek: locale/cs.xml
-
-    Added missing translations
-
-  • Robert Stayton: locale/eo.xml
-
-    New locale for Esperanto.
-
-  • Robert Stayton: locale/mn.xml
-
-    Update from Ganbold Tsagaankhuu.
-
-  • Jirka Kosek: locale/en.xml; locale/cs.xml
-
-    Rules for normalizing glossary entries before they are sorted can be now different for each language.
-
-  • Michael(tm) Smith: locale/sr_Latn.xml; locale/sr.xml
-
-    Committed changes from Miloš Komarčević to Serbian files.
-
-  • Robert Stayton: locale/ja.xml
-
-    Fix chapter in context xref-number-and-title
-
-  • Robert Stayton: locale/it.xml
-
-    Improved version from contributor.
-
-  • Mauritz Jeanson: locale/uk.xml
-
-    Applied patch 1592083.
-
-Common
-
-The following changes have been made to the common code since the 1.72.0
-release.
-
-  • Michael(tm) Smith: labels.xsl
-
-    Changed handling of reference auto-labeling such that reference
-    (when it appears at the component level) is now affected by the
-    label.from.part param, just as preface, chapter, and appendix.
-
-  • Michael(tm) Smith: common.xsl
-
-    Added support to the HTML stylesheets for proper processing of
-    orgname as a child of author.
-
-  • Michael(tm) Smith: refentry.xsl
-
-    Refined logging output of refentry metadata-gathering template;
-    for some cases of "missing" elements (refmiscinfo stuff, etc.),
-    the log messages now include URL to corresponding page in the
-    Definitive Guide (TDG).
-
-  • Robert Stayton: titles.xsl
-
-    Add refsection/info/title support.
-
-  • Michael(tm) Smith: titles.xsl
-
-    Added support for correct handling of xref to elements that
-    contain info/title descendants but no title children.
-
-    This should be further refined so that it handles any *info
-    elements. And there are probably some other places where similar
-    handling for *info/title should be added.
-
-  • Mauritz Jeanson: pi.xsl
-
-    Modified <xsl:when> in datetime.format template to work
-    around Xalan bug.
-
-FO
-
-The following changes have been made to the fo code since the 1.72.0 release.
-
-  • Robert Stayton: component.xsl
-
-    Add parameters to the page.sequence utility template.
-
-  • Mauritz Jeanson: xref.xsl
-
-    Added template for xref to area/areaset.
-    Part of fix for bug #1675513 (xref to area broken).
-
-  • Michael(tm) Smith: inline.xsl
-
-    Added template match for person element to fo stylesheet.
-
-  • Robert Stayton: lists.xsl
-
-    Added support for spacing="compact" in variablelist, per bug report #1722540.
-
-  • Robert Stayton: table.xsl
-
-    table pgwide="1" should also use pgwide.properties attribute-set.
-
-  • Mauritz Jeanson: inline.xsl
-
-    Make citations numbered if bibliography.numbered != 0.
-
-  • Robert Stayton: param.xweb; param.ent
-
-    Add new profiling parameters for audience and wordsize.
-
-  • Robert Stayton: param.xweb; param.ent
-
-    Added callout.icon.size parameter.
-
-  • Robert Stayton: inline.xsl; xref.xsl
-
-    Add support for xlink as olink.
-
-  • Robert Stayton: autotoc.xsl; param.xweb; param.ent
-
-    Add support for qanda.in.toc to fo TOC.
-
-  • Robert Stayton: component.xsl
-
-    Improved the page.sequence utility template for use with book.
-
-  • Robert Stayton: division.xsl
-
-    Refactored the big book template into smaller pieces.
-    Used the "page.sequence" utility template in
-    component.xsl to shorten the toc piece.
-    Added placeholder templates for front.cover and back.cover.
-
-  • Robert Stayton: param.xweb; param.ent; sections.xsl
-
-    Add section.container.element parameter to enable
-    pgwide spans inside sections.
-
-  • Robert Stayton: param.xweb; param.ent; component.xsl
-
-    Add component.titlepage.properties attribute-set to
-    support span="all" and other properties.
-
-  • Robert Stayton: htmltbl.xsl; table.xsl
-
-    Apply table.row.properties template to html tr rows too.
-    Add keep-with-next to table.row.properties when row is in thead.
-
-  • Robert Stayton: table.xsl
-
-    Add support for default.table.frame parameter.
-    Fix bug 1575446 rowsep last check for @morerows.
-
-  • Robert Stayton: refentry.xsl
-
-    Add support for info/title in refsections.
-
-  • David Cramer: qandaset.xsl
-
-    Make fo questions and answers behave the same way as html
-
-  • Jirka Kosek: lists.xsl
-
-    Added missing attribute set for procedure
-
-  • Jirka Kosek: param.xweb; biblio.xsl; docbook.xsl; param.ent;
-    biblio-iso690.xsl
-
-    Added support for formatting biblioentries according to ISO690 citation style.
-    New bibliography style can be turned on by setting parameter bibliography.style to "iso690"
-    The code was provided by Jana Dvorakova
-
-  • Robert Stayton: param.xweb; param.ent; pagesetup.xsl
-
-    Add header.table.properties and footer.table.properties attribute-sets.
-
-  • Robert Stayton: inline.xsl
-
-    Add fop1.extensions for menuchoice arrow handling exception.
-
-HTML
-
-The following changes have been made to the html code since the 1.72.0 release.
-
-  • Mauritz Jeanson: param.xweb; param.ent
-
-    Moved declaration and documentation of javahelp.encoding from javahelp.xsl to the
-    regular "parameter machinery".
-
-  • Michael(tm) Smith: admon.xsl
-
-    Changed handling of titles for note, warning, caution, important,
-    tip admonitions: We now output and HTML h3 head only if
-    admon.textlabel is non-zero or if the admonition actually contains
-    a title; otherwise, we don't output an h3 head at all.
-    (Previously, we were outputting an empty h3 if the admon.textlabel
-    was zero and if the admonition had no title.)
-
-  • Mauritz Jeanson: xref.xsl
-
-    Added template for xref to area/areaset.
-    Part of fix for bug #1675513 (xref to area broken).
-
-  • Mauritz Jeanson: titlepage.xsl; component.xsl; division.xsl; sections.xsl
-
-    Added fixes to avoid duplicate ids when generate.id.attributes = 1.
-    This (hopefully) closes bug #1671052.
-
-  • Michael(tm) Smith: formal.xsl; pi.xsl
-
-    Made the dbfunclist PI work as intended. Also added doc for
-    dbfunclist and dbcmdlist PIs.
-
-  • Michael(tm) Smith: pi.xsl; synop.xsl
-
-    Made the dbcmdlist work the way it appears to have been intended
-    to work. Restored dbhtml-dir template back to pi.xsl.
-
-  • Michael(tm) Smith: titlepage.xsl; param.xweb; param.ent
-
-    Added new param abstract.notitle.enabled.
-    If non-zero, in output of the abstract element on titlepages,
-    display of the abstract title is suppressed.
-    Because sometimes you really don't want or need that title
-    there...
-
-  • Michael(tm) Smith: chunk-code.xsl; graphics.xsl
-
-    When we are chunking long descriptions for mediaobject instances
-    into separate HTML output files, and use.id.as.filename is
-    non-zero, if a mediaobject has an ID, use that ID as the basename
-    for the long-description file (otherwise, we generate an ID for it
-    and use that ID as the basename for the file).
-    The parallels the recent change made to cause IDs for legalnotice
-    instances to be used as basenames for legalnotice chunks.
-    Also, made some minor refinements to the recent changes for
-    legalnotice chunk handling.
-
-  • Michael(tm) Smith: titlepage.xsl
-
-    Added support to the HTML stylesheets for proper processing of
-    orgname as a child of author.
-
-  • Michael(tm) Smith: chunk-code.xsl
-
-    When $generate.legalnotice.link is non-zero and
-    $use.id.as.filename is also non-zero, if a legalnotice has an ID,
-    then instead of assigning the "ln-<generatedID>" basename to the
-    output file for that legalnotice, just use its real ID as the
-    basename for the file -- as we do when chunking other elements
-    that have IDs.
-
-  • David Cramer: xref.xsl
-
-    Handle alt text on xrefs to steps when the step doesn't have a title.
-
-  • David Cramer: lists.xsl
-
-    Added <p> element around term in variablelist when formatted as table to avoid misalignment of term and listitem in xhtml (non-quirks mode) output
-
-  • David Cramer: qandaset.xsl
-
-    Added <p> element around question and answer labels to avoid misalignment of label and listitem in xhtml (non-quirks mode) output
-
-  • David Cramer: lists.xsl
-
-    Added <p> element around callouts to avoid misalignment of callout and listitem in xhtml (non-quirks mode) output
-
-  • Mauritz Jeanson: inline.xsl
-
-    Make citations numbered if bibliography.numbered != 0.
-
-  • Robert Stayton: param.xweb; param.ent
-
-    Add support for new profiling attributes audience and wordsize.
-
-  • Robert Stayton: inline.xsl; xref.xsl
-
-    Add support for xlink olinks.
-
-  • Jirka Kosek: glossary.xsl
-
-    Rules for normalizing glossary entries before they are sorted can be now different for each language.
-
-  • Robert Stayton: chunk-common.xsl; chunk-code.xsl; manifest.xsl; chunk.xsl
-
-    Refactored the chunking modules to move all named templates to
-    chunk-common.xsl and all match templates to chunk-code.xsl, in
-    order to enable better chunk customization.
-    See the comments in chunk.xsl for more details.
-
-  • Robert Stayton: lists.xsl
-
-    Add anchor for xml:id for listitem in varlistentry.
-
-  • Robert Stayton: refentry.xsl
-
-    Add support for info/title in refsections for db5.
-
-  • Jirka Kosek: param.xweb; biblio.xsl; docbook.xsl; param.ent;
-    biblio-iso690.xsl
-
-    Added support for formatting biblioentries according to ISO690 citation style.
-    New bibliography style can be turned on by setting parameter bibliography.style to "iso690"
-    The code was provided by Jana Dvorakova
-
-  • Robert Stayton: inline.xsl; xref.xsl
-
-    Add call to class.attribute to <a> output elements so they can
-    have a class value too.
-
-  • Mauritz Jeanson: glossary.xsl
-
-    Fixed bug #1644881:
-    * Added curly braces around all $language attribute values.
-    * Moved declaration of language variable to top level of stylesheet.
-    Tested with Xalan, Saxon, and xsltproc.
-
-Manpages
-
-The following changes have been made to the manpages code since the 1.72.0
-release.
-
-  • Michael(tm) Smith: param.xweb; docbook.xsl; param.ent
-
-    Added the man.authors.section.enabled and
-    man.copyright.section.enabled parameters. Set those to zero when
-    you want to suppress display of the auto-generated AUTHORS and
-    COPYRIGHT sections. Closes request #1467806. Thanks to Daniel
-    Leidert.
-
-  • Michael(tm) Smith: docbook.xsl
-
-    Took the test that the manpages stylesheet does to see if there
-    are any Refentry chilren in current doc, and made it
-    namespace-agnostic. Reason for that is because the test otherwise
-    won't work when it is copied over into the generated
-    profile-docbook.xsl stylesheet.
-
-  • Michael(tm) Smith: Makefile
-
-    Added a manpages/profile-docbook.xsl file to enable single-pass
-    profiling for manpages output.
-
-  • Michael(tm) Smith: info.xsl
-
-    Output copyright and legalnotice in man-page output in whatever
-    place they are in in document order. Closes #1690539. Thanks to
-    Daniel Leidert for reporting.
-
-  • Michael(tm) Smith: docbook.xsl
-
-    Restored support for single-pass namespace stripping to manpages
-    stylesheet.
-
-  • Michael(tm) Smith: synop.xsl; block.xsl; info.xsl; inline.xsl; lists.xsl;
-    endnotes.xsl; ut⋯
-
-    Changed handling of bold and italic/underline output in manpages
-    output. Should be transparent to users, but...
-
-    This touches handling of all bold and italic/underline output. The
-    exact change is that the mode="bold" and mode="italic" utility
-    templates were changed to named templates. (I think maybe I've
-    changed it back and forth from mode to named before, so this is
-    maybe re-reverting it yet again).
-
-    Anyway, the reason for the change is that the templates are
-    sometimes call on dynamically node-sets, and using modes to format
-    those doesn't allow passing info about the current/real context
-    node from the source (not the node-set created by the stylesheet)
-    to that formatting stage.
-
-    The named templates allow the context to be passed in as a
-    parameter, so that the bold/ital formatting template can use
-    context-aware condition checking.
-
-    This was basically necessary in order to suppress bold formatting
-    in titles, which otherwise gets screwed up because of the numbnut
-    way that roff handles nested bold/ital.
-
-    Closes #1674534). Much thanks to Daniel Leidert, whose in his
-    docbook-xsl bug-finding kung-fu has achieved Grand Master status.
-
-  • Michael(tm) Smith: block.xsl
-
-    Fixed handling of example instances by adding the example element
-    to the same template we use for processing figure. Closes
-    #1674538. Thanks to Daniel Leidert.
-
-  • Michael(tm) Smith: utility.xsl
-
-    Don't include lang in manpages filename/pathname if lang=en (that
-    is, only generate lang-qualified file-/pathnames for non-English).
-
-  • Michael(tm) Smith: endnotes.xsl
-
-    In manpages output, emit warnings for notesources (footnote, etc.)
-    that have something other than para as a child.
-
-    The numbered-with-hanging-indent formatting that's used for
-    rendering endnotes in the NOTES section of man pages places some
-    limits/assumptions on how the DocBook source is marked up; namely,
-    for notesources (footnote, annotation, etc.) that can contain
-    block-level children, if the they have a block-level child such as
-    a table or itemizedlist or orderedlist that is the first child of
-    a footnote, we have no way of rendering/indenting its content
-    properly in the endnotes list.
-
-    Thus, the manpages stylesheet not emits a warning message for that
-    case, and suggests the "fix" (which is to wrap the table or
-    itemizedlist or whatever in a para that has some preferatory text.
-
-  • Michael(tm) Smith: utility.xsl
-
-    Added support to mixed-block template for handling tables in
-    mixed-blocks (e.g., as child of para) correctly.
-
-  • Michael(tm) Smith: table.xsl; synop.xsl; block.xsl; info.xsl; lists.xsl;
-    refentry.xsl; end⋯
-
-    Reverted necessary escaping of backslash, dot, and dash
-    out of the well-intentioned (but it now appears,
-    misguided) "marker" mechanism (introduced in the 1.72.0
-    release) -- which made use of alternative "marker"
-    characters as internal representations of those
-    characters, and then replaced them just prior to
-    serialization -- and back into what's basically the
-    system that was used prior to the 1.69.0 release; that
-    is, into a part of stylesheet code that gets executed
-    at the beginning of processing -- before any other roff
-    markup up is. This change obviates the need for the
-    marker system. It also requires a lot less RAM during
-    processing (for large files, the marker mechanism
-    ending up requiring gigabytes of memory).
-
-    Closes bug #1661177. Thanks to Scott Smedley for
-    providing a test case (the fvwm man page) that exposed
-    the problem with the marker mechanism.
-
-    Also moved the mechanism for converting non-breaking
-    spaces back into the same area of the stylesheet code.
-
-  • Michael(tm) Smith: lists.xsl
-
-    Fixed problem with incorrect formatting of nested variablelist.
-    Closes bug #1650931. Thanks to Daniel "Eagle Eye" Leidert.
-
-  • Michael(tm) Smith: lists.xsl
-
-    Make sure that all listitems in itemizedlist and orderedlist are
-    preceded by a blank line. This fixes a regression that occurred
-    when instances of the TP macro that were use in a previous
-    versions of the list-handling code were switched to RS/RE (because
-    TP doesn't support nesting). TP automatically generates a blank
-    line, but RS doesn't. So I added a .sp before each .RS
-
-  • Michael(tm) Smith: block.xsl; inline.xsl; param.xweb; docbook.xsl;
-    links.xsl; param.ent
-
-    Made a number of changes related to elements with
-    out-of-line content:
-
-    - Added handling for mediaobject & inlinemediaobject.
-      Each imagedata, audiodata, or videodata element
-      within a mediaobject or inline mediaobject is now
-      treated as a "notesource" and so handled in much the
-      same way as links and annotation/alt/footnotes.
-
-      That means a numbered marker is generated inline to
-      mark the place in the main flow where the imagedata,
-      audiodata, or videodata element occurs, and a
-      corresponding numbered endnote for it is generated in
-      the endnotes list at the end of the man page; the
-      endnote contains the URL from the fileref attribute
-      of the imagedata, audiodata, or videodata element.
-
-      For mediobject and inlinemediaobject instances that
-      have a textobject child, the textobject is displayed
-      within the main text flow.
-
-    - Renamed several man.link.* params to man.endnotes.*,
-      to reflect that fact that the endnotes list now
-      contains more than just links. Also did similar
-      renaming for a number of stylesheet-internal vars.
-
-    - Added support for xlink:href (along with existing
-      support for the legacy ulink element).
-
-    - Cleaned up and streamlined the endnotes-handling
-      code. It's still messy and klunky and the basic
-      mechanism it uses is very inefficent for documents
-      that contain a lot of notesources, but at least it's
-      a bit better than it was.
-
-Eclipse
-
-The following changes have been made to the eclipse code since the 1.72.0
-release.
-
-  • Mauritz Jeanson: Makefile
-
-    Fixed bug #1715093: Makefile for creating profiled version of eclipse.xsl added.
-
-  • David Cramer: eclipse.xsl
-
-    Added normalize-space around  to avoid leading whitespace from appearing in the output if there's extra leading whitespace (e.g. <title> Foo</title>) in the source
-
-JavaHelp
-
-The following changes have been made to the javahelp code since the 1.72.0
-release.
-
-  • Mauritz Jeanson: javahelp.xsl
-
-    Implemented FR #1230233 (sorted index in javahelp).
-
-  • Mauritz Jeanson: javahelp.xsl
-
-    Added normalize-space() around titles and index entries to work around whitespace problems.
-    Added support for glossary and bibliography in toc and map files.
-
-Roundtrip
-
-The following changes have been made to the roundtrip code since the 1.72.0
-release.
-
-  • Steve Ball: blocks2dbk.xsl; wordml2normalise.xsl; normalise2sections.xsl;
-    sections2blocks.⋯
-
-    new stylesheets for better word processor support and easier maintenance
-
-  • Steve Ball: template-pages.xml; dbk2wp.xsl; sections-spec.xml
-
-    fixed bugs
-
-Params
-
-The following changes have been made to the params code since the 1.72.0
-release.
-
-  • Mauritz Jeanson: htmlhelp.button.back.xml; htmlhelp.button.forward.xml;
-    htmlhelp.button.zo⋯
-
-    Modified refpurpose text.
-
-  • Mauritz Jeanson: htmlhelp.map.file.xml; htmlhelp.force.map.and.alias.xml;
-    htmlhelp.alias.f⋯
-
-    Fixed typos, made some small changes.
-
-  • Mauritz Jeanson: javahelp.encoding.xml
-
-    Moved declaration and documentation of javahelp.encoding from javahelp.xsl to the
-    regular "parameter machinery".
-
-  • Mauritz Jeanson: generate.id.attributes.xml
-
-    Added refpurpose text.
-
-  • Mauritz Jeanson: annotation.js.xml; annotation.graphic.open.xml;
-    annotation.graphic.close.⋯
-
-    Added better refpurpose texts.
-
-  • Michael(tm) Smith: chunker.output.cdata-section-elements.xml;
-    chunker.output.standalone.xm⋯
-
-    Fixed some broken formatting in source files for chunker.* params,
-    as pointed out by Dave Pawson.
-
-  • Michael(tm) Smith: label.from.part.xml
-
-    Changed handling of reference auto-labeling such that reference
-    (when it appears at the component level) is now affected by the
-    label.from.part param, just as preface, chapter, and appendix.
-
-  • Mauritz Jeanson: callout.graphics.extension.xml
-
-    Clarified that 'extension' refers to file names.
-
-  • Michael(tm) Smith: abstract.notitle.enabled.xml
-
-    Added new param abstract.notitle.enabled.
-    If non-zero, in output of the abstract element on titlepages,
-    display of the abstract title is suppressed.
-    Because sometimes you really don't want or need that title
-    there...
-
-  • Michael(tm) Smith: man.string.subst.map.xml
-
-    Updated manpages string-substitute map to reflect fact that
-    because of another recent change to suppress bold markup in .SH
-    output, we no longer need to add a workaround for the accidental
-    uppercasing of roff escapes that occurred previously.
-
-  • Jirka Kosek: margin.note.float.type.xml; title.font.family.xml;
-    table.frame.border.color.x⋯
-
-    Improved parameter metadata
-
-  • Robert Stayton: profile.wordsize.xml; profile.audience.xml
-
-    Add support for profiling on new attributes audience and wordsize.
-
-  • Robert Stayton: callout.graphics.number.limit.xml;
-    callout.graphics.extension.xml
-
-    Added SVG graphics for fo output.
-
-  • Robert Stayton: callout.icon.size.xml
-
-    Set size of callout graphics.
-
-  • Jirka Kosek: default.units.xml; chunker.output.method.xml;
-    toc.list.type.xml; output.inden⋯
-
-    Updated parameter metadata to the new format.
-
-  • Jirka Kosek: man.output.quietly.xml; title.font.family.xml;
-    footnote.sep.leader.properties⋯
-
-    Added type annotations into parameter definition files.
-
-  • Robert Stayton: section.container.element.xml
-
-    Support spans in sections for certain processors.
-
-  • Robert Stayton: component.titlepage.properties.xml
-
-    Empty attribute set for top level component titlepage block.
-    Allows setting a span on title info.
-
-  • Jirka Kosek: bibliography.style.xml
-
-    Added link to WiKi page with description of special markup needed for ISO690 biblioentries
-
-  • Robert Stayton: make.year.ranges.xml
-
-    Clarify that multiple year elements are required.
-
-  • Robert Stayton: id.warnings.xml
-
-    Turn off id.warnings by default.
-
-  • Jirka Kosek: bibliography.style.xml
-
-    Added support for formatting biblioentries according to ISO690 citation style.
-    New bibliography style can be turned on by setting parameter bibliography.style to "iso690"
-    The code was provided by Jana Dvorakova
-
-  • Robert Stayton: header.table.properties.xml; footer.table.properties.xml
-
-    Support adding table properties to header and footer tables.
-
-Highlighting
-
-The following changes have been made to the highlighting code since the 1.72.0
-release.
-
-  • Jirka Kosek: c-hl.xml; xslthl-config.xml
-
-    Added support for C language. Provided by Bruno Guegan.
-
-Profiling
-
-The following changes have been made to the profiling code since the 1.72.0
-release.
-
-  • Robert Stayton: profile-mode.xsl
-
-    Add support for new profiling attributes audience and wordsize.
-
-Lib
-
-The following changes have been made to the lib code since the 1.72.0 release.
-
-  • Michael(tm) Smith: lib.xweb
-
-    Changed name of prepend-pad template to pad-string and twheeked so
-    it can do both right/left padding.
-
-Tools
-
-The following changes have been made to the tools code since the 1.72.0
-release.
-
-  • Michael(tm) Smith: bin; bin/docbook-xsl-update
-
-    Did some cleanup to the install.sh source and added a
-    docbook-xsl-update script to the docbook-xsl distro, the purpose
-    of which is to facilitate easy sync-up to the latest docbook-xsl
-    snapshot (by means of rsync).
-
-XSL-Saxon
-
-The following changes have been made to the xsl-saxon code since the 1.72.0
-release.
-
-  • Mauritz Jeanson: xalan27/src/com/nwalsh/xalan/Verbatim.java; xalan27/src/
-    com/nwalsh/xalan/⋯
-
-    Added modifications so that the new callout.icon.size parameter is taken into account. This
-    parameter is used for FO output (where SVG now is the default graphics format for callouts).
-
-  • Mauritz Jeanson: saxon65/src/com/nwalsh/saxon/FormatCallout.java; xalan27/
-    src/com/nwalsh/x⋯
-
-    Added code for generating id attributes on callouts in HTML and FO output.
-    These patches enable cross-references to callouts placed by area coordinates.
-    It works for graphic, unicode and text callouts.
-    Part of fix for bug #1675513 (xref to area broken).
-
-  • Michael(tm) Smith: saxon65/src/com/nwalsh/saxon/Website.java; xalan27/src/
-    com/nwalsh/xalan⋯
-
-    Copied over Website XSL Java extensions.
-
-XSL-Xalan
-
-The following changes have been made to the xsl-xalan code since the 1.72.0
-release.
-
-  • Michael(tm) Smith: Makefile; xalan2
-
-    Turned off xalan2.jar build. This removes DocBook XSL
-    Java extensions support for versions of Xalan prior to
-    Xalan 2.7. If you are currently using the extensions
-    with an earlier version of Xalan, you need to upgrade
-    to Xalan 2.7.
-
-  • Mauritz Jeanson: xalan27/src/com/nwalsh/xalan/Verbatim.java; xalan27/src/
-    com/nwalsh/xalan/⋯
-
-    Added modifications so that the new callout.icon.size parameter is taken into account. This
-    parameter is used for FO output (where SVG now is the default graphics format for callouts).
-
-  • Mauritz Jeanson: saxon65/src/com/nwalsh/saxon/FormatCallout.java; xalan27/
-    src/com/nwalsh/x⋯
-
-    Added code for generating id attributes on callouts in HTML and FO output.
-    These patches enable cross-references to callouts placed by area coordinates.
-    It works for graphic, unicode and text callouts.
-    Part of fix for bug #1675513 (xref to area broken).
-
-  • Michael(tm) Smith: saxon65/src/com/nwalsh/saxon/Website.java; xalan27/src/
-    com/nwalsh/xalan⋯
-
-    Copied over Website XSL Java extensions.
-
-Release: 1.72.0
-
-This release includes important bug fixes and adds the following significant
-feature changes:
-
-Automatic sorting of glossary entries
-
-    The HTML and FO stylesheets now support automatic sorting of glossary
-    entries. To enable glossary sorting, set the value of the glossary.sort 
-    parameter to 1 (by default, it’s value is 0). When you enable glossary
-    sorting, glossentry elements within a glossary, glossdiv, or glosslist are
-    sorted on the glossterm, using the current language setting. If you don’t
-    enable glossary sorting, then the order of glossentry elements is left “as
-    is” — that is, they are not sorted but are instead just displayed in
-    document order.
-
-WordML renamed to Roundtrip, OpenOffice support added
-
-    Stylesheets for “roundtrip” conversion between documents in OpenOffice
-    format (ODF) and DocBook XML have been added to the set of stylesheets that
-    formerly had the collective title WordML, and that set of stylesheets has
-    been renamed to Roundtrip to better reflect the actual scope and purpose of
-    its contents.
-
-    So the DocBook XSL Stylesheets now support roundtrip conversion (with
-    certain limitations) of WordML, OpenOffice, and Apple Pages documents to
-    and from DocBook XML.
-
-Including QandASet questions in TOCs
-
-    The HTML stylesheet now provides support for including QandASet questions
-    in the document TOC. To enable display of questions in the document TOC,
-    set the value of the qanda.in.toc to 1 (by default, it’s 0). When you
-    enable qanda.in.toc, then the generated table of contents for a document
-    will include qandaset titles, qandadiv titles, and question elements. The
-    default value of zero excludes them from the TOC.
-
-    Note
-
-    The qanda.in.toc parameter does not affect any tables of contents that may
-    be generated within a qandaset or qandadiv (only in the document TOC).
-
-Language identifier in man-page filenames and pathnames
-
-    Added new parameter man.output.lang.in.name.enabled, which controls whether
-    a language identifier is included in man-page filenames and pathnames. It
-    works like this:
-
-    If the value of man.output.lang.in.name.enabled is non-zero, man-page files
-    are output with a language identifier included in their filenames or
-    pathnames as follows:
-
-      □ if man.output.subdirs.enabled is non-zero, each file is output to,
-        e.g., a /$lang/man8/foo.8 pathname
-
-      □ if man.output.subdirs.enabled is zero, each file is output with a
-        foo.$lang.8 filename
-
-index.page.number.properties property set
-
-    For FO output, use the index.page.number.properties to control formatting
-    of page numbers in index output — to (for example) to display page numbers
-    in index output in a different color (to indicate that they are links).
-
-Crop marks in output from Antenna House XSL Formatter
-
-    Support has been added for generating crop marks in print/PDF output
-    generated using Antenna House XSL Formatter
-
-More string-substitution hooks in manpages output
-
-    The man.string.subst.map.local.pre and man.string.subst.map.local.post
-    parameters have been added to enable easier control over custom string
-    substitutions.
-
-Moved verbatim properties to attribute-set
-
-    The hardcoded properties used in verbatim elements (literallayout,
-    programlisting, screen) were moved to the verbatim.properties attribute-set
-    so they can be more easily customized.
-
-enhanced simple.xlink template
-
-    Now the simple.xlink template in inline.xsl works with cross reference
-    elements xref and link as well. Also, more elements call simple.xlink,
-    which enables DB5 xlink functionality.
-
-DocBook 5 compatibility
-
-    Stylesheets now consistently support DocBook 5 attributes (such as xml:id).
-    Also, DocBook 5 info elements are now checked along with other *info
-    elements, and the use of name() function was replaced by local-name() so it
-    also matches on DocBook 5 elements. These changes enable reusing the
-    stylesheets with DocBook 5 documents with minimal fixup.
-
-HTML class attributes now handled in class.attribute mode
-
-    The HTML class attributes were formerly hardcoded to the element name. Now
-    the class attribute is generated by applying templates in class.attribute
-    mode so class attribute names can be customized. The default is still the
-    element name.
-
-arabic-indic numbering enabled in autolabels
-
-    Numbering of chapter, sections, and pages can now use arabic-indic
-    numbering when number format is set to 'arabicindic' or to ١.
-
-The following is a detailed list of changes (not including bug fixes) that have
-been made since the 1.71.1 release.
-
-Common
-
-The following changes have been made to the common code since the 1.71.1
-release.
-
-  • Add support for arabicindic numbering to autolabel.format template.
-
-  • Finish support for @xml:id everywhere @id is used.
-
-  • replace name() with local-name() in most cases.
-
-  • Add support for info.
-
-  • Add utility template tabstyle to return the tabstyle from
-    any table element.
-
-FO
-
-The following changes have been made to the fo code since the 1.71.1 release.
-
-  • Add support for sorting glossary entries
-
-  • Add table.row.properties template to customize table rows.
-
-  • Moved all properties to attribute-sets so can be customized more easily.
-
-  • Add index.page.number.properties attribute-set to format page numbers.
-
-  • xref now supports xlink:href, using simple.xlink template.
-
-  • Rewrote simple.xlink, and call it with all charseq templates.
-
-  • Add simple.xlink processing to term and member elements.
-
-  • Add support for crop marks in Antenna House.
-
-HTML
-
-The following changes have been made to the html code since the 1.71.1 release.
-
-  • Add support for sorting glossary entries
-
-  • Add support for qanda.in.toc to add qandaentry questions to document TOC.
-
-  • add simple.xlink support to variablelist term and simplelist member.
-
-  • *.propagates.style now handled in class.attribute mode.
-
-  • add class parameter to class.attribute mode to set default class.
-
-  • Convert all class attributes to use the class.attribute mode
-    so class names can be customized more easily.
-
-  • Add class.attribute mode to generate class attributes.
-
-  • Added simple.xlink to most remaining inlines.
-    Changed class attributes to applying class.attributes mode.
-
-  • Changed xref template to use simple.xlink tempalte.
-
-  • Improve generate.html.title to work with link targets too.
-
-  • Improved simple.xlink to support link and xref.
-
-  • Use new link.title.attribute now.
-
-  • Rewrote simple.xlink to handle linkend also.
-    Better computation of title attribute on link too.
-
-  • Handle Xalan quirk as special case.
-
-  • Add support for info.
-
-  • Fixed imagemaps so they work properly going from calspair coords
-    to HTML area coords.
-
-Manpages
-
-The following changes have been made to the manpages code since the 1.71.1
-release.
-
-  • Added doc for man.output.lang.in.name.enabled parameter. This
-    checkin completes support for writing file/pathnames for man-pages
-    with $lang include in the names. Closes #1585967. knightly
-    accolades to Daniel Leidert for providing the feature request.
-
-  • Added new param man.output.lang.in.name.enabled, which
-    controls whether $LANG value is included in manpages
-    filenames and pathnames. It works like this:
-
-    If the value of man.output.lang.in.name.enabled is non-zero,
-    man-page files are output with the $lang value included in
-    their filenames or pathnames as follows;
-
-    - if man.output.subdirs.enabled is non-zero, each file is
-      output to, e.g., a /$lang/man8/foo.8 pathname
-
-    - if man.output.subdirs.enabled is zero, each file is output
-      with a foo.$lang.8 filename
-
-  • Use "\e" instead of "\\" for backslash output, because the
-    groff docs say that's the correct thing to do; also because
-    testing (thanks, Paul Dubois) shows that "\\" doesn't always
-    work as expected; for example, "\\" within a table seems to
-    mess things up.
-
-  • Added the man.string.subst.map.local.pre and
-    man.string.subst.map.local.post parameters. Those parameters
-    enable local additions and changes to string-substitution mappings
-    without the need to change the value of man.string.subst.map
-    parameter (which is for standard system mappings). Closes
-    #1456738. Thanks to Sam Steingold for constructing a true
-    stylesheet torture test (the clisp docs) that exposed the need for
-    these params.
-
-  • Added the Markup element to the list of elements that get output
-    in bold. Thanks to Eric S. Raymond.
-
-  • Replaced all dots in roff requests with U+2302 ("house"
-    character), and added escaping in output for all instances of dot
-    that are not in roff requests. This fixes the problem case where a
-    string beginning with a dot (for example, the string ".bashrc")
-    might occur at the beginning of a line in output, in which case 
-    would mistakenly get interpreted as a roff request. Thanks to Eric
-    S. Raymond for pushing to fix this.
-
-  • Made change to ensure that list content nested in
-    itemizedlist and orderedlist instances is properly indented. This
-    is a switch from using .TP to format those lists to using .RS/.RE
-    to format them instead (because .TP does not allow nesting). Closes bug #
-    1602616.
-    Thanks to Daniel Leidert.
-
-Params
-
-The following changes have been made to the params code since the 1.71.1
-release.
-
-  • Added doc for man.output.lang.in.name.enabled parameter. This
-    checkin completes support for writing file/pathnames for man-pages
-    with $lang include in the names. Closes #1585967. knightly
-    accolades to Daniel Leidert for providing the feature request.
-
-  • Added new param man.output.lang.in.name.enabled, which
-    controls whether $LANG value is included in manpages
-    filenames and pathnames. It works like this:
-
-    If the value of man.output.lang.in.name.enabled is non-zero,
-    man-page files are output with the $lang value included in
-    their filenames or pathnames as follows;
-
-    - if man.output.subdirs.enabled is non-zero, each file is
-      output to, e.g., a /$lang/man8/foo.8 pathname
-
-    - if man.output.subdirs.enabled is zero, each file is output
-      with a foo.$lang.8 filename
-
-  • Added the man.string.subst.map.local.pre and
-    man.string.subst.map.local.post parameters. Those parameters
-    enable local additions and changes to string-substitution mappings
-    without the need to change the value of man.string.subst.map
-    parameter (which is for standard system mappings). Closes
-    #1456738. Thanks to Sam Steingold for constructing a true
-    stylesheet torture test (the clisp docs) that exposed the need for
-    these params.
-
-  • Add index.page.number.properties by default.
-
-  • Added index.page.number.properties
-     to allow customizations of page numbers in indexes.
-
-  • Move show-destination="replace" property from template to attribute-set
-    so it can be customized.
-
-  • Add support for sorting glossary entries
-
-  • Add option to include qanda in tables of contents.
-
-  • Moved all properties to attribute-sets so can be customized more easily.
-
-Template
-
-The following changes have been made to the template code since the 1.71.1
-release.
-
-  • Added workaround for Xalan bug: use for-each and copy instead of copy-of (#
-    1604770).
-
-Roundtrip
-
-The following changes have been made to the roundtrip code since the 1.71.1
-release.
-
-  • rename to roundtrip, add OpenOffice support
-
-Release: 1.71.1
-
-This is a minor update to the 1.71.0 release. Along with a number of bug fixes,
-it includes two feature changes:
-
-  • Added support for profiling based on xml:lang and status attributes.
-
-  • Added initial support in manpages output for footnote, annotation, and alt
-    instances. Basically, they all now get handled the same way ulink instances
-    are. They are treated as a class as "note sources": A numbered marker is
-    generated at the place in the main text flow where they occur, then their
-    contents are displayed in an endnotes section at the end of the man page.
-
-Common
-
-The following changes have been made to the common code since the 1.71.1
-release.
-
-  • For backward compatability autoidx-ng.xsl is invoking "kosek" indexing method again.
-
-  • Add support for Xalan generating a root xml:base like saxon.
-
-FO
-
-The following changes have been made to the fo code since the 1.71.1 release.
-
-  • For backward compatability autoidx-ng.xsl is invoking "kosek" indexing method again.
-
-  • Add support for Xalan to add root node xml:base for db5 docs.
-
-  • Added support for profiling based on xml:lang and status attributes.
-
-HTML
-
-The following changes have been made to the html code since the 1.71.1 release.
-
-  • For backward compatability autoidx-ng.xsl is invoking "kosek" indexing method again.
-
-  • Add support for Xalan to add root node xml:base for db5 docs.
-
-  • Added support for profiling based on xml:lang and status attributes.
-
-  • Made changes in namespace declarations to prevent xmllint's
-    canonicalizer from treating them as relative namespace URIs.
-
-      - Changed xmlns:k="java:com.isogen.saxoni18n.Saxoni18nService"
-        to xmlns:k="http://www.isogen.com/functions/
-    com.isogen.saxoni18n.Saxoni18nService";
-        Saxon accepts either form
-        (see http://www.saxonica.com/documentation/extensibility/
-    functions.html);
-        to Saxon, "the part of the URI before the final '/' is immaterial".
-
-      - Changed, e.g. xmlns:xverb="com.nwalsh.xalan.Verbatim" to
-        xmlns:xverb="xalan://com.nwalsh.xalan.Verbatim"; Xalan accepts
-        either form
-        (see http://xml.apache.org/xalan-j/extensions.html#
-    java-namespace-declare);
-        just as Saxon does, it will "simply use the string to the
-        right of the rightmost forward slash as the Java class name".
-
-      - Changed xmlns:xalanredirect="org.apache.xalan.xslt.extensions.Redirect"
-        to xmlns:redirect="http://xml.apache.org/xalan/redirect", and
-        adjusted associated code to make the current Xalan redirect spec.
-        (see http://xml.apache.org/xalan-j/apidocs/org/apache/xalan/lib/
-    Redirect.html)
-
-  • Added the html.append and chunk.append parameters. By default, the
-    value of both is empty; but the internal DocBook XSL stylesheets
-    build sets their value to "<xsl:text>&#x0a;</xsl:text>", in order
-    to ensure that all files in the docbook-xsl-doc package end in a
-    newline character. (Because diff and some other tools may emit
-    error messages and/or not behave as expected when processing
-    files that are not newline-terminated.)
-
-Highlighting
-
-The following changes have been made to the highlighting code since the 1.71.1
-release.
-
-  • Added license information
-
-Manpages
-
-The following changes have been made to the manpages code since the 1.71.1
-release.
-
-  • Added initial support in manpages output for footnote, annotation,
-    and alt instances. Basically, they all now get handled the same
-    way ulink instances are. They are treated as a class as "note
-    sources": A numbered marker is generated at the place in the main
-    text flow where they occur, then their contents are displayed in
-    an endnotes section at the end of the man page (currently titled
-    REFERENCES, for English output, but will be changed to NOTES).
-
-    This support is not yet complete. It works for most "normal"
-    cases, but probably mishandles a good number of cases. More
-    testing will be needed to expose the problems. It may well also
-    introduce some bugs and regressions in other areas, including
-    basic paragraph handling, handling of "mixed block" content,
-    handling of other indented content, and handling of authorblurb
-    and personblurb in the AUTHORS section.
-
-Params
-
-The following changes have been made to the params code since the 1.71.1
-release.
-
-  • Added support for profiling based on xml:lang and status attributes.
-
-  • Added the html.append and chunk.append parameters. By default, the
-    value of both is empty; but the internal DocBook XSL stylesheets
-    build sets their value to "<xsl:text>&#x0a;</xsl:text>", in order
-    to ensure that all files in the docbook-xsl-doc package end in a
-    newline character. (Because diff and some other tools may emit
-    error messages and/or not behave as expected when processing
-    files that are not newline-terminated.)
-
-Profiling
-
-The following changes have been made to the profiling code since the 1.71.1
-release.
-
-  • Added support for profiling based on xml:lang and status attributes.
-
-Release: 1.71.0
-
-This is mainly a bug fix release, but it also includes two significant feature
-changes:
-
-Highlighting support added
-
-    The stylesheets now include support for source-code highlighting in output
-    of programlisting instances (controlled through the highlight.source
-    parameter). The Java-based implementation requires Saxon and makes use of
-    Michal Molhanec’s XSLTHL. More details are available at Jirka Kosek’s
-    website:
-
-        http://xmlguru.cz/2006/07/docbook-syntax-highlighting
-
-    The support is currently limited to highlighting of XML, Java, PHP, Delphi,
-    Modula-2 sources, and INI files.
-
-Changes to autoindexing
-
-    The templates that handle alternative indexing methods were reworked to
-    avoid errors produced by certain processors not being able to tolerate the
-    presence of unused functions. With this release, none of the code for the
-    'kimber' or 'kosek' methods is included in the default stylesheets. In
-    order to use one of those methods, your customization layer must import one
-    of the optional stylesheet modules:
-
-      □ html/autoidx-kosek.xsl
-      □ html/autoidx-kimber.xsl
-      □ fo/autoidx-kosek.xsl
-      □ fo/autoidx-kimber.xsl
-
-    See the index.method parameter reference page for more information.
-
-    Two other changes to note:
-
-      □ The default indexing method now can handle accented characters in
-        latin-based alphabets, not just English. This means accented latin
-        letters will group and sort with their unaccented counterpart.
-      □ The default value for the index.method parameter was changed from
-        'english' to 'basic' because now the default method can handle
-        latin-based alphabets, not just English.
-
-The following is a list of changes that have been made since the 1.70.1
-release.
-
-Common
-
-The following changes have been made to the common code since the 1.70.1
-release.
-
-  • Added reference.autolabel parameter for controlling labels on
-    reference output.
-
-  • Support rows that are *completely* overlapped by the preceding row
-
-  • New modules for supporting indexing extensions.
-
-  • Support startinglinenumber on orderedlist
-
-Extensions
-
-The following changes have been made to the extensions code since the 1.70.1
-release.
-
-  • Completely reworked extensions build system; now uses NetBeans and ant
-
-FO
-
-The following changes have been made to the fo code since the 1.70.1 release.
-
-  • xsl:sort lang attribute now uses two-char substring of lang attribute.
-
-  • Support titlecase "Java", "Perl", and "IDL" as values for the
-    language attribute on classsynopsis, etc. (instead of just
-    lowercase "java", "perl", and "idl"). Also support "c++" and "C++"
-    (instead of just "cpp").
-
-    Affects HTML, FO, and manpages output. Closes bug 1552332. Thanks
-    to "Brian A. Vanderburg II".
-
-  • Added support for the reference.autolabel param in (X)HTML and FO
-    output.
-
-  • Support rows that are *completely* overlapped by the preceding row
-
-  • Rearranged templates for the 3 indexing methods
-    and changed method named 'english' to 'basic'.
-
-  • New modules for supporting indexing extensions.
-
-  • Turn off blank-body for fop1.extensions too since fop 0.92
-    does not support it either.
-
-  • Add Xalan variant to test for exslt:node-set function.
-    Xalan can use function named node-set(), but doesn't
-    recognize it using function-available().
-
-  • Added support to FO stylesheets for handling instances of Org
-    where it occurs outside of *info content. In HTML stylesheets,
-    moved handling of Org out of info.xsl and into inline.xsl. In both
-    FO and HTML stylesheets, added support for correctly processing
-    Affiliation and Jobtitle.
-
-  • Don't output punctuation between Refname and Refpurpose if
-    Refpurpose is empty. Also corrected handling of Refsect2/title
-    instances, and removed some debugging stuff that was generated in
-    manpages output to mark the ends of sections.
-
-  • Added new email.delimiters.enabled param. If non-zero (the
-    default), delimiters are generated around e-mail addresses (output
-    of the email element). If zero, the delimiters are suppressed.
-
-  • Initial support of syntax highlighting of programlistings.
-
-  • Chapter after preface should restart numbering of pages.
-
-HTML
-
-The following changes have been made to the html code since the 1.70.1 release.
-
-  • xsl:sort lang attribute now uses two-char substring of lang attribute.
-
-  • Support titlecase "Java", "Perl", and "IDL" as values for the
-    language attribute on classsynopsis, etc. (instead of just
-    lowercase "java", "perl", and "idl"). Also support "c++" and "C++"
-    (instead of just "cpp").
-
-    Affects HTML, FO, and manpages output. Closes bug 1552332. Thanks
-    to "Brian A. Vanderburg II".
-
-  • Added support for the reference.autolabel param in (X)HTML and FO
-    output.
-
-  • Support rows that are *completely* overlapped by the preceding row
-
-  • Rearranged templates for the 3 indexing methods
-    and changed method named 'english' to 'basic'.
-
-  • New modules for supporting indexing extensions.
-
-  • Added several new HTML parameters for controlling appearance of
-    content on HTML title pages:
-
-    contrib.inline.enabled:
-      If non-zero (the default), output of the contrib element is
-      displayed as inline content rather than as block content.
-
-    othercredit.like.author.enabled:
-      If non-zero, output of the othercredit element on titlepages is
-      displayed in the same style as author and editor output. If zero
-      (the default), othercredit output is displayed using a style
-      different than that of author and editor.
-
-    blurb.on.titlepage.enabled:
-      If non-zero, output from authorblurb and personblurb elements is
-      displayed on title pages. If zero (the default), output from
-      those elements is suppressed on title pages (unless you are
-      using a titlepage customization that causes them to be included).
-
-    editedby.enabled
-      If non-zero (the default), a localized Edited by heading is
-      displayed above editor names in output of the editor element.
-
-  • Add Xalan variant to test for exslt:node-set function.
-    Xalan can use function named node-set(), but doesn't
-    recognize it using function-available().
-
-  • Added support to FO stylesheets for handling instances of Org
-    where it occurs outside of *info content. In HTML stylesheets,
-    moved handling of Org out of info.xsl and into inline.xsl. In both
-    FO and HTML stylesheets, added support for correctly processing
-    Affiliation and Jobtitle.
-
-  • Don't output punctuation between Refname and Refpurpose if
-    Refpurpose is empty. Also corrected handling of Refsect2/title
-    instances, and removed some debugging stuff that was generated in
-    manpages output to mark the ends of sections.
-
-  • Added new email.delimiters.enabled param. If non-zero (the
-    default), delimiters are generated around e-mail addresses (output
-    of the email element). If zero, the delimiters are suppressed.
-
-  • Added qanda.nested.in.toc param. Default value is zero. If
-    non-zero, instances of "nested" Qandaentry (ones that are children
-    of Answer elements) are displayed in the TOC. Closes patch 1509018
-    (from Daniel Leidert). Currently on affects HTML output (no patch
-    for FO output provided).
-
-  • Improved handling of relative locations generated files
-
-  • Initial support of syntax highlighting of programlistings.
-
-  • Support org
-
-  • Support person
-
-  • Support $keep.relative.image.uris also when chunking
-
-Highlighting
-
-The following changes have been made to the highlighting code since the 1.70.1
-release.
-
-  • Initial support of syntax highlighting of programlistings.
-
-Manpages
-
-The following changes have been made to the manpages code since the 1.70.1
-release.
-
-  • Suppress footnote markers and output warning that footnotes are
-    not yet supported.
-
-  • Handle instances of address/otheraddr/ulink in author et al in the
-    same way as email instances; that is, display them on the same
-    linke as the author, editor, etc., name.
-
-  • Don't number or link-list any Ulink instance whose string value is
-    identical to the value of its url attribute. Just display it inline.
-
-  • Don't output punctuation between Refname and Refpurpose if
-    Refpurpose is empty. Also corrected handling of Refsect2/title
-    instances, and removed some debugging stuff that was generated in
-    manpages output to mark the ends of sections.
-
-  • Added new email.delimiters.enabled param. If non-zero (the
-    default), delimiters are generated around e-mail addresses (output
-    of the email element). If zero, the delimiters are suppressed.
-
-  • In manpages output, if the last/nearest *info element for
-    particular Refentry has multiple Copyright and/or Legalnotice
-    children, process them all (not just the first ones). Closes bug
-    1524576. Thanks to Sam Steingold for the report and to Daniel
-    Leidert for providing a patch.
-
-Params
-
-The following changes have been made to the params code since the 1.70.1
-release.
-
-  • Added reference.autolabel parameter for controlling labels on
-    reference output.
-
-  • Added namespace declarations to document elements for all param files.
-
-  • Updated index.method doc to describe revised setup for importing index
-     extensions.
-
-  • Added several new HTML parameters for controlling appearance of
-    content on HTML title pages:
-
-    contrib.inline.enabled:
-      If non-zero (the default), output of the contrib element is
-      displayed as inline content rather than as block content.
-
-    othercredit.like.author.enabled:
-      If non-zero, output of the othercredit element on titlepages is
-      displayed in the same style as author and editor output. If zero
-      (the default), othercredit output is displayed using a style
-      different than that of author and editor.
-
-    blurb.on.titlepage.enabled:
-      If non-zero, output from authorblurb and personblurb elements is
-      displayed on title pages. If zero (the default), output from
-      those elements is suppressed on title pages (unless you are
-      using a titlepage customization that causes them to be included).
-
-    editedby.enabled
-      If non-zero (the default), a localized Edited by heading is
-      displayed above editor names in output of the editor element.
-
-  • Added new email.delimiters.enabled param. If non-zero (the
-    default), delimiters are generated around e-mail addresses (output
-    of the email element). If zero, the delimiters are suppressed.
-
-  • Added qanda.nested.in.toc param. Default value is zero. If
-    non-zero, instances of "nested" Qandaentry (ones that are children
-    of Answer elements) are displayed in the TOC. Closes patch 1509018
-    (from Daniel Leidert). Currently on affects HTML output (no patch
-    for FO output provided).
-
-  • Initial support of syntax highlighting of programlistings.
-
-Tools
-
-The following changes have been made to the tools code since the 1.70.1
-release.
-
-  • Racheted down font sizes of headings in example makefile FO output.
-
-  • Added param and attribute set to example makefile, for getting
-    wrapping in verbatims in FO output.
-
-  • Renamed Makefile.paramDoc to Makefile.docParam.
-
-  • Added Makefile.paramDoc file, for creating versions of param.xsl
-    files with doc embedded.
-
-  • Added variable to example makefile for controlling whether HTML or
-    XHTML is generated.
-
-Release: 1.70.1
-
-This is a stable release of the 1.70 stylesheets. It includes only a few small
-changes from 1.70.0.
-
-The following is a list of changes that have been made since the 1.70.0
-release.
-
-FO
-
-The following changes have been made to the fo code since the 1.70.0 release.
-
-  • Added three new attribute sets (revhistory.title.properties,
-    revhistory.table.properties and revhistory.table.cell.properties) for
-    controlling appearance of revhistory in FO output.
-
-    Modified: fo/block.xsl,1.34; fo/param.ent,1.101; fo/param.xweb,1.114; fo/
-    titlepage.xsl,1.41; params/revhistory.table.cell.properties.xml,1.1; params
-    /revhistory.table.properties.xml,1.1; params/
-    revhistory.title.properties.xml,1.1 - Jirka Kosek
-
-  • Support DBv5 revisions with full author name (not only authorinitials)
-
-    Modified: fo/block.xsl,1.33; fo/titlepage.xsl,1.40 - Jirka Kosek
-
-HTML
-
-The following changes have been made to the html code since the 1.70.0 release.
-
-  • Support DBv5 revisions with full author name (not only authorinitials)
-
-    Modified: html/block.xsl,1.23; html/titlepage.xsl,1.34 - Jirka Kosek
-
-HTMLHelp
-
-The following changes have been made to the htmlhelp code since the 1.70.0
-release.
-
-  • htmlhelp.generate.index is now param, not variable. This means that you can
-    override its setting from outside. This is useful when you generate
-    indexterms on the fly (see http://www.xml.com/pub/a/2004/07/14/dbndx.html?
-    page=3).
-
-    Modified: htmlhelp/htmlhelp-common.xsl,1.38 - Jirka Kosek
-
-  • Support chunk.tocs.and.lots in HTML Help
-
-    Modified: htmlhelp/htmlhelp-common.xsl,1.37 - Jirka Kosek
-
-Params
-
-The following changes have been made to the params code since the 1.70.0
-release.
-
-  • Added three new attribute sets (revhistory.title.properties,
-    revhistory.table.properties and revhistory.table.cell.properties) for
-    controlling appearance of revhistory in FO output.
-
-    Modified: fo/block.xsl,1.34; fo/param.ent,1.101; fo/param.xweb,1.114; fo/
-    titlepage.xsl,1.41; params/revhistory.table.cell.properties.xml,1.1; params
-    /revhistory.table.properties.xml,1.1; params/
-    revhistory.title.properties.xml,1.1 - Jirka Kosek
-
-Release: 1.70.0
-
-As with all DocBook Project dot-zero releases, this is an experimental release.
-It will be followed shortly by a stable release.
-
-This release adds a number of new features, including:
-
-  • support for selecting alternative index-collation methods (in particular,
-    support for using a collation library developed by Eliot Kimber)
-
-  • improved handling of DocBook 5 document instances (through a
-    namespace-stripping mechanism)
-
-  • full support for CALS and HTML tables in manpages output
-
-  • a mechanism for preserving relative URIs in documents that make use of
-    XInclude
-
-  • support for the "new" .90 version of FOP
-
-  • enhanced capabilities for controlling formatting of lists in HTML and FO
-    output
-
-  • autogeneration of AUTHOR and COPYRIGHT sections in manpages output
-
-  • support for generating crop marks in FO/PDF output
-
-  • support for qandaset as a root element in FO output
-
-  • support for floatstyle and orient on all table types
-
-  • support for floatstyle in figure, and example
-
-  • pgwide.properties attribute-set supports extending figure, example and
-    table into the left indent area instead of spanning multiple columns.
-
-The following is a detailed list of enhancements and API changes that have been
-made since the 1.69.1 release.
-
-Common
-
-The following changes have been made to the common code since the 1.69.1
-release.
-
-  • Add the xsl:key for the kimber indexing method.
-
-    Modified: common/autoidx-ng.xsl,1.2 - Robert Stayton
-
-  • Add support for qandaset.
-
-    Modified: common/labels.xsl,1.37; common/subtitles.xsl,1.7; common/
-    titles.xsl,1.35 - Robert Stayton
-
-  • Support dbhtml/dbfo start PI for orderedlist numbering in both HTML and FO
-
-    Modified: common/common.xsl,1.61; html/lists.xsl,1.50 - Norman Walsh
-
-  • Added CVS header.
-
-    Modified: common/stripns.xsl,1.12 - Robert Stayton
-
-  • Changed content model of text element to ANY rather than #PCDATA because
-    they could contain markup.
-
-    Modified: common/targetdatabase.dtd,1.7 - Robert Stayton
-
-  • Added refentry.meta.get.quietly param.
-
-    If zero (the default), notes and warnings about "missing" markup are
-    generated during gathering of refentry metadata. If non-zero, the metadata
-    is gathered "quietly" -- that is, the notes and warnings are suppressed.
-
-    NOTE: If you are processing a large amount of refentry content, you may be
-    able to speed up processing significantly by setting a non-zero value for
-    refentry.meta.get.quietly.
-
-    Modified: common/refentry.xsl,1.17; manpages/param.ent,1.15; manpages/
-    param.xweb,1.17; params/refentry.meta.get.quietly.xml,1.1 - Michael(tm)
-    Smith
-
-  • After namespace stripping, the source document is the temporary tree
-    created by the stripping process and it has the wrong base URI for relative
-    references. Earlier versions of this code used to try to fix that by
-    patching the elements with relative @fileref attributes. That was
-    inadequate because it calculated an absolute base URI without considering
-    that there might be xml:base attributes already in effect. It seems obvious
-    now that the right thing to do is simply to put the xml:base on the root of
-    the document. And that seems to work.
-
-    Modified: common/stripns.xsl,1.7 - Norman Walsh
-
-  • Added support for "software" and "sectdesc" class values on refmiscinfo;
-    "software" is treated identically to "source", and "setdesc" is treated
-    identically to "manual".
-
-    Modified: common/refentry.xsl,1.10; params/
-    man.th.extra2.max.length.xml,1.3; params/
-    refentry.source.name.profile.xml,1.4 - Michael(tm) Smith
-
-  • Added support for DocBook 5 namespace-stripping in manpages stylesheet.
-    Closes request #1210692.
-
-    Modified: common/common.xsl,1.56; manpages/docbook.xsl,1.57 - Michael(tm)
-    Smith
-
-  • Added <xsl:template match="/"> to make stripns.xsl usable as a standalone
-    stylesheet for stripping out DocBook 5/NG to DocBook 4. Note that DocBook
-    XSLT drivers that include this stylesheet all override the match="/"
-    template.
-
-    Modified: common/stripns.xsl,1.4 - Michael(tm) Smith
-
-  • Number figures, examples, and tables from book if there is no prefix (i.e.
-    if chapter.autolabel is set to 0). This avoids having the list of figures
-    where the figures mysteriously restart their numeration periodically when
-    chapter.autolabel is set to 0.
-
-    Modified: common/labels.xsl,1.36 - David Cramer
-
-  • Add task template in title.markup mode.
-
-    Modified: common/titles.xsl,1.34 - Robert Stayton
-
-  • Add children (with ids) of formal objects to target data.
-
-    Modified: common/targets.xsl,1.10 - Robert Stayton
-
-  • Added support for case when personname doesn't contain specific name markup
-    (as allowed in DocBook 5.0)
-
-    Modified: common/common.xsl,1.54 - Jirka Kosek
-
-Extensions
-
-The following changes have been made to the extensions code since the 1.69.1
-release.
-
-  • Support Xalan 2.7
-
-    Modified: extensions/xalan27/.cvsignore,1.1; extensions/xalan27/
-    build.xml,1.1; extensions/xalan27/nbproject/.cvsignore,1.1; extensions/
-    xalan27/nbproject/build-impl.xml,1.1; extensions/xalan27/nbproject/
-    genfiles.properties,1.1; extensions/xalan27/nbproject/
-    project.properties,1.1; extensions/xalan27/nbproject/project.xml,1.1;
-    extensions/xalan27/src/com/nwalsh/xalan/CVS.java,1.1; extensions/xalan27/
-    src/com/nwalsh/xalan/Callout.java,1.1; extensions/xalan27/src/com/nwalsh/
-    xalan/FormatCallout.java,1.1; extensions/xalan27/src/com/nwalsh/xalan/
-    FormatDingbatCallout.java,1.1; extensions/xalan27/src/com/nwalsh/xalan/
-    FormatGraphicCallout.java,1.1; extensions/xalan27/src/com/nwalsh/xalan/
-    FormatTextCallout.java,1.1; extensions/xalan27/src/com/nwalsh/xalan/
-    FormatUnicodeCallout.java,1.1; extensions/xalan27/src/com/nwalsh/xalan/
-    Func.java,1.1; extensions/xalan27/src/com/nwalsh/xalan/
-    ImageIntrinsics.java,1.1; extensions/xalan27/src/com/nwalsh/xalan/
-    Params.java,1.1; extensions/xalan27/src/com/nwalsh/xalan/Table.java,1.1;
-    extensions/xalan27/src/com/nwalsh/xalan/Text.java,1.1; extensions/xalan27/
-    src/com/nwalsh/xalan/Verbatim.java,1.1 - Norman Walsh
-
-  • Handle the case where the imageFn is actually a URI. This still needs work.
-
-    Modified: extensions/saxon643/com/nwalsh/saxon/ImageIntrinsics.java,1.4 -
-    Norman Walsh
-
-FO
-
-The following changes have been made to the fo code since the 1.69.1 release.
-
-  • Adapted to the new indexing code. Now works just like a wrapper that calls
-    kosek indexing method, originally implemented here.
-
-    Modified: fo/autoidx-ng.xsl,1.5 - Jirka Kosek
-
-  • Added parameters for header/footer table minimum height.
-
-    Modified: fo/pagesetup.xsl,1.60; fo/param.ent,1.100; fo/param.xweb,1.113 -
-    Robert Stayton
-
-  • Add the index.method parameter.
-
-    Modified: fo/param.ent,1.99; fo/param.xweb,1.112 - Robert Stayton
-
-  • Integrate support for three indexing methods: - the original English-only
-    method. - Jirka Kosek's method using EXSLT extensions. - Eliot Kimber's
-    method using Saxon extensions. Use the 'index.method' parameter to select.
-
-    Modified: fo/autoidx.xsl,1.38 - Robert Stayton
-
-  • Add support for TOC for qandaset in fo output.
-
-    Modified: fo/autotoc.xsl,1.30; fo/qandaset.xsl,1.20 - Robert Stayton
-
-  • Added parameter ulink.hyphenate.chars. Added parameter insert.link
-    .page.number.
-
-    Modified: fo/param.ent,1.98; fo/param.xweb,1.111 - Robert Stayton
-
-  • Implemented feature request #942524 to add insert.link.page.number to allow
-    link element cross references to have a page number.
-
-    Modified: fo/xref.xsl,1.67 - Robert Stayton
-
-  • Add support for ulink.hyphenate.chars so more characters can be break
-    points in urls.
-
-    Modified: fo/xref.xsl,1.66 - Robert Stayton
-
-  • Implemented patch #1075144 to make the url text in a ulink in FO output an
-    active link as well.
-
-    Modified: fo/xref.xsl,1.65 - Robert Stayton
-
-  • table footnotes now have their own table.footnote.properties attribute set.
-
-    Modified: fo/footnote.xsl,1.23 - Robert Stayton
-
-  • Add qandaset to root.elements.
-
-    Modified: fo/docbook.xsl,1.41 - Robert Stayton
-
-  • Added mode="page.sequence" to make it easier to put content into a page
-    sequence. First used for qandaset.
-
-    Modified: fo/component.xsl,1.37 - Robert Stayton
-
-  • Implemented feature request #1434408 to support formatting of biblioentry.
-
-    Modified: fo/biblio.xsl,1.35 - Robert Stayton
-
-  • Added biblioentry.properties.
-
-    Modified: fo/param.ent,1.97; fo/param.xweb,1.110 - Robert Stayton
-
-  • Support PTC/Arbortext bookmarks
-
-    Modified: fo/docbook.xsl,1.40; fo/ptc.xsl,1.1 - Norman Walsh
-
-  • Added table.footnote.properties to permit table footnotes to format
-    differently from regular footnotes.
-
-    Modified: fo/param.ent,1.96; fo/param.xweb,1.109 - Robert Stayton
-
-  • Refactored table templates to unify their processing and support all
-    options in all types. Now table and informaltable, in both Cals and Html
-    markup, use the same templates where possible, and all support pgwide,
-    rotation, and floats. There is also a placeholder table.container template
-    to support wrapping a table in a layout table, so the XEP table title
-    "continued" extension can be more easily implemented.
-
-    Modified: fo/formal.xsl,1.52; fo/htmltbl.xsl,1.9; fo/table.xsl,1.48 -
-    Robert Stayton
-
-  • Added new attribute set toc.line.properties for controlling appearance of
-    lines in ToC/LoT
-
-    Modified: fo/autotoc.xsl,1.29; fo/param.ent,1.95; fo/param.xweb,1.108 -
-    Jirka Kosek
-
-  • Added support for float to example and equation. Added support for pgwide
-    to figure, example, and equation (the latter two via a dbfo pgwide="1"
-    processing instruction).
-
-    Modified: fo/formal.xsl,1.51 - Robert Stayton
-
-  • Add pgwide.properties attribute-set.
-
-    Modified: fo/param.ent,1.94; fo/param.xweb,1.107 - Robert Stayton
-
-  • Added refclass.suppress param.
-
-    If the value of refclass.suppress is non-zero, then display refclass
-    contents is suppressed in output. Affects HTML and FO output only.
-
-    Modified: fo/param.ent,1.93; fo/param.xweb,1.106; html/param.ent,1.90; html
-    /param.xweb,1.99; params/refclass.suppress.xml,1.1 - Michael(tm) Smith
-
-  • Improved support for task subelements
-
-    Modified: fo/task.xsl,1.3; html/task.xsl,1.3 - Jirka Kosek
-
-  • Adjusted spacing around K&R-formatted Funcdef and Paramdef output such that
-    it can more easily be discerned where one ends and the other begins. Closes
-    #1213264.
-
-    Modified: fo/synop.xsl,1.18 - Michael(tm) Smith
-
-  • Made handling of paramdef/parameter in FO output consistent with that in
-    HTML and manpages output. Closes #1213259.
-
-    Modified: fo/synop.xsl,1.17 - Michael(tm) Smith
-
-  • Made handling of Refnamediv consistent with formatting in HTML and manpages
-    output; specifically, changed so that Refname (comma-separated list of
-    multiple instances found) is used (instead of Refentrytitle as previously),
-    then em-dash, then the Refpurpose. Closes #1212562.
-
-    Modified: fo/refentry.xsl,1.30 - Michael(tm) Smith
-
-  • Added output of Releaseinfo to recto titlepage ("copyright" page) for Book
-    in FO output. This makes it consistent with HTML output. Closes #1327034.
-    Thanks to Paul DuBois for reporting.
-
-    Modified: fo/titlepage.templates.xml,1.28 - Michael(tm) Smith
-
-  • Added condition for setting block-progression-dimension.minimum on
-    table-row, instead of height, when fop1.extensions is non-zero. For an
-    explanation of the reason for the change, see: http://wiki.apache.org/
-    xmlgraphics-fop/Troubleshooting/CommonLogMessages
-
-    Modified: fo/pagesetup.xsl,1.59 - Michael(tm) Smith
-
-  • Added new refclass.suppress param for suppressing display of Refclass in
-    HTML and FO output. Did not add it to manpages because manpages stylesheet
-    is currently just silently ignoring Refclass anyway. Closes request #
-    1461065. Thanks to Davor Ocelic (docelic) for reporting.
-
-    Modified: fo/refentry.xsl,1.29; html/refentry.xsl,1.23 - Michael(tm) Smith
-
-  • Add support for keep-together PI to informal objects.
-
-    Modified: fo/formal.xsl,1.50 - Robert Stayton
-
-  • Add support for fop1.extensions.
-
-    Modified: fo/formal.xsl,1.49; fo/graphics.xsl,1.44; fo/table.xsl,1.47 -
-    Robert Stayton
-
-  • Add support for fop1 bookmarks.
-
-    Modified: fo/docbook.xsl,1.39 - Robert Stayton
-
-  • Add fop1.extentions parameter to add support for fop development version.
-
-    Modified: fo/param.ent,1.92; fo/param.xweb,1.105 - Robert Stayton
-
-  • Start supporting fop development version, which will become fop version 1.
-
-    Modified: fo/fop1.xsl,1.1 - Robert Stayton
-
-  • Add template for task in mode="xref-to".
-
-    Modified: fo/xref.xsl,1.63; html/xref.xsl,1.57 - Robert Stayton
-
-  • table footnotes now also get footnote.properties attribute-set.
-
-    Modified: fo/footnote.xsl,1.22 - Robert Stayton
-
-  • Added index.separator named template to compute the separator punctuation
-    based on locale.
-
-    Modified: fo/autoidx.xsl,1.36 - Robert Stayton
-
-  • Added support for link, olink, and xref within OO Classsynopsis and
-    children. (Because DocBook NG/5 allows it).
-
-    Modified: fo/synop.xsl,1.15; html/synop.xsl,1.19 - Michael(tm) Smith
-
-  • Support date as an inline
-
-    Modified: fo/inline.xsl,1.43; html/inline.xsl,1.46 - Norman Walsh
-
-  • Added new parameter keep.relative.image.uris
-
-    Modified: fo/param.ent,1.91; fo/param.xweb,1.104; html/param.ent,1.87; html
-    /param.xweb,1.96; params/keep.relative.image.uris.xml,1.1 - Norman Walsh
-
-  • Map Unicode space characters U+2000-U+200A to fo:leaders.
-
-    Modified: fo/docbook.xsl,1.38; fo/passivetex.xsl,1.4; fo/spaces.xsl,1.1 -
-    Jirka Kosek
-
-  • Output a real em dash for em-dash dingbat (instead of two hypens).
-
-    Modified: fo/fo.xsl,1.7 - Michael(tm) Smith
-
-  • Support default label width parameters for itemized and ordered lists
-
-    Modified: fo/lists.xsl,1.64; fo/param.ent,1.90; fo/param.xweb,1.103; params
-    /itemizedlist.label.width.xml,1.1; params/orderedlist.label.width.xml,1.1 -
-    Norman Walsh
-
-  • Generate localized title for Refsynopsisdiv if no appropriate Title
-    descendant found in source. Closes #1212398. This change makes behavior for
-    the Synopsis title consistent with the behavior of HTML and manpages
-    output.
-
-    Also, added xsl:use-attribute-sets="normal.para.spacing" to block generated
-    for Cmdsynopsis output. Previously, that block had no spacing at all
-    specified, which resulted it being crammed up to closely to the Synopsis
-    head.
-
-    Modified: fo/refentry.xsl,1.28; fo/synop.xsl,1.13 - Michael(tm) Smith
-
-  • Added parameters to support localization of index item punctuation.
-
-    Modified: fo/autoidx.xsl,1.35 - Robert Stayton
-
-  • Added index.number.separator, index.range.separator, and
-    index.term.separator parameters to support localization of punctuation in
-    index entries.
-
-    Modified: fo/param.ent,1.89; fo/param.xweb,1.102 - Robert Stayton
-
-  • Added "Cross References" section in HTML doc (for consistency with the FO
-    doc). Also, moved the existing FO "Cross References" section to follow the
-    "Linking" section.
-
-    Modified: fo/param.xweb,1.101; html/param.xweb,1.95 - Michael(tm) Smith
-
-  • Added ID attribues to all Reference elements (e.g., id="tables" for the doc
-    for section on Table params). So pages for all subsections of ref docs now
-    have stable filenames instead of arbitrary generated filenames.
-
-    Modified: fo/param.xweb,1.100; html/param.xweb,1.94 - Michael(tm) Smith
-
-  • Added two new parameters for handling of multi-term varlistentry elements:
-
-    variablelist.term.break.after: When the variablelist.term.break.after is
-    non-zero, it will generate a line break after each term multi-term
-    varlistentry.
-
-    variablelist.term.separator: When a varlistentry contains multiple term
-    elements, the string specified in the value of the
-    variablelist.term.separator parameter is placed after each term except the
-    last. The default is ", " (a comma followed by a space). To suppress
-    rendering of the separator, set the value of variablelist.term.separator to
-    the empty string ("").
-
-    These parameters are primarily intended to be useful if you have multi-term
-    varlistentries that have long terms.
-
-    Closes #1306676. Thanks to Sam Steingold for providing an example "lots of
-    long terms" doc that demonstrated the value of having these options.
-
-    Also, added normalize-space() call to processing of each term.
-
-    This change affects all output formats (HTML, PDF, manpages). The default
-    behavior should pretty much remain the same as before, but it is possible
-    (as always) that the change may introduce some new bugginess.
-
-    Modified: fo/lists.xsl,1.62; fo/param.ent,1.88; fo/param.xweb,1.99; html/
-    lists.xsl,1.48; html/param.ent,1.86; html/param.xweb,1.93; manpages/
-    lists.xsl,1.22; manpages/param.ent,1.14; manpages/param.xweb,1.16; params/
-    variablelist.term.break.after.xml,1.1; params/
-    variablelist.term.separator.xml,1.1 - Michael(tm) Smith
-
-  • Add sidebar titlepage placeholder attset for styles.
-
-    Modified: fo/titlepage.xsl,1.37 - Robert Stayton
-
-  • Add titlepage for sidebar.
-
-    Modified: fo/titlepage.templates.xml,1.27 - Robert Stayton
-
-  • Implemented RFE #1292615.
-
-    Added bunch of new parameters (attribute sets) that affect list
-    presentation: list.block.properties, itemizedlist.properties, orderedlist
-    .properties, itemizedlist.label.properties and orderedlist.label
-    .properties. Default behaviour of stylesheets has not been changed but
-    further customizations will be much more easier.
-
-    Modified: fo/lists.xsl,1.61; fo/param.ent,1.87; fo/param.xweb,1.98; params/
-    itemizedlist.label.properties.xml,1.1; params/
-    itemizedlist.properties.xml,1.1; params/list.block.properties.xml,1.1;
-    params/orderedlist.label.properties.xml,1.1; params/
-    orderedlist.properties.xml,1.1 - Jirka Kosek
-
-  • Implemented RFE #1242092.
-
-    You can enable crop marks in your document by setting crop.marks=1 and
-    xep.extensions=1. Appearance of crop marks can be controlled by parameters
-    crop.mark.bleed (6pt), crop.mark.offset (24pt) and crop.mark.width (0.5pt).
-
-    Also there is new named template called user-xep-pis. You can overwrite it
-    in order to produce some PIs that can control XEP as described in http://
-    www.renderx.com/reference.html#Output_Formats
-
-    Modified: fo/docbook.xsl,1.36; fo/param.ent,1.86; fo/param.xweb,1.97; fo/
-    xep.xsl,1.23; params/crop.mark.bleed.xml,1.1; params/
-    crop.mark.offset.xml,1.1; params/crop.mark.width.xml,1.1; params/
-    crop.marks.xml,1.1 - Jirka Kosek
-
-HTML
-
-The following changes have been made to the html code since the 1.69.1 release.
-
-  • implemented index.method parameter and three methods.
-
-    Modified: html/autoidx.xsl,1.28 - Robert Stayton
-
-  • added index.method parameter to support 3 indexing methods.
-
-    Modified: html/param.ent,1.94; html/param.xweb,1.103 - Robert Stayton
-
-  • Implemented feature request #1072510 as a processing instruction to permit
-    including external HTML content into HTML output.
-
-    Modified: html/pi.xsl,1.9 - Robert Stayton
-
-  • Added new parameter chunk.tocs.and.lots.has.title which controls presence
-    of title in a separate chunk with ToC/LoT. Disabling title can be very
-    useful if you are generating frameset output (well, yes those frames, but
-    some customers really want them ;-).
-
-    Modified: html/chunk-code.xsl,1.15; html/param.ent,1.93; html/
-    param.xweb,1.102; params/chunk.tocs.and.lots.has.title.xml,1.1 - Jirka
-    Kosek
-
-  • Support dbhtml/dbfo start PI for orderedlist numbering in both HTML and FO
-
-    Modified: common/common.xsl,1.61; html/lists.xsl,1.50 - Norman Walsh
-
-  • Allow ToC without title also for set and book.
-
-    Modified: html/autotoc.xsl,1.37; html/division.xsl,1.12 - Jirka Kosek
-
-  • Implemented floats uniformly for figure, example, equation and
-    informalfigure, informalexample, and informalequation.
-
-    Modified: html/formal.xsl,1.22 - Robert Stayton
-
-  • Added the autotoc.label.in.hyperlink param.
-
-    If the value of autotoc.label.in.hyperlink is non-zero, labels are included
-    in hyperlinked titles in the TOC. If it is instead zero, labels are still
-    displayed prior to the hyperlinked titles, but are not hyperlinked along
-    with the titles.
-
-    Closes patch #1065868. Thanks to anatoly techtonik for the patch.
-
-    Modified: html/autotoc.xsl,1.36; html/param.ent,1.92; html/
-    param.xweb,1.101; params/autotoc.label.in.hyperlink.xml,1.1 - Michael(tm)
-    Smith
-
-  • Added two new params: html.head.legalnotice.link.types and html.head.
-    legalnotice.link.multiple.
-
-    If the value of the generate.legalnotice.link is non-zero, then the
-    stylesheet generates (in the head section of the HTML source) either a
-    single HTML link element or, if the value of the html.head.legalnotice.link
-    .multiple is non-zero, one link element for each link type specified. Each
-    link has the following attributes:
-
-    - a rel attribute whose value is derived from the value of html.head.
-    legalnotice.link.types
-
-    - an href attribute whose value is set to the URL of the file containing
-    the legalnotice
-
-    - a title attribute whose value is set to the title of the corresponding
-    legalnotice (or a title programatically determined by the stylesheet)
-
-    For example:
-
-    <link rel="copyright" href="ln-id2524073.html" title="Legal Notice">
-
-    Closes #1476450. Thanks to Sam Steingold.
-
-    Modified: html/chunk-common.xsl,1.45; html/param.ent,1.91; html/
-    param.xweb,1.100; params/generate.legalnotice.link.xml,1.4; params/
-    html.head.legalnotice.link.multiple.xml,1.1; params/
-    html.head.legalnotice.link.types.xml,1.1 - Michael(tm) Smith
-
-  • Added refclass.suppress param.
-
-    If the value of refclass.suppress is non-zero, then display refclass
-    contents is suppressed in output. Affects HTML and FO output only.
-
-    Modified: fo/param.ent,1.93; fo/param.xweb,1.106; html/param.ent,1.90; html
-    /param.xweb,1.99; params/refclass.suppress.xml,1.1 - Michael(tm) Smith
-
-  • Improved support for task subelements
-
-    Modified: fo/task.xsl,1.3; html/task.xsl,1.3 - Jirka Kosek
-
-  • Added new refclass.suppress param for suppressing display of Refclass in
-    HTML and FO output. Did not add it to manpages because manpages stylesheet
-    is currently just silently ignoring Refclass anyway. Closes request #
-    1461065. Thanks to Davor Ocelic (docelic) for reporting.
-
-    Modified: fo/refentry.xsl,1.29; html/refentry.xsl,1.23 - Michael(tm) Smith
-
-  • Process alt text with normalize-space(). Replace tab indents with spaces.
-
-    Modified: html/graphics.xsl,1.57 - Robert Stayton
-
-  • Content of citation element is automatically linked to the bibliographic
-    entry with the corresponding abbrev.
-
-    Modified: html/biblio.xsl,1.26; html/inline.xsl,1.47; html/xref.xsl,1.58 -
-    Jirka Kosek
-
-  • Add template for task in mode="xref-to".
-
-    Modified: fo/xref.xsl,1.63; html/xref.xsl,1.57 - Robert Stayton
-
-  • Suppress ID warnings if the .warnings parameter is 0
-
-    Modified: html/html.xsl,1.17 - Norman Walsh
-
-  • Add support for floatstyle to figure.
-
-    Modified: html/formal.xsl,1.21 - Robert Stayton
-
-  • Handling of xref to area/areaset need support in extensions code also. I
-    currently have no time to touch extensions code, so code is here to be
-    enabled when extension is fixed also.
-
-    Modified: html/xref.xsl,1.56 - Jirka Kosek
-
-  • Added 3 parameters for overriding gentext for index punctuation.
-
-    Modified: html/param.ent,1.89; html/param.xweb,1.98 - Robert Stayton
-
-  • Added parameters to support localization of index item punctuation. Added
-    index.separator named template to compute the separator punctuation based
-    on locale.
-
-    Modified: html/autoidx.xsl,1.27 - Robert Stayton
-
-  • Added a <div class="{$class}-contents"> wrapper around output of contents
-    of all formal objects. Also, added an optional <br class="{class}-break"/>
-    linebreak after all formal objects.
-
-    WARNING: Because this change places an additional DIV between the DIV
-    wrapper for the equation and the equation contents, it may break some
-    existing CSS stylesheets that have been created with the assumption that
-    there would never be an intervening DIV there.
-
-    The following is an example of what Equation output looks like as a result
-    of the changes described above.
-
-    <div class="equation"> <a name="three" id="three"></a>
-
-    <p class="title"><b>(1.3)</b></p>
-
-    <div class="equation-contents"> <span class="mathphrase">1+1=3</span> </
-    div> </div><br class="equation-break">
-
-    Rationale: These changes allow CSS control of the placement of the
-    formal-object title relative to the formal-object contents. For example,
-    using the CSS "float" property enables the title and contents to be
-    rendered on the same line. Example stylesheet:
-
-    .equation { margin-top: 20px; margin-bottom: 20px; } .equation-contents {
-    float: left; }
-
-    .equation .title { margin-top: 0; float: right; margin-right: 200px; }
-
-    .equation .title b { font-weight: normal; }
-
-    .equation-break { clear: both; }
-
-    Note that the purpose of the ".equation-break" class is to provide a way to
-    clear off the floats.
-
-    If you want to instead have the equation title rendered to the left of the
-    equation contents, you can do something like this:
-
-    .equation { margin-top: 20px; width: 300px; margin-bottom: 20px; }
-    .equation-contents { float: right; }
-
-    .equation .title { margin-top: 0; float: left; margin-right: 200px; }
-
-    .equation .title b { font-weight: normal; }
-
-    .equation-break { clear: both; }
-
-    Modified: html/formal.xsl,1.20 - Michael(tm) Smith
-
-  • Added a chunker.output.quiet top-level parameter so that the chunker can be
-    made quiet by default
-
-    Modified: html/chunker.xsl,1.26 - Norman Walsh
-
-  • Added support for link, olink, and xref within OO Classsynopsis and
-    children. (Because DocBook NG/5 allows it).
-
-    Modified: fo/synop.xsl,1.15; html/synop.xsl,1.19 - Michael(tm) Smith
-
-  • New parameter: id.warnings. If non-zero, warnings are generated for titled
-    objects that don't have titles. True by default; I wonder if this will be
-    too aggressive?
-
-    Modified: html/biblio.xsl,1.25; html/component.xsl,1.27; html/
-    division.xsl,1.11; html/formal.xsl,1.19; html/glossary.xsl,1.20; html/
-    html.xsl,1.13; html/index.xsl,1.16; html/param.ent,1.88; html/
-    param.xweb,1.97; html/refentry.xsl,1.22; html/sections.xsl,1.30; params/
-    id.warnings.xml,1.1 - Norman Walsh
-
-  • If the keep.relative.image.uris parameter is true, don't use the absolute
-    URI (as calculated from xml:base) in the img src attribute, us the value
-    the author specified. Note that we still have to calculate the absolute
-    filename for use in the image intrinsics extension.
-
-    Modified: html/graphics.xsl,1.56 - Norman Walsh
-
-  • Support date as an inline
-
-    Modified: fo/inline.xsl,1.43; html/inline.xsl,1.46 - Norman Walsh
-
-  • Added new parameter keep.relative.image.uris
-
-    Modified: fo/param.ent,1.91; fo/param.xweb,1.104; html/param.ent,1.87; html
-    /param.xweb,1.96; params/keep.relative.image.uris.xml,1.1 - Norman Walsh
-
-  • Added two new parameters for handling of multi-term varlistentry elements:
-
-    variablelist.term.break.after: When the variablelist.term.break.after is
-    non-zero, it will generate a line break after each term multi-term
-    varlistentry.
-
-    variablelist.term.separator: When a varlistentry contains multiple term
-    elements, the string specified in the value of the
-    variablelist.term.separator parameter is placed after each term except the
-    last. The default is ", " (a comma followed by a space). To suppress
-    rendering of the separator, set the value of variablelist.term.separator to
-    the empty string ("").
-
-    These parameters are primarily intended to be useful if you have multi-term
-    varlistentries that have long terms.
-
-    Closes #1306676. Thanks to Sam Steingold for providing an example "lots of
-    long terms" doc that demonstrated the value of having these options.
-
-    Also, added normalize-space() call to processing of each term.
-
-    This change affects all output formats (HTML, PDF, manpages). The default
-    behavior should pretty much remain the same as before, but it is possible
-    (as always) that the change may introduce some new bugginess.
-
-    Modified: fo/lists.xsl,1.62; fo/param.ent,1.88; fo/param.xweb,1.99; html/
-    lists.xsl,1.48; html/param.ent,1.86; html/param.xweb,1.93; manpages/
-    lists.xsl,1.22; manpages/param.ent,1.14; manpages/param.xweb,1.16; params/
-    variablelist.term.break.after.xml,1.1; params/
-    variablelist.term.separator.xml,1.1 - Michael(tm) Smith
-
-  • Added "wrapper-name" param to inline.charseq named template, enabling it to
-    output inlines other than just "span". Acronym and Abbrev templates now use
-    inline.charseq to output HTML "acronym" and "abbr" elements (instead of
-    "span"). Closes #1305468. Thanks to Sam Steingold for suggesting the
-    change.
-
-    Modified: html/inline.xsl,1.45 - Michael(tm) Smith
-
-Manpages
-
-The following changes have been made to the manpages code since the 1.69.1
-release.
-
-  • Added the following params:
-
-    - man.indent.width (string-valued) - man.indent.refsect (boolean) -
-    man.indent.blurbs (boolean) - man.indent.lists (boolean) -
-    man.indent.verbatims (boolean)
-
-    Note that in earlier snapshots, man.indent.width was named
-    man.indentation.default.value and the boolean params had names like
-    man.indentation.*.adjust. Also the man.indent.blurbs param was called
-    man.indentation.authors.adjust (or something).
-
-    The behavior now is: If the value of a particular man.indent.* boolean
-    param is non-zero, the corresponding contents (refsect*, list items,
-    authorblurb/personblurb, vervatims) are displayed with a left margin
-    indented by a width equal to the value of man.indent.width.
-
-    Modified: params/man.indent.blurbs.xml,1.1; manpages/docbook.xsl,1.74;
-    manpages/info.xsl,1.20; manpages/lists.xsl,1.30; manpages/other.xsl,1.20;
-    manpages/param.ent,1.22; manpages/param.xweb,1.24; manpages/
-    refentry.xsl,1.14; params/man.indent.lists.xml,1.1; params/
-    man.indent.refsect.xml,1.1; params/man.indent.verbatims.xml,1.1; params/
-    man.indent.width.xml,1.1 - Michael(tm) Smith
-
-  • Added man.table.footnotes.divider param.
-
-    In each table that contains footenotes, the string specified by the man.
-    table.footnotes.divider parameter is output before the list of footnotes
-    for the table.
-
-    Modified: manpages/docbook.xsl,1.73; manpages/links.xsl,1.6; manpages/
-    param.ent,1.21; manpages/param.xweb,1.23; params/
-    man.table.footnotes.divider.xml,1.1 - Michael(tm) Smith
-
-  • Added the man.output.in.separate.dir, man.output.base.dir, and
-    man.output.subdirs.enabled parameters.
-
-    The man.output.base.dir parameter specifies the base directory into which
-    man-page files are output. The man.output.subdirs.enabled parameter
-    controls whether the files are output in subdirectories within the base
-    directory.
-
-    The values of the man.output.base.dir and man.output.subdirs.enabled
-    parameters are used only if the value of man.output.in.separate.dir
-    parameter is non-zero. If the value of man.output.in.separate.dir is zero,
-    man-page files are not output in a separate directory.
-
-    Modified: manpages/docbook.xsl,1.72; manpages/param.ent,1.20; manpages/
-    param.xweb,1.22; params/man.output.base.dir.xml,1.1; params/
-    man.output.in.separate.dir.xml,1.1; params/
-    man.output.subdirs.enabled.xml,1.1 - Michael(tm) Smith
-
-  • Added man.font.table.headings and man.font.table.title params, for
-    controlling font in table headings and titles.
-
-    Modified: manpages/docbook.xsl,1.71; manpages/param.ent,1.19; manpages/
-    param.xweb,1.21; params/man.font.table.headings.xml,1.1; params/
-    man.font.table.title.xml,1.1 - Michael(tm) Smith
-
-  • Added man.font.funcsynopsisinfo and man.font.funcprototype params, for
-    specifying the roff font (for example, BI, B, I) for funcsynopsisinfo and
-    funcprototype output.
-
-    Modified: manpages/block.xsl,1.19; manpages/docbook.xsl,1.69; manpages/
-    param.ent,1.18; manpages/param.xweb,1.20; manpages/synop.xsl,1.29; manpages
-    /table.xsl,1.21; params/man.font.funcprototype.xml,1.1; params/
-    man.font.funcsynopsisinfo.xml,1.1 - Michael(tm) Smith
-
-  • Added man.segtitle.suppress param.
-
-    If the value of man.segtitle.suppress is non-zero, then display of segtitle
-    contents is suppressed in output.
-
-    Modified: manpages/docbook.xsl,1.68; manpages/param.ent,1.17; manpages/
-    param.xweb,1.19; params/man.segtitle.suppress.xml,1.1 - Michael(tm) Smith
-
-  • Added man.output.manifest.enabled and man.output.manifest.filename params.
-
-    If man.output.manifest.enabled is non-zero, a list of filenames for man
-    pages generated by the stylesheet transformation is written to the file
-    named by man.output.manifest.filename
-
-    Modified: manpages/docbook.xsl,1.67; manpages/other.xsl,1.19; manpages/
-    param.ent,1.16; manpages/param.xweb,1.18; params/
-    man.output.manifest.enabled.xml,1.1; params/
-    man.output.manifest.filename.xml,1.1; tools/make/Makefile.DocBook,1.4 -
-    Michael(tm) Smith
-
-  • Added refentry.meta.get.quietly param.
-
-    If zero (the default), notes and warnings about "missing" markup are
-    generated during gathering of refentry metadata. If non-zero, the metadata
-    is gathered "quietly" -- that is, the notes and warnings are suppressed.
-
-    NOTE: If you are processing a large amount of refentry content, you may be
-    able to speed up processing significantly by setting a non-zero value for
-    refentry.meta.get.quietly.
-
-    Modified: common/refentry.xsl,1.17; manpages/param.ent,1.15; manpages/
-    param.xweb,1.17; params/refentry.meta.get.quietly.xml,1.1 - Michael(tm)
-    Smith
-
-  • Changed names of all boolean indentation params to man.indent.* Also
-    discarded individual man.indent.*.value params and switched to just using a
-    common man.indent.width param (3n by default).
-
-    Modified: manpages/docbook.xsl,1.66; manpages/info.xsl,1.19; manpages/
-    lists.xsl,1.29; manpages/other.xsl,1.18; manpages/refentry.xsl,1.13 -
-    Michael(tm) Smith
-
-  • Added boolean man.output.in.separate.dir param, to control whether or not
-    man files are output in separate directory.
-
-    Modified: manpages/docbook.xsl,1.65; manpages/utility.xsl,1.14 - Michael
-    (tm) Smith
-
-  • Added options for controlling indentation of verbatim output. Controlled
-    through the man.indentation.verbatims.adjust and
-    man.indentation.verbatims.value params. Closes #1242997
-
-    Modified: manpages/block.xsl,1.15; manpages/docbook.xsl,1.64 - Michael(tm)
-    Smith
-
-  • Added options for controlling indentation in lists and in *blurb output in
-    the AUTHORS section. Controlled through the man.indentation.lists.adjust,
-    man.indentation.lists.value, man.indentation.authors.adjust, and
-    man.indentation.authors.value parameters. Default is 3 characters (instead
-    of the roff default of 8 characters). Closes #1449369.
-
-    Also, removed the indent that was being set on informalexample outuput. I
-    will instead add an option for indenting verbatims, which I think is what
-    the informalexample indent was intended for originally.
-
-    Modified: manpages/block.xsl,1.14; manpages/docbook.xsl,1.63; manpages/
-    info.xsl,1.18; manpages/lists.xsl,1.28 - Michael(tm) Smith
-
-  • Changed line-spacing call before synopfragment to use ".sp -1n" ("n" units
-    specified) instead of plain ".sp -1"
-
-    Modified: manpages/synop.xsl,1.28 - Michael(tm) Smith
-
-  • Added support for writing man files into a specific output directory and
-    into appropriate subdirectories within that output directory. Controlled
-    through the man.base.dir parameter (similar to the base.dir support in the
-    HTML stylesheet) and the man.subdirs.enabled parameter, which automatically
-    determines the name of an appropriate subdir (for example, man/man7, man/
-    man1, etc.) based on the section number/manvolnum of the source Refentry.
-
-    Closes #1255036 and #1170317. Thanks to Denis Bradford for the original
-    feature request, and to Costin Stroie for submitting a patch that was very
-    helpful in implementing the support.
-
-    Modified: manpages/docbook.xsl,1.62; manpages/utility.xsl,1.13 - Michael
-    (tm) Smith
-
-  • Refined XPath statements and notification messages for refentry metadata
-    handling.
-
-    Modified: common/common.xsl,1.59; common/refentry.xsl,1.14; manpages/
-    docbook.xsl,1.61; manpages/other.xsl,1.17 - Michael(tm) Smith
-
-  • Added support for copyright and legalnotice. The manpages stylesheets now
-    output a COPYRIGHT section, after the AUTHORS section, if a copyright or
-    legalnotice is found in the source. The section contains the copyright
-    contents followed by the legalnotice contents. Closes #1450209.
-
-    Modified: manpages/docbook.xsl,1.59; manpages/info.xsl,1.17 - Michael(tm)
-    Smith
-
-  • Drastically reworked all of the XPath expressions used in refentry metadata
-    gathering -- completely removed $parentinfo and turned $info into a set of
-    nodes that includes the *info contents of the Refentry plus the *info
-    contents all all of its ancestor elements. The basic XPath expression now
-    used throughout is (using the example of checking for a date):
-
-    (($info[//date])[last()]/date)[1].
-
-    That selects the "last" *info/date date in document order -- that is, the
-    one eitther on the Refentry itself or on the closest ancestor to the
-    Refentry.
-
-    It's likely this change may break some things; may need to pick up some
-    pieces later.
-
-    Also, changed the default value for the man.th.extra2.max.length from 40 to
-    30.
-
-    Modified: common/common.xsl,1.58; common/refentry.xsl,1.7; params/
-    man.th.extra2.max.length.xml,1.2; params/refentry.date.profile.xml,1.2;
-    params/refentry.manual.profile.xml,1.2; params/
-    refentry.source.name.profile.xml,1.2; params/
-    refentry.version.profile.xml,1.2; manpages/docbook.xsl,1.58; manpages/
-    other.xsl,1.15 - Michael(tm) Smith
-
-  • Added support for DocBook 5 namespace-stripping in manpages stylesheet.
-    Closes request #1210692.
-
-    Modified: common/common.xsl,1.56; manpages/docbook.xsl,1.57 - Michael(tm)
-    Smith
-
-  • Fixed handling of table footnotes. With this checkin, the table support in
-    the manpages stylesheet is now basically feature complete. So this change
-    closes request #619532, "No support for tables" -- the oldest currently
-    open manpages feature request, submitted by Ben Secrest (blsecres) on
-    2002-10-07. Congratulations to me [patting myself on the back].
-
-    Modified: manpages/block.xsl,1.11; manpages/docbook.xsl,1.55; manpages/
-    table.xsl,1.15 - Michael(tm) Smith
-
-  • Added handling for table titles. Also fixed handling of nested tables; nest
-    tables are now "extracted" and displayed just after their parent tables.
-
-    Modified: manpages/docbook.xsl,1.54; manpages/table.xsl,1.14 - Michael(tm)
-    Smith
-
-  • Added option for turning off bold formatting in Funcsynopsis. Boldface
-    formatting in function synopsis is mandated in the man(7) man page and is
-    used almost universally in existing man pages. Despite that, it really does
-    look like crap to have an entire Funcsynopsis output in bold, so I added
-    params for turning off the bold formatting and/or replacing it with a
-    different roff special font (e.g., "RI" for alternating roman/italic
-    instead of the default "BI" for alternating bold/italic). The new params
-    are "man.funcprototype.font" and "man.funcsynopsisinfo.font". To be
-    documented later.
-
-    Closes #1452247. Thanks to Joe Orton for the feature request.
-
-    Modified: params/man.string.subst.map.xml,1.16; manpages/block.xsl,1.10;
-    manpages/docbook.xsl,1.51; manpages/inline.xsl,1.16; manpages/
-    synop.xsl,1.27 - Michael(tm) Smith
-
-  • Use AUTHORS instead of AUTHOR if we have multiple people to attribute.
-    Also, fixed checking such that we generate author section even if we don't
-    have an author (as long as there is at least one other person/entity we can
-    put in the section). Also adjusted assembly of content for Author metainfo
-    field such that we now not only use author, but try to find a "best match"
-    if we can't find an author name to put there.
-
-    Closes #1233592. Thanks to Sam Steingold for the request.
-
-    Modified: manpages/info.xsl,1.12 - Michael(tm) Smith
-
-  • Changes for request #1243027, "Impove handling of AUTHOR section." This
-    adds support for Collab, Corpauthor, Corpcredt, Orgname, Publishername, and
-    Publisher. Also adds support for output of Affiliation and its children,
-    and support for using gentext strings for auto-attributing roles (Author,
-    Editor, Publisher, Translator, etc.). Also did a lot of code cleanup and
-    modularization of all the AUTHOR handling code. And fixed a bug that was
-    causing Author info to not be picked up correctly for metainfo comment we
-    embed in man-page source.
-
-    Modified: manpages/info.xsl,1.11 - Michael(tm) Smith
-
-  • Support bold output for "emphasis remap='B'". (because Eric Raymond's
-    doclifter(1) tool converts groff source marked up with ".B" request or "\
-    fB" escapes to DocBook "emphasis remap='B'".)
-
-    Modified: manpages/inline.xsl,1.14 - Michael(tm) Smith
-
-  • Added support for Segmentedlist. Details: Output is tabular, with no option
-    for "list" type output. Output for Segtitle elements can be supressed by
-    setting man.segtitle.suppress. If Segtitle content is output, it is
-    rendered in italic type (not bold because not all terminals support bold
-    and so italic ensures the stand out on those terminals). Extra space (.sp
-    line) at end of table code ensures that it gets handled correctly in the
-    case where its source is the child of a Para. Closes feature-request #
-    1400097. Thanks to Daniel Leidert for the patch and push, and to Alastair
-    Rankine for filing the original feature request.
-
-    Modified: manpages/lists.xsl,1.23; manpages/utility.xsl,1.10 - Michael(tm)
-    Smith
-
-  • Improved handling or Author/Editor/Othercredit.
-
-    Reworked content of (non-visible) comment added at top of each page
-    (metadata stuff).
-
-    Added support for generating a manifest file (useful for cleaning up after
-    builds, etc.)
-
-    Modified: manpages/docbook.xsl,1.46; manpages/info.xsl,1.9; manpages/
-    other.xsl,1.12; manpages/utility.xsl,1.6 - Michael(tm) Smith
-
-  • Added two new parameters for handling of multi-term varlistentry elements:
-
-    variablelist.term.break.after: When the variablelist.term.break.after is
-    non-zero, it will generate a line break after each term multi-term
-    varlistentry.
-
-    variablelist.term.separator: When a varlistentry contains multiple term
-    elements, the string specified in the value of the
-    variablelist.term.separator parameter is placed after each term except the
-    last. The default is ", " (a comma followed by a space). To suppress
-    rendering of the separator, set the value of variablelist.term.separator to
-    the empty string ("").
-
-    These parameters are primarily intended to be useful if you have multi-term
-    varlistentries that have long terms.
-
-    Closes #1306676. Thanks to Sam Steingold for providing an example "lots of
-    long terms" doc that demonstrated the value of having these options.
-
-    Also, added normalize-space() call to processing of each term.
-
-    This change affects all output formats (HTML, PDF, manpages). The default
-    behavior should pretty much remain the same as before, but it is possible
-    (as always) that the change may introduce some new bugginess.
-
-    Modified: fo/lists.xsl,1.62; fo/param.ent,1.88; fo/param.xweb,1.99; html/
-    lists.xsl,1.48; html/param.ent,1.86; html/param.xweb,1.93; manpages/
-    lists.xsl,1.22; manpages/param.ent,1.14; manpages/param.xweb,1.16; params/
-    variablelist.term.break.after.xml,1.1; params/
-    variablelist.term.separator.xml,1.1 - Michael(tm) Smith
-
-Params
-
-The following changes have been made to the params code since the 1.69.1
-release.
-
-  • New parameters to set header/footer table minimum height.
-
-    Modified: params/footer.table.height.xml,1.1; params/
-    header.table.height.xml,1.1 - Robert Stayton
-
-  • Support multiple indexing methods for different languages.
-
-    Modified: params/index.method.xml,1.1 - Robert Stayton
-
-  • Remove qandaset and qandadiv from generate.toc for fo output because
-    formerly it wasn't working, but now it is and the default behavior should
-    stay the same.
-
-    Modified: params/generate.toc.xml,1.8 - Robert Stayton
-
-  • add support for page number references to link element too.
-
-    Modified: params/insert.link.page.number.xml,1.1 - Robert Stayton
-
-  • Add support for more characters to hyphen on when ulink.hyphenate is turned
-    on.
-
-    Modified: params/ulink.hyphenate.chars.xml,1.1; params/
-    ulink.hyphenate.xml,1.3 - Robert Stayton
-
-  • New attribute-set to format biblioentry and bibliomixed.
-
-    Modified: params/biblioentry.properties.xml,1.1 - Robert Stayton
-
-  • Added new parameter chunk.tocs.and.lots.has.title which controls presence
-    of title in a separate chunk with ToC/LoT. Disabling title can be very
-    useful if you are generating frameset output (well, yes those frames, but
-    some customers really want them ;-).
-
-    Modified: html/chunk-code.xsl,1.15; html/param.ent,1.93; html/
-    param.xweb,1.102; params/chunk.tocs.and.lots.has.title.xml,1.1 - Jirka
-    Kosek
-
-  • Added new attribute set toc.line.properties for controlling appearance of
-    lines in ToC/LoT
-
-    Modified: params/toc.line.properties.xml,1.1 - Jirka Kosek
-
-  • Allow table footnotes to have different properties from regular footnotes.
-
-    Modified: params/table.footnote.properties.xml,1.1 - Robert Stayton
-
-  • Set properties for pgwide="1" objects.
-
-    Modified: params/pgwide.properties.xml,1.1 - Robert Stayton
-
-  • Added the autotoc.label.in.hyperlink param.
-
-    If the value of autotoc.label.in.hyperlink is non-zero, labels are included
-    in hyperlinked titles in the TOC. If it is instead zero, labels are still
-    displayed prior to the hyperlinked titles, but are not hyperlinked along
-    with the titles.
-
-    Closes patch #1065868. Thanks to anatoly techtonik for the patch.
-
-    Modified: html/autotoc.xsl,1.36; html/param.ent,1.92; html/
-    param.xweb,1.101; params/autotoc.label.in.hyperlink.xml,1.1 - Michael(tm)
-    Smith
-
-  • Added two new params: html.head.legalnotice.link.types and html.head.
-    legalnotice.link.multiple.
-
-    If the value of the generate.legalnotice.link is non-zero, then the
-    stylesheet generates (in the head section of the HTML source) either a
-    single HTML link element or, if the value of the html.head.legalnotice.link
-    .multiple is non-zero, one link element for each link type specified. Each
-    link has the following attributes:
-
-    - a rel attribute whose value is derived from the value of html.head.
-    legalnotice.link.types
-
-    - an href attribute whose value is set to the URL of the file containing
-    the legalnotice
-
-    - a title attribute whose value is set to the title of the corresponding
-    legalnotice (or a title programatically determined by the stylesheet)
-
-    For example:
-
-    <link rel="copyright" href="ln-id2524073.html" title="Legal Notice">
-
-    Closes #1476450. Thanks to Sam Steingold.
-
-    Modified: html/chunk-common.xsl,1.45; html/param.ent,1.91; html/
-    param.xweb,1.100; params/generate.legalnotice.link.xml,1.4; params/
-    html.head.legalnotice.link.multiple.xml,1.1; params/
-    html.head.legalnotice.link.types.xml,1.1 - Michael(tm) Smith
-
-  • Added the following params:
-
-    - man.indent.width (string-valued) - man.indent.refsect (boolean) -
-    man.indent.blurbs (boolean) - man.indent.lists (boolean) -
-    man.indent.verbatims (boolean)
-
-    Note that in earlier snapshots, man.indent.width was named
-    man.indentation.default.value and the boolean params had names like
-    man.indentation.*.adjust. Also the man.indent.blurbs param was called
-    man.indentation.authors.adjust (or something).
-
-    The behavior now is: If the value of a particular man.indent.* boolean
-    param is non-zero, the corresponding contents (refsect*, list items,
-    authorblurb/personblurb, vervatims) are displayed with a left margin
-    indented by a width equal to the value of man.indent.width.
-
-    Modified: params/man.indent.blurbs.xml,1.1; manpages/docbook.xsl,1.74;
-    manpages/info.xsl,1.20; manpages/lists.xsl,1.30; manpages/other.xsl,1.20;
-    manpages/param.ent,1.22; manpages/param.xweb,1.24; manpages/
-    refentry.xsl,1.14; params/man.indent.lists.xml,1.1; params/
-    man.indent.refsect.xml,1.1; params/man.indent.verbatims.xml,1.1; params/
-    man.indent.width.xml,1.1 - Michael(tm) Smith
-
-  • Added man.table.footnotes.divider param.
-
-    In each table that contains footenotes, the string specified by the man.
-    table.footnotes.divider parameter is output before the list of footnotes
-    for the table.
-
-    Modified: manpages/docbook.xsl,1.73; manpages/links.xsl,1.6; manpages/
-    param.ent,1.21; manpages/param.xweb,1.23; params/
-    man.table.footnotes.divider.xml,1.1 - Michael(tm) Smith
-
-  • Added the man.output.in.separate.dir, man.output.base.dir, and
-    man.output.subdirs.enabled parameters.
-
-    The man.output.base.dir parameter specifies the base directory into which
-    man-page files are output. The man.output.subdirs.enabled parameter
-    controls whether the files are output in subdirectories within the base
-    directory.
-
-    The values of the man.output.base.dir and man.output.subdirs.enabled
-    parameters are used only if the value of man.output.in.separate.dir
-    parameter is non-zero. If the value of man.output.in.separate.dir is zero,
-    man-page files are not output in a separate directory.
-
-    Modified: manpages/docbook.xsl,1.72; manpages/param.ent,1.20; manpages/
-    param.xweb,1.22; params/man.output.base.dir.xml,1.1; params/
-    man.output.in.separate.dir.xml,1.1; params/
-    man.output.subdirs.enabled.xml,1.1 - Michael(tm) Smith
-
-  • Added man.font.table.headings and man.font.table.title params, for
-    controlling font in table headings and titles.
-
-    Modified: manpages/docbook.xsl,1.71; manpages/param.ent,1.19; manpages/
-    param.xweb,1.21; params/man.font.table.headings.xml,1.1; params/
-    man.font.table.title.xml,1.1 - Michael(tm) Smith
-
-  • Added man.font.funcsynopsisinfo and man.font.funcprototype params, for
-    specifying the roff font (for example, BI, B, I) for funcsynopsisinfo and
-    funcprototype output.
-
-    Modified: manpages/block.xsl,1.19; manpages/docbook.xsl,1.69; manpages/
-    param.ent,1.18; manpages/param.xweb,1.20; manpages/synop.xsl,1.29; manpages
-    /table.xsl,1.21; params/man.font.funcprototype.xml,1.1; params/
-    man.font.funcsynopsisinfo.xml,1.1 - Michael(tm) Smith
-
-  • Changed to select="0" in refclass.suppress (instead of ..>0</..)
-
-    Modified: params/refclass.suppress.xml,1.3 - Michael(tm) Smith
-
-  • Added man.segtitle.suppress param.
-
-    If the value of man.segtitle.suppress is non-zero, then display of segtitle
-    contents is suppressed in output.
-
-    Modified: manpages/docbook.xsl,1.68; manpages/param.ent,1.17; manpages/
-    param.xweb,1.19; params/man.segtitle.suppress.xml,1.1 - Michael(tm) Smith
-
-  • Added man.output.manifest.enabled and man.output.manifest.filename params.
-
-    If man.output.manifest.enabled is non-zero, a list of filenames for man
-    pages generated by the stylesheet transformation is written to the file
-    named by man.output.manifest.filename
-
-    Modified: manpages/docbook.xsl,1.67; manpages/other.xsl,1.19; manpages/
-    param.ent,1.16; manpages/param.xweb,1.18; params/
-    man.output.manifest.enabled.xml,1.1; params/
-    man.output.manifest.filename.xml,1.1; tools/make/Makefile.DocBook,1.4 -
-    Michael(tm) Smith
-
-  • Added refclass.suppress param.
-
-    If the value of refclass.suppress is non-zero, then display refclass
-    contents is suppressed in output. Affects HTML and FO output only.
-
-    Modified: fo/param.ent,1.93; fo/param.xweb,1.106; html/param.ent,1.90; html
-    /param.xweb,1.99; params/refclass.suppress.xml,1.1 - Michael(tm) Smith
-
-  • Added refentry.meta.get.quietly param.
-
-    If zero (the default), notes and warnings about "missing" markup are
-    generated during gathering of refentry metadata. If non-zero, the metadata
-    is gathered "quietly" -- that is, the notes and warnings are suppressed.
-
-    NOTE: If you are processing a large amount of refentry content, you may be
-    able to speed up processing significantly by setting a non-zero value for
-    refentry.meta.get.quietly.
-
-    Modified: common/refentry.xsl,1.17; manpages/param.ent,1.15; manpages/
-    param.xweb,1.17; params/refentry.meta.get.quietly.xml,1.1 - Michael(tm)
-    Smith
-
-  • Added support for "software" and "sectdesc" class values on refmiscinfo;
-    "software" is treated identically to "source", and "setdesc" is treated
-    identically to "manual".
-
-    Modified: common/refentry.xsl,1.10; params/
-    man.th.extra2.max.length.xml,1.3; params/
-    refentry.source.name.profile.xml,1.4 - Michael(tm) Smith
-
-  • Drastically reworked all of the XPath expressions used in refentry metadata
-    gathering -- completely removed $parentinfo and turned $info into a set of
-    nodes that includes the *info contents of the Refentry plus the *info
-    contents all all of its ancestor elements. The basic XPath expression now
-    used throughout is (using the example of checking for a date):
-
-    (($info[//date])[last()]/date)[1].
-
-    That selects the "last" *info/date date in document order -- that is, the
-    one eitther on the Refentry itself or on the closest ancestor to the
-    Refentry.
-
-    It's likely this change may break some things; may need to pick up some
-    pieces later.
-
-    Also, changed the default value for the man.th.extra2.max.length from 40 to
-    30.
-
-    Modified: common/common.xsl,1.58; common/refentry.xsl,1.7; params/
-    man.th.extra2.max.length.xml,1.2; params/refentry.date.profile.xml,1.2;
-    params/refentry.manual.profile.xml,1.2; params/
-    refentry.source.name.profile.xml,1.2; params/
-    refentry.version.profile.xml,1.2; manpages/docbook.xsl,1.58; manpages/
-    other.xsl,1.15 - Michael(tm) Smith
-
-  • Added option for turning off bold formatting in Funcsynopsis. Boldface
-    formatting in function synopsis is mandated in the man(7) man page and is
-    used almost universally in existing man pages. Despite that, it really does
-    look like crap to have an entire Funcsynopsis output in bold, so I added
-    params for turning off the bold formatting and/or replacing it with a
-    different roff special font (e.g., "RI" for alternating roman/italic
-    instead of the default "BI" for alternating bold/italic). The new params
-    are "man.funcprototype.font" and "man.funcsynopsisinfo.font". To be
-    documented later.
-
-    Closes #1452247. Thanks to Joe Orton for the feature request.
-
-    Modified: params/man.string.subst.map.xml,1.16; manpages/block.xsl,1.10;
-    manpages/docbook.xsl,1.51; manpages/inline.xsl,1.16; manpages/
-    synop.xsl,1.27 - Michael(tm) Smith
-
-  • fop.extensions now only for FOP version 0.20.5 and earlier.
-
-    Modified: params/fop.extensions.xml,1.4 - Robert Stayton
-
-  • Support for fop1 different from fop 0.20.5 and earlier.
-
-    Modified: params/fop1.extensions.xml,1.1 - Robert Stayton
-
-  • Reset default value to empty string so template uses gentext first, then
-    the parameter value if not empty.
-
-    Modified: params/index.number.separator.xml,1.2; params/
-    index.range.separator.xml,1.2; params/index.term.separator.xml,1.2 - Robert
-    Stayton
-
-  • New parameter: id.warnings. If non-zero, warnings are generated for titled
-    objects that don't have titles. True by default; I wonder if this will be
-    too aggressive?
-
-    Modified: html/biblio.xsl,1.25; html/component.xsl,1.27; html/
-    division.xsl,1.11; html/formal.xsl,1.19; html/glossary.xsl,1.20; html/
-    html.xsl,1.13; html/index.xsl,1.16; html/param.ent,1.88; html/
-    param.xweb,1.97; html/refentry.xsl,1.22; html/sections.xsl,1.30; params/
-    id.warnings.xml,1.1 - Norman Walsh
-
-  • Added new parameter keep.relative.image.uris
-
-    Modified: fo/param.ent,1.91; fo/param.xweb,1.104; html/param.ent,1.87; html
-    /param.xweb,1.96; params/keep.relative.image.uris.xml,1.1 - Norman Walsh
-
-  • Support default label width parameters for itemized and ordered lists
-
-    Modified: fo/lists.xsl,1.64; fo/param.ent,1.90; fo/param.xweb,1.103; params
-    /itemizedlist.label.width.xml,1.1; params/orderedlist.label.width.xml,1.1 -
-    Norman Walsh
-
-  • Added parameters to localize punctuation in indexes.
-
-    Modified: params/index.number.separator.xml,1.1; params/
-    index.range.separator.xml,1.1; params/index.term.separator.xml,1.1 - Robert
-    Stayton
-
-  • Added two new parameters for handling of multi-term varlistentry elements:
-
-    variablelist.term.break.after: When the variablelist.term.break.after is
-    non-zero, it will generate a line break after each term multi-term
-    varlistentry.
-
-    variablelist.term.separator: When a varlistentry contains multiple term
-    elements, the string specified in the value of the
-    variablelist.term.separator parameter is placed after each term except the
-    last. The default is ", " (a comma followed by a space). To suppress
-    rendering of the separator, set the value of variablelist.term.separator to
-    the empty string ("").
-
-    These parameters are primarily intended to be useful if you have multi-term
-    varlistentries that have long terms.
-
-    Closes #1306676. Thanks to Sam Steingold for providing an example "lots of
-    long terms" doc that demonstrated the value of having these options.
-
-    Also, added normalize-space() call to processing of each term.
-
-    This change affects all output formats (HTML, PDF, manpages). The default
-    behavior should pretty much remain the same as before, but it is possible
-    (as always) that the change may introduce some new bugginess.
-
-    Modified: fo/lists.xsl,1.62; fo/param.ent,1.88; fo/param.xweb,1.99; html/
-    lists.xsl,1.48; html/param.ent,1.86; html/param.xweb,1.93; manpages/
-    lists.xsl,1.22; manpages/param.ent,1.14; manpages/param.xweb,1.16; params/
-    variablelist.term.break.after.xml,1.1; params/
-    variablelist.term.separator.xml,1.1 - Michael(tm) Smith
-
-  • Convert 'no' to string in default value.
-
-    Modified: params/olink.doctitle.xml,1.4 - Robert Stayton
-
-  • Implemented RFE #1292615.
-
-    Added bunch of new parameters (attribute sets) that affect list
-    presentation: list.block.properties, itemizedlist.properties, orderedlist
-    .properties, itemizedlist.label.properties and orderedlist.label
-    .properties. Default behaviour of stylesheets has not been changed but
-    further customizations will be much more easier.
-
-    Modified: fo/lists.xsl,1.61; fo/param.ent,1.87; fo/param.xweb,1.98; params/
-    itemizedlist.label.properties.xml,1.1; params/
-    itemizedlist.properties.xml,1.1; params/list.block.properties.xml,1.1;
-    params/orderedlist.label.properties.xml,1.1; params/
-    orderedlist.properties.xml,1.1 - Jirka Kosek
-
-  • Implemented RFE #1242092.
-
-    You can enable crop marks in your document by setting crop.marks=1 and
-    xep.extensions=1. Appearance of crop marks can be controlled by parameters
-    crop.mark.bleed (6pt), crop.mark.offset (24pt) and crop.mark.width (0.5pt).
-
-    Also there is new named template called user-xep-pis. You can overwrite it
-    in order to produce some PIs that can control XEP as described in http://
-    www.renderx.com/reference.html#Output_Formats
-
-    Modified: fo/docbook.xsl,1.36; fo/param.ent,1.86; fo/param.xweb,1.97; fo/
-    xep.xsl,1.23; params/crop.mark.bleed.xml,1.1; params/
-    crop.mark.offset.xml,1.1; params/crop.mark.width.xml,1.1; params/
-    crop.marks.xml,1.1 - Jirka Kosek
-
-  • Changed short descriptions in doc for *autolabel* params to match new
-    autolabel behavior.
-
-    Modified: params/appendix.autolabel.xml,1.5; params/
-    chapter.autolabel.xml,1.4; params/part.autolabel.xml,1.5; params/
-    preface.autolabel.xml,1.4 - Michael(tm) Smith
-
-Profiling
-
-The following changes have been made to the profiling code since the 1.69.1
-release.
-
-  • Profiling now works together with namespace stripping (V5 documents).
-    Namespace striping should work with all stylesheets named profile-, even if
-    they are not supporting namespace stripping in a non-profiling variant.
-
-    Modified: profiling/profile-mode.xsl,1.4; profiling/xsl2profile.xsl,1.7 -
-    Jirka Kosek
-
-  • Moved profiling stage out of templates. This make possible to reuse
-    profiled content by several templates and still maintaing node indentity
-    (needed for example for HTML Help where content is processed multiple
-    times).
-
-    I don't know why this was not on the top level before. Maybe some XSLT
-    processors choked on it. I hope this will be OK now.
-
-    Modified: profiling/xsl2profile.xsl,1.5 - Jirka Kosek
-
-Tools
-
-The following changes have been made to the tools code since the 1.69.1
-release.
-
-  • Moved Makefile.DocBook from contrib module to xsl module.
-
-    Modified: tools/make/Makefile.DocBook,1.1 - Michael(tm) Smith
-
-WordML
-
-The following changes have been made to the wordml code since the 1.69.1
-release.
-
-  • added contrib element, better handling of default paragraph style
-
-    Modified: wordml/pages-normalise.xsl,1.6; wordml/supported.xml,1.2; wordml/
-    wordml-final.xsl,1.14 - Steve Ball
-
-  • added bridgehead
-
-    Modified: wordml/docbook-pages.xsl,1.6; wordml/docbook.xsl,1.17; wordml/
-    pages-normalise.xsl,1.5; wordml/template-pages.xml,1.7; wordml/
-    template.dot,1.4; wordml/template.xml,1.14; wordml/wordml-final.xsl,1.13 -
-    Steve Ball
-
-  • added blocks stylesheet to support bibliographies, glossaries and qandasets
-
-    Modified: wordml/Makefile,1.4; wordml/README,1.3; wordml/
-    blocks-spec.xml,1.1; wordml/docbook-pages.xsl,1.5; wordml/docbook.xsl,1.16;
-    wordml/pages-normalise.xsl,1.4; wordml/sections-spec.xml,1.3; wordml/
-    specifications.xml,1.13; wordml/template-pages.xml,1.6; wordml/
-    template.dot,1.3; wordml/template.xml,1.13; wordml/wordml-blocks.xsl,1.1;
-    wordml/wordml-final.xsl,1.12; wordml/wordml-sections.xsl,1.3 - Steve Ball
-
-  • added mediaobject caption
-
-    Modified: wordml/docbook-pages.xsl,1.4; wordml/docbook.xsl,1.15; wordml/
-    specifications.xml,1.12; wordml/template-pages.xml,1.5; wordml/
-    template.dot,1.2; wordml/template.xml,1.12; wordml/wordml-final.xsl,1.11 -
-    Steve Ball
-
-  • added callouts
-
-    Modified: wordml/docbook-pages.xsl,1.3; wordml/docbook.xsl,1.14; wordml/
-    pages-normalise.xsl,1.3; wordml/specifications.xml,1.11; wordml/
-    template-pages.xml,1.4; wordml/wordml-final.xsl,1.10 - Steve Ball
-
-  • added Word template file
-
-    Modified: wordml/template.dot,1.1 - Steve Ball
-
-  • added abstract, fixed itemizedlist, ulink
-
-    Modified: wordml/specifications.xml,1.10; wordml/wordml-final.xsl,1.9 -
-    Steve Ball
-
-  • fixed Makefile added many features to Pages support added revhistory,
-    inlines, highlights, abstract
-
-    Modified: wordml/Makefile,1.2; wordml/docbook-pages.xsl,1.2; wordml/
-    pages-normalise.xsl,1.2; wordml/sections-spec.xml,1.2; wordml/
-    specifications.xml,1.9; wordml/template-pages.xml,1.3; wordml/
-    template.xml,1.11; wordml/wordml-final.xsl,1.8; wordml/
-    wordml-sections.xsl,1.2 - Steve Ball
-
-  • fixed handling linebreaks when generating WordML added Apple Pages support
-
-    Modified: wordml/docbook.xsl,1.13; wordml/template-pages.xml,1.2 - Steve
-    Ball
-
-Release 1.69.1
-
-This release is a minor bug-fix update to the 1.69.0 release. Along with bug
-fixes, it includes one configuration-parameter change: The default value of the
-annotation.support parameter is now 0 (off). The reason for that change is that
-there have been reports that annotation handling is causing a significant
-performance degradation in processing of large documents with xsltproc.
-
-Release 1.69.0
-
-The release includes major feature changes, particularly in the manpages
-stylesheets, as well as a large number of bug fixes.
-
-As with all DocBook Project “dot zero” releases, this is an experimental
-release .
-
-Common
-
-  • This release adds localizations for the following languages: Albanian,
-    Amharic, Azerbaijani, Hindi, Irish (Gaelic), Gujarati, Kannada, Mongolian,
-    Oriya, Punjabi, Tagalog, Tamil, and Welsh.
-
-  • Added support for specifying number format for auto labels for chapter,
-    appendix, part, and preface. Contolled with the appendix.autolabel,
-    chapter.autolabel, part.autolabel, and preface.autolabel parameters.
-
-  • Added basic support for biblioref cross referencing.
-
-  • Added support for align on caption in mediaobject.
-
-  • Added support for processing documents that use the DocBook V5 namespace.
-
-  • Added support for termdef and mathphrase.
-
-  • EXPERIMENTAL: Incorporated the Slides and Website stylesheets into the
-    DocBook XSL stylesheets package. So, for example, Website documents can now
-    be processed using the following URI for the driver Website tabular.xsl
-    file:
-
-    http://docbook.sourceforge.net/release/xsl/current/website/tabular.xsl
-
-  • A procedure without a title is now treated as an “informal” procedure
-    (meaning that it is not added to any generated “list of procedures” and has
-    no affect on numbering of generated labels for other procedures).
-
-  • docname is no longer added to olink when pointing to a root element.
-
-  • Added support for generation of choice separator in inline simplelist. This
-    enables auto-generation of an appropriate localized “choice separator” (for
-    example, “and” or “or”) before the final item in an inline simplelist.
-
-    To indicate that you want a choice separator generated for a particular
-    list, you need to put a processing instruction (PI) of the form <?
-    dbchoice choice="foo"?> as a child of the list. For example:
-
-      <para>Choose from
-      ONE and ONLY ONE of the following:
-      <simplelist type="inline">
-      <?dbchoice choice="or" ?>
-      <member>A</member>
-      <member>B</member>
-      <member>C</member>.</simplelist></para>
-
-    Output (for English):
-
-        Choose from ONE and only ONE of the following choices: A, B, or C.
-
-    As a temporary workaround for the fact that most of the DocBook non-English
-    locale files don't have a localization for the word “or”, you can put in a
-    literal string to be used; example for French: <?dbchoice choice="ou">.
-    That is, use “ou” instead of “or”.
-
-FO
-
-  • Added content-type property to external-graphic element, based on imagedata
-    format attribute.
-
-  • Added support for generating <rx:meta-field creator="$VERSION"/> field for
-    XEP output. This makes the DocBook XSL stylesheet version information
-    available through the Document Properties menu in Acrobat Reader and other
-    PDF viewers.
-
-  • Trademark symbol handling made consistent with handling of same in HTML
-    stylesheets. Prior to this change, if you processed a document that
-    contained no value for the class attribute on the trademark element, the
-    HTML stylesheets would default to rendering a superscript TM symbol after
-    the trademark contents, but the FO stylesheets would render nothing.
-
-  • Added support for generating XEP bookmarks for refentry.
-
-  • Added support for HTML markup table border attribute, applied to each table
-    cell.
-
-  • The table.width template can now sum column specs if none use % or *.
-
-  • Added fox:destination extension inside fox:outline to support linking to
-    internal destinations.
-
-  • Added support for customizing abstract with property sets. Controlled with
-    the abstract.properties and abstract.title.properties parameters.
-
-  • Add footnotes in table title to table footnote set, and add support for
-    table footnotes to HTML table markup.
-
-  • Added support for title in glosslist.
-
-  • Added support for itemizedlist symbol none.
-
-  • Implemented the new graphical.admonition.properties and
-    nongraphical.admonition.properties attribute sets.
-
-  • Added id to formalpara and some other blocks that were missing it.
-
-  • Changed the anchor template to output fo:inline instead of fo:wrapper.
-
-  • Added support for toc.max.depth parameter.
-
-Help
-
-  • Eclipse Help: Added support for generating olink database.
-
-HTML
-
-  • Added a first cut at support in HTML output for DocBook 5 style annotation
-    s. Controlled using the annotation.support parameter, and implemented using
-    JavaScript and CSS styling. For more details, see the documentation for the
-    annotation.js, annotation.css, annotation.graphic.open, and
-    annotation.graphic.close parameters.
-
-  • Generate client-side image map for imageobjectco with areas using calspair
-    units
-
-  • Added support for <?img.src.path?> PI.
-
-  • Added support for passing img.src.path to DocBook Java XSLT image
-    extensions when appropriate. Controlled using the
-    graphicsize.use.img.src.path parameter.
-
-  • Added support for (not valid for DocBook 4) xlink:href on area and (not
-    valid for DocBook 4) alt in area.
-
-  • Added new parameter default.table.frame to control table framing if there
-    is no frame attribute on a table.
-
-  • Added initial, experimental support for generating content for the HTML
-    title attribute from content of the alt element. This change adds support
-    for the following inline elements only (none of them are block elements):
-    abbrev, accel, acronym, action, application, authorinitials, beginpage,
-    citation, citerefentry, citetitle, city, classname, code, command,
-    computeroutput, constant, country, database, email, envar, errorcode,
-    errorname, errortext, errortype, exceptionname, fax, filename, firstname,
-    firstterm, foreignphrase, function, glossterm, guibutton, guiicon, guilabel
-    , guimenu, guimenuitem, guisubmenu, hardware, honorific, interface,
-    interfacename, keycap, keycode, keysym, lineage, lineannotation, literal,
-    markup, medialabel, methodname, mousebutton, option, optional, otheraddr,
-    othername, package, parameter, personname, phone, pob, postcode,
-    productname, productnumber, prompt, property, quote, refentrytitle, remark,
-    replaceable, returnvalue, tag, shortcut, state, street, structfield,
-    structname, subscript, superscript, surname, symbol, systemitem, tag,
-    termdef, token, trademark, type, uri, userinput, varname, and wordasword
-
-  • Added support for chunking revhistory into separate file (similar to the
-    support for doing same with legalnotice). Patch from Thomas Schraitle.
-    Controlled through new generate.revhistory.link parameter.
-
-  • l10n.xsl: Made language codes RFC compliant. Added a new boolean config
-    parameter, l10n.lang.value.rfc.compliant. If it is non-zero (the default),
-    any underscore in a language code will be converted to a hyphen in HTML
-    output. If it is zero, the language code will be left as-is.
-
-man
-
-This release closes out 44 manpages stylesheet bug reports and feature
-requests. It adds more than 35 new configuration parameters for controlling
-aspects of man-page output -- including hyphenation and justification, handling
-of links, conversion of Unicode characters, and contents of man-page headers
-and footers.
-
-  • New options for globally disabling/enabling hyphenation and justification:
-    man.justify and man.hyphenate.
-
-    Note that the default for the both of those is zero (off), because
-    justified text looks good only when it is also hyphenated; to quote the
-    “Hyphenation” node from the groff info page:
-
-        Since the odds are not great for finding a set of words, for every
-        output line, which fit nicely on a line without inserting excessive
-        amounts of space between words, `gtroff' hyphenates words so that it
-        can justify lines without inserting too much space between words.
-
-    The problem is that groff can end up hyphenating a lot of things that you
-    don't want hyphenated (variable names and command names, for example).
-    Keeping both justification and hyphenation disabled ensures that hyphens
-    won't get inserted where you don't want to them, and you don't end up with
-    lines containing excessive amounts of space between words. These default
-    settings run counter to how most existing man pages are formatted. But
-    there are some notable exceptions, such as the perl man pages.
-
-  • Added parameters for controlling hyphenation of computer inlines,
-    filenames, and URLs. By default, even when hyphenation is enabled
-    (globally), hyphenation is now suppressed for "computer inlines"
-    (currently, just classname, constant, envar, errorcode, option, replaceable
-    , userinput, type, and varname, and for filenames, and for URLs from link.
-    It can be (re)enabled using the man.hyphenate.computer.inlines,
-    man.hyphenate.filenames, and man.hyphenate.urls parameters.
-
-  • Implemented a new system for replacing Unicode characters. There are two
-    parts to the new system: a “string substitution map” for doing “essential”
-    replacements, and a “character map” that can optionally be disabled and
-    enabled.
-
-    The new system fixes all open bugs that had to do with literal Unicode
-    numbered entities such as &#8220; and &#8221; showing up in output, and
-    greatly expands the ability of the stylesheets to generate “good” roff
-    equivalents for Unicode symbols and special characters.
-
-    Here are some details...
-
-    The previous manpages mechanism for replacing Unicode symbols and special
-    characters with roff equivalents (the replace-entities template) was not
-    scalable and not complete. The mechanism handled a somewhat arbitrary
-    selection of less than 20 or so Unicode characters. But there are
-    potentially more than 800 Unicode special characters that have some groff
-    equivalent they can be mapped to. And there are about 34 symbols in the
-    Latin-1 (ISO-8859-1) block alone. Users might reasonably expect that if
-    they include any of those Latin-1 characters in their DocBook source
-    documents, they will get correctly converted to known roff equivalents in
-    output.
-
-    In addition to those common symbols, certain users may have a need to use
-    symbols from other Unicode blocks. Say, somebody who is documenting an
-    application related to math might need to use a bunch of symbols from the
-    “Mathematical Operators” Unicode block (there are about 65 characters in
-    that block that have reasonable roff equivalents). Or somebody else might
-    really like Dingbats -- such as the checkmark character -- and so might use
-    a bunch of things from the “Dingbat” block (141 characters in that that
-    have roff equivalents or that can at least be “degraded” somewhat
-    gracefully into roff).
-
-    So, the old replace-entities mechanism was replaced with a completely
-    different mechanism that is based on use of two “maps”: a “substitution
-    map” and a “character map” (the latter in a format compliant with the XSLT
-    2.0 spec and therefore completely “forward compatible” with XSLT 2.0).
-
-    The substitution map is controlled through the man.string.subst.map
-    parameter, and is used to replace things like the backslash character
-    (which needs special handling to prevent it from being interpreted as a
-    roff escape). The substitution map cannot be disabled, because disabling it
-    will cause the output to be broken. However, you can add to it and change
-    it if needed.
-
-    The “character map” mechanism, on the other hand, can be completely
-    disabled. It is enabled by default, and, by default, does replacement of
-    all Latin-1 symbols, along with most special spaces, dashes, and quotes
-    (about 75 characters by default). Also, you can optionally enable a “full”
-    character map that provides support for converting all 800 or so of the
-    characters that have some reasonable groff equivalent.
-
-    The character-map mechanism is controlled through the following parameters:
-
-    man.charmap.enabled
-
-        turns character-map support on/off
-
-    man.charmap.use.subset
-
-        specifies that a subset of the character map is used instead of the
-        full map
-
-    man.charmap.subset.profile
-
-        specifies profile of character-map subset
-
-    man.charmap.uri
-
-        specifies an alternate character map to use instead of the “standard”
-        character map provided in the distribution
-
-  • Implemented out-of-line handling of display of URLs for links (currently,
-    only for ulink). This gives you three choices for handling of links:
-
-     1. Number and list links. Each link is numbered inline, with a number in
-        square brackets preceding the link contents, and a numbered list of all
-        links is added to the end of the document.
-
-     2. Only list links. Links are not numbered, but an (unnumbered) list of
-        links is added to the end of the document.
-
-     3. Suppress links. Don't number links and don't add any list of links to
-        the end of the document.
-
-    You can also choose whether links should be underlined. The default is “the
-    works” -- list, number, and underline links. You can use the
-    man.links.list.enabled, man.links.are.numbered, and
-    man.links.are.underlined parameters to change the defaults. The default
-    heading for the link list is REFERENCES. You can be change that using the
-    man.links.list.heading parameter.
-
-  • Changed default output encoding to UTF-8. This does not mean that man pages
-    are output in raw UTF-8, because the character map is applied before final
-    output, causing all UTF-8 characters covered in the map to be converted to
-    roff equivalents.
-
-  • Added support for processing refsect3 and formalpara and nested refsection
-    elements, down to any arbitrary level of nesting.
-
-  • Output of the NAME and SYNOPSIS and AUTHOR headings and the headings for
-    admonitions (note, caution, etc.) are no longer hard-coded for English.
-    Instead, headings are generated for those in the correct locale (just as
-    the FO and HTML stylesheets do).
-
-  • Re-worked mechanism for assembling page headers/footers (the contents of
-    the .TH macro “title line”).
-
-    Here are some details...
-
-    All man pages contain a .TH roff macro whose contents are used for
-    rendering the “title line” displayed in the header and footer of each page.
-    Here are a couple of examples of real-world man pages that have useful page
-    headers/footers:
-
-      gtk-options(7)    GTK+ User's Manual   gtk-options(7) <-- header
-      GTK+ 1.2              2003-10-20       gtk-options(7) <-- footer
-
-      svgalib(7)       Svgalib User Manual       svgalib(7) <-- header
-      Svgalib 1.4.1      16 December 1999        svgalib(7) <-- footer
-
-    And here are the terms with which the groff_man(7) man page refers to the
-    various parts of the header/footer:
-
-      title(section)  extra3  title(section)  <- header
-      extra2          extra1  title(section)  <- footer
-
-    Or, using the names with which the man(7) man page refers to those same
-    fields:
-
-      title(section)  manual  title(section)  <- page header
-      source          date    title(section)  <- page footer
-
-    The easiest way to control the contents of those fields is to mark up your
-    refentry content like the following (note that this is a “minimal”
-    example).
-
-      <refentry>
-        <info>
-          <date>2003-10-20</date> 1
-        </info>
-        <refmeta>
-          <refentrytitle>gtk-options</refentrytitle> 2
-          <manvolnum>7</manvolnum> 3
-          <refmiscinfo class="source-name">GTK+</refmiscinfo> 4
-          <refmiscinfo class="version">1.2</refmiscinfo> 5
-          <refmiscinfo class="manual">GTK+ User's Manual</refmiscinfo> 6
-        </refmeta>
-        <refnamediv>
-          <refname>gtk-options</refname>
-          <refpurpose>Standard Command Line Options for GTK+ Programs</refpurpose>
-        </refnamediv>
-        <refsect1>
-          <title>Description</title>
-          <para>This manual page describes the command line options, which
-          are common to all GTK+ based applications.</para>
-        </refsect1>
-      </refentry>
-
-    1  Sets the “date” part of the header/footer.
-
-    2  Sets the “title” part.
-
-    3  Sets the “section” part.
-
-    4  Sets the “source name” part.
-
-    5  Sets the “version” part.
-
-    6  Sets the “manual” part.
-
-    Below are explanations of the steps the stylesheets take to attempt to
-    assemble and display “good” headers and footer. [In the descriptions, note
-    that *info is the refentry “info” child (whatever its name), and parentinfo
-    is the “info” child of its parent (again, whatever its name).]
-
-    extra1 field (date)
-
-        Content of the “extra1” field is what shows up in the center footer
-        position of each page. The man(7) man page describes it as “the date of
-        the last revision”.
-
-        To provide this content, if the refentry.date.profile.enabled is
-        non-zero, the stylesheets check the value of refentry.date.profile.
-
-        Otherwise, by default, they check for a date or pubdate not only in the
-        *info contents, but also in the parentinfo contents.
-
-        If a date cannot be found, the stylesheets now automatically generate a
-        localized “long format” date, ensuring that this field always has
-        content in output.
-
-        However, if for some reason you want to suppress this field, you can do
-        so by setting a non-zero value for man.th.extra1.suppress.
-
-    extra2 field (source)
-
-        On Linux systems and on systems with a modern groff, the content of the
-        “extra2” field are what shows up in the left footer position of each
-        page.
-
-        The man(7) man page describes this as “the source of the command”, and
-        provides the following examples:
-
-          ☆ For binaries, use somwething like: GNU, NET-2, SLS Distribution,
-            MCC Distribution.
-
-          ☆ For system calls, use the version of the kernel that you are
-            currently looking at: Linux 0.99.11.
-
-          ☆ For library calls, use the source of the function: GNU, BSD 4.3,
-            Linux DLL 4.4.1.
-
-        In practice, there are many pages that simply have a version number in
-        the “source” field. So, it looks like what we have is a two-part field,
-        Name Version, where:
-
-        Name
-
-            product name (e.g., BSD) or org. name (e.g., GNU)
-
-        Version
-
-            version name
-
-        Each part is optional. If the Name is a product name, then the Version
-        is probably the version of the product. Or there may be no Name, in
-        which case, if there is a Version, it is probably the version of the
-        item itself, not the product it is part of. Or, if the Name is an
-        organization name, then there probably will be no Version.
-
-        To provide this content, if the refentry.source.name.profile.enabled
-        and refentry.version.profile.enabled parameter are non-zero, the
-        stylesheets check the value of refentry.source.name.profile
-        refentry.version.profile.
-
-        Otherwise, by default, they check the following places, in the
-        following order:
-
-         1. *info/productnumber
-
-         2. *info/productnumber
-
-         3. refmeta/refmiscinfo[@class = 'version']
-
-         4. parentinfo/productnumber
-
-         5. *info/productname
-
-         6. parentinfo/productname
-
-         7. refmeta/refmiscinfo
-
-         8. [nothing found, so leave it empty]
-
-    extra3 field
-
-        On Linux systems and on systems with a modern groff, the content of the
-        “extra3” field are what shows up in the center header position of each
-        page. Some man pages have “extra2” content, some don't. If a particular
-        man page has it, it is most often “context” data about some larger
-        system the documented item belongs to (for example, the name or
-        description of a group of related applications). The stylesheets now
-        check the following places, in the following order, to look for content
-        to add to the “extra3” field.
-
-         1. parentinfo/title
-
-         2. parent's title
-
-         3. refmeta/refmiscinfo
-
-         4. [nothing found, so leave it empty]
-
-  • Reworked *info gathering. For each refentry found, the stylesheets now
-    cache its *info content, then check for any valid parent of it that might
-    have metainfo content and cache that, if found; they then then do all
-    further matches against those node-sets (rather than re-selecting the
-    original *info nodes each time they are needed).
-
-  • New option for breaking strings after forward slashes. This enables long
-    URLs and pathnames to be broken across lines. Controlled through
-    man.break.after.slash parameter.
-
-  • Output for servicemark and trademark are now (SM) and (TM). There is a
-    groff "\(tm" escape, but output from that is not acceptable.
-
-  • New option for controlling the length of the title part of the .TH title
-    line. Controlled through the man.th.title.max.length parameter.
-
-  • New option for specifying output encoding of each man page; controlled with
-    man.output.encoding (similar to the HTML chunker.output.encoding 
-    parameter).
-
-  • New option for suppressing filename messages when generating output;
-    controlled with man.output.quietly (similar to the HTML chunk.quietly
-    parameter).
-
-  • The text of cross-references to first-level refentry (refsect1, top-level
-    refsection, refnamediv, and refsynopsisdiv) are now capitalized.
-
-  • Cross-references to refnamediv now use the localized NAME title instead of
-    using the first refname child. This makes the output inconsistent with HTML
-    and FO output, but for man-page output, it seems to make better sense to
-    have the NAME. (It may actually make better sense to do it that way in HTML
-    and FO output as well...)
-
-  • Added support for processing funcparams.
-
-  • Removed the space that was being output between funcdef and paramdef;
-    example: was: float rand (void); now: float rand(void)
-
-  • Turned off bold formatting for the type element when it occurs within a
-    funcdef or paramdef
-
-  • Corrected rendering of simplelist. Any <simplelist type="inline" instance
-    is now rendered as a comma-separated list (also with an optional localized
-    “and” or “or” before the last item -- see description elsewhere in these
-    release notes). Any simplelist instance whose type is not inline is
-    rendered as a one-column vertical list (ignoring the values of the type and
-    columns attributes if present)
-
-  • Comment added at top of roff source for each page now includes DocBook XSL
-    stylesheets version number (as in the HTML stylesheets)
-
-  • Made change to prevent “sticky” fonts changes. Now, when the manpages
-    stylesheets encounter node sets that need to be boldfaced or italicized,
-    they put the \fBfoo\fR and \fIbar\fR groff bold/italic instructions
-    separately around each node in the set.
-
-  • synop.xsl: Boldface everything in funcsynopsis output except parameters
-    (which are in ital). The man(7) man page says:
-
-        For functions, the arguments are always specified using italics, even
-        in the SYNOPSIS section, where the rest of the function is specified in
-        bold.
-
-    A look through the contents of the man/man2 directory shows that most (all)
-    existing pages do follow this “everything in funcsynopsis bold” rule. That
-    means the type content and any punctuation (parens, semicolons, varargs)
-    also must be bolded.
-
-  • Removed code for adding backslashes before periods/dots in roff source,
-    because backslashes in front of periods/dots in roff source are needed only
-    in the very rare case where a period is the very first character in a line,
-    without any space in front of it. A better way to deal with that rare case
-    is for you to add a zero-width space in front of the offending dot(s) in
-    your source
-
-  • Removed special handling of the quote element. That was hard-coded to cause
-    anything marked up with the quote element to be output preceded by two
-    backticks and followed by two apostrophes -- that is, that old-school
-    kludge for generating “curly” quotes in Emacs and in X-Windows fonts. While
-    Emacs still seems to support that, I don't think X-Windows has for a long
-    time now. And, anyway, it looks (and has always looked) like crap when
-    viewed on a normal tty/console. In addition, it breaks localiztion of quote
-    . By default, quote content is output with localized quotation marks,
-    which, depending on the locale, may or may not be left and right double
-    quotation marks.
-
-  • Changed mappings for left and right single quotation marks. Those had
-    previously been incorrectly mapped to the backtick (&#96;) and apostrophe
-    (&39;) characters (for kludgy reasons -- see above). They are now correctly
-    mapped to the \(oq and \(cq roff escapes. If you want the old (broken)
-    behavior, you need to manually change the mappings for those in the value
-    of the man.string.subst.map parameter.
-
-  • Removed xref.xsl file. Now, of the various cross-reference elements, only
-    the ulink element is handled differently; the rest are handled exactly as
-    the HTML stylesheets handle them, except that no hypertext links are
-    generated. (Because there is no equivalent hypertext mechanism is man
-    pages.)
-
-  • New option for making “subheading dividers” in generated roff source. The
-    dividers are not visible in the rendered man page; they are just there to
-    make the source readable. Controlled using man.subheading.divider.
-
-  • Fixed many places where too much space was being added between lines.
-
-Release 1.68.1
-
-The release adds localization support for Farsi (thanks to Sina Heshmati) and
-improved support for the XLink-based DocBook NG db:link element. Other than
-that, it is a minor bug-fix update to the 1.68.0 release. The main thing it
-fixes is a build error that caused the XSLT Java extensions to be jarred up
-with the wrong package structure. Thanks to Jens Stavnstrup for quickly
-reporting the problem, and to Mauritz Jeanson for investigating and finding the
-cause.
-
-Release 1.68.0
-
-This release includes some features changes, particularly for FO/PDF output,
-and a number of bug fixes.
-
-FO
-
-  • Moved footnote properties to attribute-sets.
-
-  • Added support for side floats, margin notes, and custom floats.
-
-  • Added new parameters body.start.indent and body.end.indent to the
-    set.flow.properties template.
-
-  • Added support for xml:id
-
-  • Added support for refdescriptor.
-
-  • Added support for multiple refnamedivs.
-
-  • Added index.entry.properties attribute-set to support customization of
-    index entries.
-
-  • Added set.flow.properties template call to each fo:flow to support
-    customizations entry point.
-
-  • Add support for @floatstyle in figure
-
-  • Moved hardcoded properties for index division titles to the
-    index.div.title.properties attribute-set.
-
-  • Added support for table-layout="auto" for XEP.
-
-  • Added index.div.title.properties attribute-set.
-
-  • $verbose parameter is now passed to most elements.
-
-  • Added refentry to toc in part, as it is permitted by the DocBook schema/
-    DTD.
-
-  • Added backmatter elements and article to toc in part, since they are
-    permitted by the DocBook schema/DTD.
-
-  • Added mode="toc" for simplesect, since it is now permitted in the toc if
-    simplesect.in.toc is set.
-
-  • Moved hard-coded properties to nongraphical.admonintion.properties and
-    graphical.admonition.properties attribute sets.
-
-  • Added support for sidebar-width and float-type processing instructions in
-    sidebar.
-
-  • For tables with HTML markup elements, added support for dbfo bgcolor PI,
-    the attribute-sets named table.properties, informaltable.properties,
-    table.table.properties, and table.cell.padding. Also added support for the
-    templates named table.cell.properties and table.cell.block.properties so
-    that tabstyles can be implemented. Also added support for tables containing
-    only tr instead of tbody with tr.
-
-  • Added new paramater hyphenate.verbatim.characters which can specify
-    characters after which a line break can occur in verbatim environments.
-    This parameter can be used to extend the initial set of characters which
-    contain only space and non-breakable space.
-
-  • Added itemizedlist.label.markup to enable selection of different bullet
-    symbol. Also added several potential bullet characters, commented out by
-    default.
-
-  • Enabled all id's in XEP output for external olinking.
-
-HTML
-
-  • Added support for refdescriptor.
-
-  • Added support for multiple refnamedivs.
-
-  • Added support for xml:id
-
-  • refsynopsisdiv as a section for counting section levels
-
-Images
-
-  • Added new SVG admonition graphics and navigation images.
-
-Release 1.67.2
-
-This release fixes a table bug introduced in the 1.67.1 release.
-
-Release 1.67.1
-
-This release includes a number of bug fixes.
-
-The following lists provide details about API and feature changes.
-
-FO
-
-  • Tables: Inherited cell properties are now passed to the
-    table.cell.properties template so they can be overridden by a
-    customization.
-
-  • Tables: Added support for bgcolor PI on table row element.
-
-  • TOCs: Added new parameter simplesect.in.toc; default value of 0 causes
-    simplesect to be omitted from TOCs; to cause simplesect to be included in
-    TOCs, you must set the value of simplesect.in.toc to 1.Comment from Norm:
-
-        Simplesect elements aren't supposed to appear in the ToC at all... The
-        use case for simplesect is when, for example, every chapter in a book
-        ends with "Exercises" or "For More Information" sections and you don't
-        want those to appear in the ToC.
-
-  • Sections: Reverted change that caused a variable reference to be used in a
-    template match and rewrote code to preserve intended semantics.
-
-  • Lists: Added workaround to prevent "* 0.60 + 1em" garbage in list output
-    from PassiveTeX
-
-  • Moved the literal attributes from component.title to the
-    component.title.properties attribute-set so they can be customized.
-
-  • Lists: Added glossdef's first para to special handling in
-    fo:list-item-body.
-
-HTML
-
-  • TOCs: Added new parameter simplesect.in.toc; for details, see the list of
-    FO changes for this release.
-
-  • Indexing: Added new parameter index.prefer.titleabbrev; when set to 1,
-    index references will use titleabbrev instead of title when available.
-
-HTML Help
-
-  • Added support for generating windows-1252-encoded output using Saxon; for
-    more details, see the list of XSL Java extensions changes for this release.
-
-man pages
-
-  • Replaced named/numeric character-entity references for non-breaking space
-    with groff equivalent (backslash-tilde).
-
-XSL Java extensions
-
-  • Saxon extensions: Added the Windows1252 class. It extends Saxon 6.5.x with
-    the windows-1252 character set, which is particularly useful when
-    generating HTML Help for Western European Languages (code from Pontus
-    Haglund and contributed to the DocBook community by Sectra AB, Sweden).
-
-    To use:
-
-     1. Make sure that the Saxon 6.5.x jar file and the jar file for the
-        DocBook XSL Java extensions are in your CLASSPATH
-
-     2. Create a DocBook XSL customization layer -- a file named
-        mystylesheet.xsl or whatever -- that, at a minimum, contains the
-        following:
-
-          <xsl:stylesheet
-            xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
-            version='1.0'>
-            <xsl:import href="http://docbook.sourceforge.net/release/xsl/current/htmlhelp/htmlhelp.xsl"/>
-            <xsl:output method="html" encoding="WINDOWS-1252" indent="no"/>
-            <xsl:param name="htmlhelp.encoding" select="'WINDOWS-1252'"></xsl:param>
-            <xsl:param name="chunker.output.encoding" select="'WINDOWS-1252'"></xsl:param>
-            <xsl:param name="saxon.character.representation" select="'native'"></xsl:param>
-          </xsl:stylesheet>
-
-        Invoke Saxon with the encoding.windows-1252 Java system property set to
-        com.nwalsh.saxon.Windows1252; for example
-
-          java \
-            -Dencoding.windows-1252=com.nwalsh.saxon.Windows1252 \
-          com.icl.saxon.StyleSheet \
-          mydoc.xml mystylesheet.xsl
-
-        Or, for a more complete "real world" case showing other options you'll
-        typically want to use:
-
-          java \
-            -Dencoding.windows-1252=com.nwalsh.saxon.Windows1252 \
-            -Djavax.xml.parsers.DocumentBuilderFactory=org.apache.xerces.jaxp.DocumentBuilderFactoryImpl \
-            -Djavax.xml.parsers.SAXParserFactory=org.apache.xerces.jaxp.SAXParserFactoryImpl \
-            -Djavax.xml.transform.TransformerFactory=com.icl.saxon.TransformerFactoryImpl \
-          com.icl.saxon.StyleSheet \
-            -x org.apache.xml.resolver.tools.ResolvingXMLReader \
-            -y org.apache.xml.resolver.tools.ResolvingXMLReader \
-            -r org.apache.xml.resolver.tools.CatalogResolver \
-          mydoc.xml mystylesheet.xsl
-
-        In both cases, the "mystylesheet.xsl" file should be a DocBook
-        customization layer containing the parameters show in step 2.
-
-  • Saxon extensions: Removed Saxon 8 extensions from release package
-
-Release 1.67.0
-
-  • A number of important bug fixes.
-
-  • Added Saxon8 extensions
-
-  • Enabled dbfo table-width on entrytbl in FO output
-
-  • Added support for role=strong on emphasis in FO output
-
-  • Added new FO parameter hyphenate.verbatim that can be used to turn on
-    "intelligent" wrapping of verbatim environments.
-
-  • Replaced all <tt></tt> output with <code></code>
-
-  • Changed admon.graphic.width template to a mode so that different
-    admonitions can have different graphical widths.
-
-  • Deprecated the HTML shade.verbatim parameter (use CSS instead)
-
-  • Wrapped ToC refentrytitle/refname and refpurpose in span with class values.
-    This makes it possible to style them using a CSS stylesheet.
-
-  • Use strong/em instead of b/i in HTML output
-
-  • Added support for converting Emphasis to groff italic and Emphasis role=
-    'bold' to bold. Controlled by emphasis.propagates.style param, but not
-    documented yet using litprog system. Will do that next (planning to add
-    some other parameter-controllable options for hyphenation and handling of
-    line spacing).
-
-  • callout.graphics.number.limit.xml param: Changed the default from 10 to 15.
-
-  • verbatim.properties: Added hyphenate=false
-
-  • Saxon and Xalan Text.java extensions: Added support for URIResolver() on
-    insertfile href's
-
-  • Added generated RELEASE-NOTES.txt file.
-
-  • Added INSTALL file (executable file for generating catalog.xml)
-
-  • Removed obsolete tools directory from package
-
-Release 1.66.1
-
-  • A number of important bug fixes.
-
-  • Now xml:base attributes that are generated by an XInclude processor are
-    resolved for image files.
-
-  • Rewrote olink templates to support several new features.
-
-      □ Extended full olink support to FO output.
-
-      □ Add support for xrefstyle attribute in olinks.
-
-      □ New parameters to support new olink features: insert.olink.page.number,
-        insert.olink.pdf.frag, olink.debug, olink.lang.fallback.sequence,
-        olink.properties, prefer.internal.olink. See the reference page for
-        each parameter for more information.
-
-  • Added index.on.type parameter for new type attribute introduced in DocBook
-    4.3 for indexterms and index. This allows you to create multiple indices
-    containing different categories of entries. For users of 4.2 and earlier,
-    you can use the new parameter index.on.role instead.
-
-  • Added new section.autolabel.max.depth parameter to turn off section
-    numbering below a certain depth. This permits you to number major section
-    levels and leave minor section levels unnumbered.
-
-  • Added footnote.sep.leader.properties attribute set to format the line
-    separating footnotes in printed output.
-
-  • Added parameter img.src.path as a prefix to HTML img src attributes. The
-    prefix is added to whatever path is already generated by the stylesheet for
-    each image file.
-
-  • Added new attribute-sets informalequation.properties,
-    informalexample.properties, informalfigure.properties, and
-    informaltable.properties, so each such element type can be formatted
-    individually if needed.
-
-  • Add component.label.includes.part.label parameter to add any part number to
-    chapter, appendix and other component labels when the label.from.part
-    parameter is nonzero. This permits you to distinguish multiple chapters
-    with the same chapter number in cross references and the TOC.
-
-  • Added chunk.separate.lots parameter for HTML output. This parameter lets
-    you generate separate chunk files for each LOT (list of tables, list of
-    figures, etc.).
-
-  • Added several table features:
-
-      □ Added table.table.properties attribute set to add properties to the
-        fo:table element.
-
-      □ Added placeholder templates named table.cell.properties and
-        table.cell.block.properties to enable adding properties to any
-        fo:table-cell or the cell's fo:block, respectively. These templates are
-        a start for implementing table styles.
-
-  • Added new attribute set component.title.properties for easy modifications
-    of component's title formatting in FO output.
-
-  • Added Saxon support for an encoding attribute on the textdata element.
-    Added new parameter textdata.default.encoding which specifies encoding when
-    encoding attribute on textdata is missing.
-
-  • Template label.this.section now controls whole section label, not only
-    sub-label which corresponds to particular label. Former behaviour was IMHO
-    bug as it was not usable.
-
-  • Formatting in titleabbrev for TOC and headers is preserved when there are
-    no hotlink elements in the title. Formerly the title showed only the text
-    of the title, no font changes or other markup.
-
-  • Added intial.page.number template to set the initial-page-number property
-    for page sequences in print output. Customizing this template lets you
-    change when page numbering restarts. This is similar to the
-    format.page.number template that lets you change how the page number
-    formatting changes in the output.
-
-  • Added force.page.count template to set the force-page-count property for
-    page sequences in print output. This is similar to the format.page.number
-    template.
-
-  • Sort language for localized index sorting in autoidx-ng.xsl is now taken
-    from document lang, not from system environment.
-
-  • Numbering and formatting of normal and ulink footnotes (if turned on) has
-    been unified. Now ulink footnotes are mixed in with any other footnotes.
-
-  • Added support for renderas attribute in section and sect1 et al. This
-    permits you to render a given section title as if it were a different
-    level.
-
-  • Added support for label attribute in footnote to manually supply the
-    footnote mark.
-
-  • Added support for DocBook 4.3 corpcredit element.
-
-  • Added support for a dbfo keep-together PI for formal objects (table,
-    figure, example, equation, programlisting). That permits a formal object to
-    be kept together if it is not already, or to be broken if it is very long
-    and the default keep-together is not appropriate.
-
-  • For graphics files, made file extension matching case insensitive, and
-    updated the list of graphics extensions.
-
-  • Allow calloutlist to have block content before the first callout
-
-  • Added dbfo-need processing instruction to provide soft page breaks.
-
-  • Added implementation of existing but unused default.image.width parameter
-    for graphics.
-
-  • Support DocBook NG tag inline element.
-
-  • It appears that XEP now supports Unicode characters in bookmarks. There is
-    no further need to strip accents from characters.
-
-  • Make segmentedlist HTML markup more semantic and available to CSS styles.
-
-  • Added user.preroot placeholder template to permit xsl-stylesheet and other
-    PIs and comments to be output before the HTML root element.
-
-  • Non-chunked legalnotice now gets an <a name="id"> element in HTML output so
-    it can be referenced with xref or link.
-
-  • In chunked HTML output, changed link rel="home" to rel="start", and link
-    rel="previous" to rel="prev", per W3C HTML 4.01 spec.
-
-  • Added several patches to htmlhelp from W. Borgert
-
-  • Added Bosnian locale file as common/bs.xml.
-
-Release 1.65.0
-
-  • A number of important bug fixes.
-
-  • Added a workaround to allow these stylesheets to process DocBook NG
-    documents. (It’s a hack that pre-processes the document to strip off the
-    namespace and then uses exsl:node-set to process the result.)
-
-  • Added alternative indexing mechanism which has better internationalization
-    support. New indexing method allows grouping of accented letters like e, é,
-    ë into the same group under letter "e". It can also treat special letters
-    (e.g. "ch") as one character and place them in the correct position (e.g.
-    between "h" and "i" in Czech language).
-
-    In order to use this mechanism you must create customization layer which
-    imports some base stylesheet (like fo/docbook.xsl, html/chunk.xsl) and then
-    includes appropriate stylesheet with new indexing code (fo/autoidx-ng.xsl
-    or html/autoidx-ng.xsl). For example:
-
-    <xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
-                    version="1.0">
-
-    <xsl:import href="http://docbook.sourceforge.net/release/xsl/current/fo/docbook.xsl"/>
-    <xsl:include href="http://docbook.sourceforge.net/release/xsl/current/fo/autoidx-ng.xsl"/>
-
-    </xsl:stylesheet>
-
-    New method is known to work with Saxon and it should also work with
-    xsltproc 1.1.1 and later. Currently supported languages are English, Czech,
-    German, French, Spanish and Danish.
-
-Release 1.64.1
-
-General bug fixes and improvements. Sorry about the failure to produce an
-updated release notes file for 1.62.0—1.63.2
-
-  • In the course of fixing bug #849787, wrapping Unicode callouts with an
-    appropriate font change in the Xalan extensions, I discovered that the
-    Xalan APIs have changed a bit. So xalan2.jar will work with older Xalan 2
-    implementations, xalan25.jar works with Xalan 2.5.
-
-Release 1.61.0
-
-Lots of bug fixes and improvements.
-
-  • Initial support for timestamp PI. From now you can use <?dbtimestamp format
-    ="Y-m-d H:M:S"?> to get current datetime in your document. Added
-    localization support for datetime PI
-
-  • Added level 6 to test for section depth in section.level template so that
-    section.title.level6.properties will be used for sections that are 6 deep
-    or deeper. This should also cause a h6 to be created in html output.
-
-  • Don't use SVG graphics if use.svg=0
-
-  • Now uses number-and-title-template for sections only if section.autolabel
-    is not zero.
-
-  • Added missing 'english-language-name' attribute to the l10n element, and
-    the missing 'style' attribute to the template element so the current
-    gentext documents will validate.
-
-  • Corrected several references to parameter qanda.defaultlabel that were
-    missing the "$".
-
-  • Now accepts admon.textlabel parameter to turn off Note, Warning, etc.
-    label.
-
-  • FeatReq #684561: support more XEP metadata
-
-  • Added hyphenation support. Added support for coref. Added beginpage
-    support. (does nothing; see TDG).
-
-  • Added support for hyphenation-character, hyphenation-push-character-count,
-    and hyphenation-remain-character-count
-
-  • Added root.properties, ebnf.assignment, and ebnf.statement.terminator
-
-  • Support bgcolor PI in table cells; make sure rowsep and colsep don't have
-    any effect on the last row or column
-
-  • Handle othercredit on titlepage a little better
-
-  • Applied fix from Jeff Beal that fixed the bug that put secondary page
-    numbers on primary entries. Same with tertiary page numbers on secondary
-    entries.
-
-  • Added definition of missing variable collection.
-
-  • Make footnote formatting 'normal' even when it occurs in a context that has
-    special formatting
-
-  • Added warning when glossary.collection is not blank, but it cannot open the
-    specified file.
-
-  • Pick up the frame attribute on table and informaltable.
-
-  • indexdiv/title in non-autogenerated indexes are now picked up.
-
-  • Removed (unused) component.title.properties
-
-  • Move IDs from page-sequences down to titlepage blocks
-
-  • Use proportional-column-width(1) on more tables.
-
-    Use proportional-column-width() for header/footer tables; suppress
-    relative-align when when using FOP
-
-  • Check for glossterm.auto.link when linking firstterms; don't output gl.
-    prefix on glossterm links
-
-  • Generate Part ToCs
-
-  • Support glossary, bibliography, and index in component ToCs.
-
-  • Refactored chunking code so that customization of chunk algorithm and chunk
-    elements is more practical
-
-  • Support textobject/phrase on inlinemediaobject.
-
-  • Support 'start' PI on ordered lists
-
-  • Fixed test of $toc PI to turn on qandaset TOC.
-
-  • Added process.chunk.footnotes to sect2 through 5 to fix bug of missing
-    footnotes when chunk level greater than 1.
-
-  • Added paramater toc.max.depth which controls maximal depth of ToC as
-    requested by PHP-DOC group.
-
-  • Exempted titleabbrev from preamble processing in lists, and fixed
-    variablelist preamble code to use the same syntax as the other lists.
-
-  • Added support for elements between variablelist and first varlistentry
-    since DocBook 4.2 supports that now.
-
-Release 1.60.1
-
-Lots of bug fixes.
-
-  • The format of the titlepage.templates.xml files and the stylesheet that
-    transforms them have been significantly changed. All of the attributes used
-    to control the templates are now namespace qualified. So what used to be:
-
-    <t:titlepage element="article" wrapper="fo:block">
-
-    is now:
-
-    <t:titlepage t:element="article" t:wrapper="fo:block">
-
-    Attributes from other namespaces (including those that are unqualified) are
-    now copied directly through. In practice, this means that the names that
-    used to be “fo:” qualified:
-
-    <title named-template="component.title"
-           param:node="ancestor-or-self::article[1]"
-           fo:text-align="center"
-           fo:keep-with-next="always"
-           fo:font-size="&hsize5;"
-           fo:font-weight="bold"
-           fo:font-family="{$title.font.family}"/>
-
-    are now unqualified:
-
-    <title t:named-template="component.title"
-           param:node="ancestor-or-self::article[1]"
-           text-align="center"
-           keep-with-next="always"
-           font-size="&hsize5;"
-           font-weight="bold"
-           font-family="{$title.font.family}"/>
-
-    The t:titlepage and t:titlepage-content elements both generate wrappers
-    now. And unqualified attributes on those elements are passed through. This
-    means that you can now make the title font apply to ane entire titlepage
-    and make the entire “recto” titlepage centered by specifying the font and
-    alignment on the those elements:
-
-    <t:titlepage t:element="article" t:wrapper="fo:block"
-                 font-family="{$title.font.family}">
-
-      <t:titlepage-content t:side="recto"
-                 text-align="center">
-
-  • Support use of titleabbrev in running headers and footers.
-
-  • Added (experimental) xref.with.number.and.title parameter to enable number/
-    title cross references even when the default would be just the number.
-
-  • Generate part ToCs if they're requested.
-
-  • Use proportional-column-width() in header/footer tables.
-
-  • Handle alignment correctly when screenshot wraps a graphic in a figure.
-
-  • Format chapter and appendix cross references consistently.
-
-  • Attempt to support tables with multiple tgroups in FO.
-
-  • Output fo:table-columns in simplelist tables.
-
-  • Use titlepage.templates.xml for indexdiv and glossdiv formatting.
-
-  • Improve support for new bibliography elements.
-
-  • Added footnote.number.format, table.footnote.number.format,
-    footnote.number.symbols, and table.footnote.number.symbols for better
-    control of footnote markers.
-
-  • Added glossentry.show.acronyms.
-
-  • Suppress the draft-mode page masters when draft-mode is “no”.
-
-  • Make blank pages verso not recto. D'Oh!
-
-  • Improved formatting of ulink footnotes.
-
-  • Fixed bugs in graphic width/height calculations.
-
-  • Added class attributes to inline elements.
-
-  • Don't add “.html” to the filenames identified with the “dbhtml” PI.
-
-  • Don't force a ToC when sections contain refentrys.
-
-  • Make section title sizes a function of the body.master.size.
-
-Release 1.59.2
-
-The 1.59.2 fixes an FO bug in the page masters that causes FOP to fail.
-
-  • Removed the region-name from the region-body of blank pages. There's no
-    reason to give the body of blank pages a unique name and doing so causes a
-    mismatch that FOP detects.
-
-  • Output IDs for the first paragraphs in listitems.
-
-  • Fixed some small bugs in the handling of page numbers in double-sided mode.
-
-  • Attempt to prevent duplicated IDs from being produced when endterm on xref
-    points to something with nested structure.
-
-  • Fix aligment problems in equations.
-
-  • Output the type attribute on unordered lists (UL) in HTML only if the
-    css.decoration parameter is true.
-
-  • Calculate the font size in formal.title.properties so that it's 1.2 times
-    the base font size, not a fixed "12pt".
-
-Release 1.59.1
-
-The 1.59.1 fixes a few bugs.
-
-  • Added Bulgarian localization.
-
-  • Indexing improvements; localize book indexes to books but allow setindex to
-    index an entire set.
-
-  • The default value for rowsep and colsep is now "1" as per CALS.
-
-  • Added support for titleabbrev (use them for cross references).
-
-  • Improvements to mediaobject for selecting print vs. online images.
-
-  • Added seperate property sets for figures, examples, equations, tabless, and
-    procedures.
-
-  • Make lineannotations italic.
-
-  • Support xrefstyle attribute.
-
-  • Make endterm on xref higher priority than xreflabel target.
-
-  • Glossary formatting improvements.
-
-Release 1.58.0
-
-The 1.58.0 adds some initial support for extensions in xsltproc, adds a few
-features, and fixes bugs.
-
-  • This release contains the first attempt at extension support for xsltproc.
-    The only extension available to date is the one that adjusts table column
-    widths. Run extensions/xsltproc/python/xslt.py.
-
-  • Fixed bugs in calculation of adjusted column widths to correct for rounding
-    errors.
-
-  • Support nested refsection elements correctly.
-
-  • Reworked gentext.template to take context into consideration. The name of
-    elements in localization files is now an xpath-like context list, not just
-    a simple name.
-
-  • Made some improvements to bibliography formatting.
-
-  • Improved graphical formatting of admonitions.
-
-  • Added support for entrytbl.
-
-  • Support spanning index terms.
-
-  • Support bibliosource.
-
-Release 1.57.0
-
-  • The 1.57.0 release wasn't documented here. Oops.
-
-Release 1.56.0
-
-The 1.56.0 release fixes bugs.
-
-  • Reworked chunking. This will break all existing customizations layers that
-    change the chunking algorithm. If you're customizing chunking, look at the
-    new “content” parameter that's passed to process-chunk-element and friends.
-
-  • Support continued and inherited numeration in orderedlist formatting for
-    FOs.
-
-  • Added Thai localization.
-
-  • Tweaked stylesheet documentation stylesheets to link to TDG and the
-    parameter references.
-
-  • Allow title on tables of contents ("Table of Contents") to be optional.
-    Added new keyword to generate.toc. Support tables of contents on sections.
-
-  • Made separate parameters for table borders and table cell borders:
-    table.frame.border.color, table.frame.border.style,
-    table.frame.border.thickness, table.cell.border.color,
-    table.cell.border.style, and table.cell.border.thickness.
-
-  • Suppress formatting of “endofrange” indexterms. This is only half-right.
-    They should generate a range, but I haven't figured out how to do that yet.
-
-  • Support revdescription. (Bug #582192)
-
-  • Added default.float.class and fixed figure floats. (Bug #497603)
-
-  • Fixed formatting of sbr in FOs.
-
-  • Added context to the “missing template” error message.
-
-  • Process arg correctly in a group. (Bug #605150)
-
-  • Removed 'keep-with-next' from formal.title.properties attribute set now
-    that the stylesheets support the option of putting such titles below the
-    object. Now the $placement value determines if 'keep-with-next' or
-    'keep-with-previous' is used in the title block.
-
-  • Wrap “url()” around external-destinations when appropriate.
-
-  • Fixed typo in compact list spacing. (Bug #615464)
-
-  • Removed spurious hash in anchor name. (Bug #617717)
-
-  • Address is now displayed verbatim on title pages. (Bug #618600)
-
-  • The bridgehead.in.toc parameter is now properly supported.
-
-  • Improved effectiveness of HTML cleanup by increasing the number of places
-    where it is used. Improve use of HTML cleanup in XHTML stylesheets.
-
-  • Support table of contents for appendix in article. (Bug #596599)
-
-  • Don't duplicate footnotes in bibliographys and glossarys. (Bug #583282)
-
-  • Added default.image.width. (Bug #516859)
-
-  • Totally reworked funcsynopsis code; it now supports a 'tabular'
-    presentation style for 'wide' prototypes; see
-    funcsynopsis.tabular.threshold. (HTML only right now, I think, FO support,
-    uh, real soon now.)
-
-  • Reworked support for difference marking; toned down the colors a bit and
-    added a “system.head.content” template so that the diff CSS wasn't
-    overriding “user.head.content”. (Bug #610660)
-
-  • Added call to the “*.head.content” elements when writing out long
-    description chunks.
-
-  • Make sure legalnotice link is correct even when chunking to a different
-    base.dir.
-
-  • Use CSS to set viewport characteristics if css.decoration is non-zero, use
-    div instead of p for making graphic a block element; make figure titles the
-    default alt text for images in a figure.
-
-  • Added space-after to list.block.spacing.
-
-  • Reworked section.level template to give “correct” answer instead of being
-    off by one.
-
-  • When processing tables, use the tabstyle attribute as the division class.
-
-  • Fixed bug in html2xhtml.xsl that was causing the XHTML chunker to output
-    HTML instead of XHTML.
-
-Older releases
-
-To view the release notes for older releases, see http://cvs.sourceforge.net/
-viewcvs.py/docbook/xsl/RELEASE-NOTES.xml. Be aware that there were no release
-notes for releases prior to the 1.50.0 release.
-
-About dot-zero releases
-
-DocBook Project “dot zero” releases should be considered experimental and are
-always followed by stable “dot one plus” releases, usually within two or three
-weeks. Please help to ensure the stability of “dot one plus” releases by
-carefully testing each “dot zero” release and reporting back about any problems
-you find.
-
-It is not recommended that you use a “dot zero” release in a production system.
-Instead, you should wait for the “dot one” or greater versions.
-

Rozdielové dáta súboru neboli zobrazené, pretože súbor je príliš veľký
+ 0 - 7412
stylesheets/lfs-xsl/docbook-xsl-1.78.1/RELEASE-NOTES.xml


+ 0 - 1
stylesheets/lfs-xsl/docbook-xsl-1.78.1/REVISION

@@ -1 +0,0 @@
-9732

+ 0 - 23
stylesheets/lfs-xsl/docbook-xsl-1.78.1/TODO

@@ -1,23 +0,0 @@
-The "to do" list for the DocBook Project XSL stylesheets is
-maintained at Sourceforge. To view a list of all open feature
-requests for the stylesheets:
-
-  http://docbook.sf.net/tracker/xsl/requests
-
-To submit a feature request against the stylesheets:
-
-  http://docbook.sf.net/tracker/submit/request
-
-To do a full-text search of all DocBook Project issues:
-
-  http://docbook.sf.net/tracker/search
-
-Discussion about the DocBook Project XSL stylesheets takes place
-on the docbook-apps mailing list:
-
-  http://wiki.docbook.org/topic/DocBookAppsMailingList
-
-Real-time discussion takes place on IRC:
-
-  http://wiki.docbook.org/topic/DocBookIrcChannel
-  irc://irc.freenode.net/docbook

+ 0 - 115
stylesheets/lfs-xsl/docbook-xsl-1.78.1/VERSION

@@ -1,115 +0,0 @@
-<?xml version='1.0'?> <!-- -*- nxml -*- vim: set foldlevel=2: -->
-<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
-  xmlns:fm="http://freshmeat.net/projects/freshmeat-submit/"
-  xmlns:sf="http://sourceforge.net/"
-  xmlns:dyn="http://exslt.org/dynamic"
-  xmlns:saxon="http://icl.com/saxon"
-  exclude-result-prefixes="fm sf"
-  version='1.0'>
-
-<xsl:param name="get"/>
-<xsl:param name="VERSION" select="string(document('')//fm:Version[1])"/>
-<xsl:param name="Tag" select="concat('V',translate(string(document('')//fm:Version[1]),'.',''))"/>
-<xsl:param name="DistroTitle" select="string(document('')//fm:Branch[1])"/>
-<xsl:param name="sf-relid" select="0"/>
-
-<xsl:param name="DistroName">docbook-xsl</xsl:param>
-<xsl:param name="PreviousRelease">1.78.0</xsl:param>
-<xsl:param name="PreviousReleaseRevision">9696</xsl:param>
-<xsl:param name="Revision">$Revision: 9731 $</xsl:param>
-<xsl:param name="VersionFileURL">$URL: https://docbook.svn.sourceforge.net/svnroot/docbook/trunk/xsl/VERSION $</xsl:param>
-
-<xsl:strip-space elements="fm:*"/>
-
-<fm:project>
-  <fm:Project>DocBook</fm:Project>
-  <fm:Branch>XSL Stylesheets</fm:Branch>
-  <!-- * set/keep fm:version as N.NN.N-pre except for official releases, -->
-  <!-- * then after the release, revert it to N.NN.N-pre & check back in -->
-  <fm:Version>1.78.1</fm:Version>
-<!--
-  <fm:License>MIT/X Consortium License</fm:License>
--->
-  <fm:Release-Focus>
-<!-- * Initial freshmeat announcement -->
-<!-- * Documentation -->
-<!-- * Code cleanup -->
-<!-- * Minor feature enhancements  -->
-* Major feature enhancements 
-<!-- * Minor bugfixes  -->
-<!-- * Major bugfixes -->
-<!-- * Minor security fixes -->
-<!-- * Major security fixes -->
-  </fm:Release-Focus>
-  <fm:Home-Page-URL>http://sourceforge.net/projects/docbook/</fm:Home-Page-URL>
-  <fm:Gzipped-Tar-URL>http://prdownloads.sourceforge.net/docbook/{DISTRONAME-VERSION}.tar.gz?download</fm:Gzipped-Tar-URL>
-  <fm:Zipped-Tar-URL>http://prdownloads.sourceforge.net/docbook/{DISTRONAME-VERSION}.zip?download</fm:Zipped-Tar-URL>
-  <fm:Bzipped-Tar-URL>http://prdownloads.sourceforge.net/docbook/{DISTRONAME-VERSION}.bz2?download</fm:Bzipped-Tar-URL>
-  <fm:Changelog-URL>http://sourceforge.net/project/shownotes.php?release_id={SFRELID}</fm:Changelog-URL>
-  <fm:CVS-URL>http://docbook.svn.sourceforge.net/viewvc/docbook/</fm:CVS-URL>
-  <fm:Mailing-List-URL>http://lists.oasis-open.org/archives/docbook-apps/</fm:Mailing-List-URL>
-  <fm:Changes>This is a release with bugfixes and some enhancements.</fm:Changes>
-</fm:project>
-
-<xsl:template match="/" priority="-100">
-  <xsl:choose>
-    <xsl:when test="$get = 'Tag'">
-      <xsl:value-of select="$Tag"/>
-    </xsl:when>
-    <xsl:when test="$get = 'PreviousRelease'">
-      <xsl:value-of select="$PreviousRelease"/>
-    </xsl:when>
-    <xsl:when test="$get = 'PreviousReleaseRevision'">
-      <xsl:value-of select="$PreviousReleaseRevision"/>
-    </xsl:when>
-    <xsl:when test="$get = 'DistroTitle'">
-      <xsl:value-of select="$DistroTitle"/>
-    </xsl:when>
-    <xsl:when test="$get = 'VERSION'">
-      <xsl:value-of select="$VERSION"/>
-    </xsl:when>
-    <xsl:otherwise>
-      <xsl:if test="$sf-relid = 0">
-        <xsl:message terminate="yes">
-         <xsl:text>You must specify the sf-relid as a parameter.</xsl:text>
-        </xsl:message>
-      </xsl:if>
-      <xsl:apply-templates select="//fm:project"/>
-    </xsl:otherwise>
-  </xsl:choose>
-</xsl:template>
-
-<xsl:template match="fm:project">
-  <xsl:apply-templates/>
-  <xsl:text>&#10;</xsl:text>
-  <xsl:apply-templates select="fm:Changes" mode="text"/>
-</xsl:template>
-
-<xsl:template match="fm:Changes"/>
-
-<xsl:template match="fm:Gzipped-Tar-URL|fm:Zipped-Tar-URL|fm:Bzipped-Tar-URL">
-  <xsl:value-of select="local-name(.)"/>
-  <xsl:text>: </xsl:text>
-  <xsl:value-of select="substring-before(., '{DISTRONAME-VERSION}')"/>
-  <xsl:value-of select="concat($DistroName, '-', $VERSION)"/>
-  <xsl:value-of select="substring-after(., '{DISTRONAME-VERSION}')"/>
-  <xsl:text>&#10;</xsl:text>
-</xsl:template>
-
-<xsl:template match="fm:Changelog-URL">
-  <xsl:value-of select="local-name(.)"/>
-  <xsl:text>: </xsl:text>
-  <xsl:value-of select="substring-before(., '{SFRELID}')"/>
-  <xsl:value-of select="$sf-relid"/>
-  <xsl:value-of select="substring-after(., '{SFRELID}')"/>
-  <xsl:text>&#10;</xsl:text>
-</xsl:template>
-
-<xsl:template match="fm:*">
-  <xsl:value-of select="local-name(.)"/>
-  <xsl:text>: </xsl:text>
-  <xsl:value-of select="normalize-space(.)"/>
-  <xsl:text>&#10;</xsl:text>
-</xsl:template>
-
-</xsl:stylesheet>

+ 0 - 195
stylesheets/lfs-xsl/docbook-xsl-1.78.1/assembly/README

@@ -1,195 +0,0 @@
-DocBook Assembly Stylesheets
-==============================
-bobs@sagehill.net
-
-This directory provides XSL stylesheets for working with
-DocBook assemblies.  It is intended to enable working with
-<topic> and <assembly> elements, as defined in DocBook 5.1
-and later.
-
-This kit currently supports most features of an assembly.
-See the "Unsupported Features" section below for details
-of what is not currently supported.  These more advanced
-features will be supported as it is further developed.
-
-
-Content of this directory:
---------------------------
-topic-maker-chunk.xsl        - stylesheet to modularize an existing DB5 document.
-topic-maker.xsl              - imported by topic-maker-chunk.xsl.
-assemble.xsl                 - stylesheet to process an <assembly> into a document.
-
-
-The toolkit consists of an assemble.xsl XSL stylesheet
-to process a DocBook <assembly> element to convert it
-to an assembled DocBook 5 document ready to be formatted.
-This stylesheet will enable users to structure a book from
-modular files.
-
-To make it easy to initially create a modular book, this
-kit also includes a topic-maker-chunk.xsl XSL stylesheet
-to break apart an existing DocBook 5 book into modular
-files, and also create the associated <assembly> document.
-Then you can run the assemble.xsl stylesheet to put it
-back together as a single DocBook document.
-
-
-To create an assembly and topic files from a book or article document
-=======================================================================
-
-If you have an existing DocBook 5 book or article document,
-you can convert it to an assembly and a collection of
-modular topic files.  If you want to convert a DocBook 4
-document, you must first convert it to version 5.
-
-For example, to disassemble a DocBook 5 book document named book.xml:
-
-xsltproc --xinclude \
-         --stringparam assembly.filename myassembly.xml \
-         --stringparam base.dir topics/  \
-         topic-maker-chunk.xsl  \
-         mybook.xml
-
-This command will result in a master assembly file named
-'myassembly.xml' with a root element of <assembly>, containing
-a single <structure> element. It will also break up the
-content of the book into modular chunks that are output
-to the 'topics/' subdirectory as specified in the 'base.dir'
-parameter.
-
-Options
-----------
-The name of the assembly file is set by the stylesheet param
-named 'assembly.filename', which should include the filename suffix.
-
-Modular files are output to the directory location specified
-by the 'base.dir' parameter.  If you want them in the current
-directory, then don't set that  param.
-
-By default the assembly element is output to the current
-directory, *not* into base.dir with the modular files.
-The <resources> element in the assembly has its xml:base
-attribute set to the value of 'base.dir', so that it is
-added to the paths to the modular files when processed.
-If you set the stylesheet param 'manifest.in.base.dir'
-to 1, then the assembly file is created in the base.dir
-directory and the xml:base attribute is omitted (since
-they are together in the same directory).
-
-If you want the assembly file in 'base.dir' instead of
-the current directory, then set the stylesheet param
-'manifest.in.base.dir' to 1.
-
-The stylesheet chunks a document into modules at the
-same boundaries as the chunking XHTML stylesheet, because
-it reuses many of the chunking stylesheet templates.
-You can alter the chunking behavior with the same options
-as for XHTML chunking.
-
-For example, the stylesheet will chunk sections into topics
-down to section level 3 by default.  To change that level,
-change the stylesheet param 'chunk.section.depth' to
-another value.
-
-Finer control of chunking can be achieved by using
-the <?dbhtml stop-chunking?> processing instruction in
-the source file.
-
-Many modular elements retain their original element name,
-such as glossary, bibliography, index, and such.  By default, the
-stylesheet converts chapter, article, preface and section elements
-into <topic> modules.  To change that list of
-converted element names, alter the stylesheet param named
-'topic.elements'.  If that param is empty, then no elements
-will be converted to <topic>, so they will all retain their
-original element names.
-
-Modular filenames use the same naming scheme as the chunking
-XHTML stylesheet, and supports the same file naming options such as
-the param 'use.id.as.filename', which is set to 1 by default.
-Note that the stylesheet param 'html.ext' is set to '.xml'
-because it is producing modular XML files, not HTML files.
-
-Root element conversion
-------------------------
-By default, the root element of the original document is 
-also converted to a module, and <structure> gets a resourceref
-attribute to reference it.  If you set the stylesheet
-param 'root.as.resourceref' to zero, then the root element
-is handled differently, as described as follows.
-
-If the structure element does not have a resourcref
-attribute, the root element is constructed rather
-than copied from a resource. The structure element must
-have a renderas attribute (or its child output element must
-have such) to select the output root element name.  
-
-Any content between the root element start tag and the
-first module is put into a resource with the original
-root element.  To pull this content in, the first
-module in the structure points to this resource but
-uses a contentonly="yes" attribute. The effect of
-that attribute is to pull in all content *except*
-the root element of that resource.
-
-In general, if you have content that does not logically
-have its own container element, you can put the content
-into a suitable container element and then deselect the
-container element upon assembly with the contentonly="yes"
-attribute.  That attribute can also be used to avoid
-pulling in a resource's xml:id when you want to change it.
-
-
-To process an <assembly> into an assembled DocBook document
-==============================================================
-
-To convert an <assembly> and its associated modular
-files into a single DocBook document, process
-your assembly document with the assemble.xsl stylesheet.
-You should then be able to process the resulting
-document with a DocBook XSL formatting stylesheet.
-
-
-
-
-Useful params in assemble.xsl
------------------------------
-The $root.default.renderas param sets the name of the
-root element of the assembled document, if it is not
-otherwise specified with @renderas.  Its default value
-is 'book'.
-
-The $topic.default.renderas param sets the name of the
-output element for any topic element included in the
-assembly, if it is not otherwise specified with
-@renderas.  It's default value is 'section'.
-
-The $structure.id param lets you specify at runtime
-the id value of the structure you want to reassemble.
-This is only necessary if you have more than one
-structure element in your assembly.
-
-The $output.type param also lets you specify at runtime
-which structure element to process.  In this case,
-the value should match on an @type attribute on
-the structure element.
-
-The $output.format param lets you specify at runtime
-which of several possible output formats are being generated.
-The param value is compared to the @format
-attribute on <output> elements to select specific properties
-for a module.
-
-
-
-Unsupported Features
------------------------
-
-The transforms and transform elements are currently ignored
-by the assembly stylesheet.
-
-The relationships and relationship elements are currently
-ignored by the assembly stylesheet.
-
-The filterin and filterout elements are not currently
-supported.

+ 0 - 677
stylesheets/lfs-xsl/docbook-xsl-1.78.1/assembly/assemble.xsl

@@ -1,677 +0,0 @@
-<?xml version="1.0" encoding="utf-8"?>
-<xsl:stylesheet 
-  xmlns:xsl="http://www.w3.org/1999/XSL/Transform" 
-  xmlns:exsl="http://exslt.org/common"
-  xmlns:xlink="http://www.w3.org/1999/xlink"
-  xmlns="http://docbook.org/ns/docbook"
-  exclude-result-prefixes="exsl d xlink"
-  version="1.0">
-
-<!-- $Id: assemble.xsl,v 1.10 2012-04-10 07:56:58 bobs Exp $ -->
-
-<xsl:preserve-space elements="*"/>
-<xsl:strip-space elements="d:assembly d:structure d:module d:resources d:resource"/>
-
-<xsl:key name="id" match="*" use="@id|@xml:id"/>
-
-
-<xsl:param name="docbook.version">5.0</xsl:param>
-<xsl:param name="root.default.renderas">book</xsl:param>
-<xsl:param name="topic.default.renderas">section</xsl:param>
-
-<xsl:param name="output.type" select="''"/>
-<xsl:param name="output.format" select="''"/>
-<!-- May be used to select one structure among several to  process -->
-<xsl:param name="structure.id" select="''"/>
-
-
-<!-- default mode is to copy all content nodes -->
-<xsl:template match="node()|@*" priority="-5" mode="copycontent">
-  <xsl:param name="omittitles"/>
-    <xsl:copy>
-      <xsl:apply-templates select="@*" mode="copycontent"/>
-      <xsl:apply-templates mode="copycontent">
-        <xsl:with-param name="omittitles" select="$omittitles"/>
-      </xsl:apply-templates>
-   </xsl:copy>
-</xsl:template>
-
-<xsl:template match="processing-instruction('oxygen')"/>
-
-<!-- skip assembly info elements -->
-<xsl:template match="d:info"/>
-
-<!-- including for structure info element -->
-<xsl:template match="d:structure/d:info"/>
-
-<!-- handle omittitles, but only top level title of resource -->
-<xsl:template match="/*/d:title 
-                   | /*/d:info/d:title 
-                   | /*/d:subtitle  
-                   | /*/d:info/d:subtitle
-                   | /*/d:titleabbrev  
-                   | /*/d:info/d:titleabbrev"
-              mode="copycontent">
-  <xsl:param name="omittitles"/>
-
-  <xsl:choose>
-    <xsl:when test="$omittitles = 'yes' or $omittitles = 'true' or $omittitles = '1'">
-      <!-- omit it -->
-    </xsl:when>
-    <xsl:otherwise>
-      <xsl:copy>
-        <xsl:apply-templates select="@*" mode="copycontent"/>
-        <xsl:apply-templates mode="copycontent"/>
-      </xsl:copy>
-    </xsl:otherwise>
-  </xsl:choose>
-</xsl:template>
-
-<!-- handled in a mode -->
-<xsl:template match="d:resources"/>
-<xsl:template match="d:output|d:filterin|d:filterout|d:merge|d:revhistory"/>
-<xsl:template match="d:output|d:filterin|d:filterout|d:merge|d:revhistory"
-              mode="copycontent"/>
-
-<xsl:template match="d:assembly">
-  <xsl:choose>
-    <xsl:when test="$structure.id != ''">
-      <xsl:variable name="id.structure" select="key('id', $structure.id)"/>
-      <xsl:choose>
-        <xsl:when test="count($id.structure) = 0">
-          <xsl:message terminate="yes">
-            <xsl:text>ERROR: structure.id param set to '</xsl:text>
-            <xsl:value-of select="$structure.id"/>
-            <xsl:text>' but no element with that xml:id exists in assembly.</xsl:text>
-          </xsl:message>
-        </xsl:when>
-        <xsl:when test="local-name($id.structure) != 'structure'">
-          <xsl:message terminate="yes">
-            <xsl:text>ERROR: structure.id param set to '</xsl:text>
-            <xsl:value-of select="$structure.id"/>
-            <xsl:text>' but no structure with that xml:id exists in assembly.</xsl:text>
-          </xsl:message>
-        </xsl:when>
-        <xsl:otherwise>
-          <xsl:apply-templates select="key('id', $structure.id)"/>
-        </xsl:otherwise>
-      </xsl:choose>
-    </xsl:when>
-    <xsl:when test="$output.type != '' and not(d:structure[@type = $output.type])">
-      <xsl:message terminate="yes">
-        <xsl:text>ERROR: output.type param set to '</xsl:text>
-        <xsl:value-of select="$output.type"/>
-        <xsl:text> but no structure element has that type attribute. Exiting.</xsl:text>
-      </xsl:message>
-    </xsl:when>
-    <xsl:when test="$output.type != '' and d:structure[@type = $output.type]">
-      <xsl:apply-templates select="d:structure[@type = $output.type][1]"/>
-    </xsl:when>
-    <xsl:otherwise>
-      <!-- otherwise process the first structure -->
-      <xsl:apply-templates select="d:structure[1]"/>
-    </xsl:otherwise>
-  </xsl:choose>
-</xsl:template>
-
-<xsl:template match="d:structure[not(@resourceref)]">
-
-  <xsl:variable name="output.root.element">
-    <xsl:apply-templates select="." mode="compute.element.name"/>
-  </xsl:variable>
-
-  <xsl:element name="{$output.root.element}" namespace="http://docbook.org/ns/docbook">
-    <xsl:attribute name="version">
-      <xsl:value-of select="$docbook.version"/>
-    </xsl:attribute>
-    <xsl:copy-of select="@xml:id"/>
-
-    <xsl:apply-templates> 
-      <xsl:with-param name="parent" select="$output.root.element"/>
-    </xsl:apply-templates>
-
-  </xsl:element>
-</xsl:template>
-
-<xsl:template match="d:glossary|d:bibliography|d:index|d:toc">
-   <xsl:param name="parent" select="''"/>
-  <xsl:apply-templates select="." mode="copycontent"/>
-</xsl:template>
-
-<xsl:template match="d:title|d:titleabbrev|d:subtitle">
-   <xsl:param name="parent" select="''"/>
-  <xsl:apply-templates select="." mode="copycontent"/>
-</xsl:template>
-
-<!-- module without a resourceref creates an element -->
-<xsl:template match="d:module[not(@resourceref)]">
-  <xsl:param name="parent" select="''"/>
-  
-  <xsl:variable name="module" select="."/>
-
-  <xsl:variable name="element.name">
-    <xsl:apply-templates select="." mode="compute.element.name"/>
-  </xsl:variable>
-
-  <xsl:element name="{$element.name}" namespace="http://docbook.org/ns/docbook">
-    <xsl:choose>
-      <!-- Use the module's xml:id if it has one -->
-      <xsl:when test="@xml:id">
-        <xsl:attribute name="xml:id">
-          <xsl:value-of select="@xml:id"/>
-        </xsl:attribute>
-      </xsl:when>
-    </xsl:choose>
-
-    <xsl:call-template name="merge.info">
-      <xsl:with-param name="merge.element" select="$module/d:merge"/>
-    </xsl:call-template>
-      
-    <xsl:apply-templates>
-      <xsl:with-param name="parent" select="$element.name"/>
-    </xsl:apply-templates>
-
-  </xsl:element>
-</xsl:template>
-
-<xsl:template name="compute.renderas">
-  <xsl:variable name="output.value">
-    <xsl:call-template name="compute.output.value">
-      <xsl:with-param name="property">renderas</xsl:with-param>
-    </xsl:call-template>
-  </xsl:variable>
-
-  <xsl:value-of select="$output.value"/>
-
-</xsl:template>
-
-<!-- This utility template is passed a value for output format
-     and the name of a property and computes the value
-     of the property from output children of context element -->
-<xsl:template name="compute.output.value">
-  <xsl:param name="property" select="''"/>
-  
-  <xsl:variable name="default.format"
-                select="ancestor::d:structure/@defaultformat"/>
-
-  <xsl:variable name="property.value">
-    <xsl:choose>
-      <!-- if a child output element has a format that matches the param value 
-           and it has that property -->
-      <!-- The format attribute can be multivalued -->
-      <xsl:when test="$output.format != '' and 
-                      d:output[contains(concat(' ', normalize-space(@format), ' '),  
-                                 $output.format)]
-                        [@*[local-name() = $property]]">
-        <xsl:value-of 
-           select="d:output[contains(concat(' ', normalize-space(@format), ' '), 
-                              $output.format)]
-                           [@*[local-name() = $property]][1]
-                           /@*[local-name() = $property]"/>
-      </xsl:when>
-      <!-- try with the structure's @defaultformat -->
-      <xsl:when test="$default.format != '' and 
-                      d:output[contains(concat(' ', normalize-space(@format), ' '),  
-                                 $default.format)]
-                        [@*[local-name() = $property]]">
-        <xsl:value-of 
-           select="d:output[contains(concat(' ', normalize-space(@format), ' '), 
-                              $default.format)]
-                           [@*[local-name() = $property]][1]
-                           /@*[local-name() = $property]"/>
-      </xsl:when>
-      <!-- try the first output with the property-->
-      <xsl:when test="d:output[@*[local-name() = $property]]">
-        <xsl:value-of 
-           select="d:output[@*[local-name() = $property]][1]
-                           /@*[local-name() = $property]"/>
-      </xsl:when>
-      <!-- and try the module element itself -->
-      <xsl:when test="@*[local-name() = $property]">
-        <xsl:value-of 
-           select="@*[local-name() = $property]"/>
-      </xsl:when>
-    </xsl:choose>
-  </xsl:variable>
-
-  <xsl:value-of select="$property.value"/>
-</xsl:template>
-
-<xsl:template match="d:module[not(@resourceref)]" mode="compute.element.name">
-
-  <xsl:variable name="renderas">
-    <xsl:call-template name="compute.renderas"/>
-  </xsl:variable>
-
-  <xsl:choose>
-    <xsl:when test="string-length($renderas) != 0">
-      <xsl:value-of select="$renderas"/>
-    </xsl:when>
-    <xsl:otherwise>
-      <xsl:message terminate="yes">
-        <xsl:text>ERROR: cannot determine output element name for </xsl:text>
-        <xsl:text>module with no @resourceref and no @renderas. Exiting.</xsl:text>
-      </xsl:message>
-    </xsl:otherwise>
-  </xsl:choose>
-</xsl:template>
-
-<xsl:template match="d:module[@resourceref]" mode="compute.element.name">
-  <xsl:param name="ref.name" select="''"/>
-
-  <xsl:variable name="renderas">
-    <xsl:call-template name="compute.renderas"/>
-  </xsl:variable>
-
-  <xsl:choose>
-    <xsl:when test="string-length($renderas) != 0">
-      <xsl:value-of select="$renderas"/>
-    </xsl:when>
-    <xsl:when test="$ref.name = 'topic' and 
-                    string-length($topic.default.renderas) != 0"> 
-      <xsl:value-of select="$topic.default.renderas"/>
-    </xsl:when>
-    <xsl:when test="string-length($ref.name) != 0">
-      <xsl:value-of select="$ref.name"/> 
-    </xsl:when>
-    <xsl:otherwise>
-      <xsl:message terminate="yes">
-        <xsl:text>ERROR: cannot determine output element name for </xsl:text>
-        <xsl:text>@resourceref="</xsl:text>
-        <xsl:value-of select="@resourceref"/>
-        <xsl:text>". Exiting.</xsl:text>
-      </xsl:message>
-    </xsl:otherwise>
-  </xsl:choose>
-</xsl:template>
-
-<xsl:template match="d:structure" mode="compute.element.name">
-  <xsl:param name="ref.name" select="''"/>
-
-  <xsl:variable name="renderas">
-    <xsl:call-template name="compute.renderas"/>
-  </xsl:variable>
-
-  <xsl:choose>
-    <xsl:when test="string-length($renderas) != 0">
-      <xsl:value-of select="$renderas"/>
-    </xsl:when>
-    <xsl:when test="string-length($ref.name) != 0">
-      <xsl:value-of select="$ref.name"/> 
-    </xsl:when>
-    <xsl:when test="string-length($root.default.renderas) != 0">
-      <xsl:value-of select="$root.default.renderas"/>
-    </xsl:when>
-    <xsl:otherwise>
-      <xsl:message terminate="yes">
-        <xsl:text>ERROR: cannot determine output element name for </xsl:text>
-        <xsl:text>structure with no @renderas and no $root.default.renderas. </xsl:text>
-        <xsl:text>Exiting.</xsl:text>
-      </xsl:message>
-    </xsl:otherwise>
-  </xsl:choose>
-</xsl:template>
-
-<xsl:template match="d:module[@resourceref] | d:structure[@resourceref]">
-  <xsl:param name="parent" select="''"/>
-
-  <xsl:variable name="module" select="."/>
-  <xsl:variable name="resourceref" select="@resourceref"/>
-  <xsl:variable name="resource" select="key('id', $resourceref)"/>
-
-  <xsl:choose>
-    <xsl:when test="not($resource)">
-      <xsl:message terminate="yes">
-        <xsl:text>ERROR: no xml:id matches @resourceref = '</xsl:text>
-        <xsl:value-of select="$resourceref"/>
-        <xsl:text>'.</xsl:text>
-      </xsl:message>
-    </xsl:when>
-    <xsl:when test="not($resource/self::d:resource)">
-      <xsl:message terminate="yes">
-        <xsl:text>ERROR: xml:id matching @resourceref = '</xsl:text>
-        <xsl:value-of select="$resourceref"/>
-        <xsl:text> is not a resource element'.</xsl:text>
-      </xsl:message>
-    </xsl:when>
-  </xsl:choose>
-
-  <xsl:variable name="fileref.att" select="$resource/@fileref"/>
-
-  <xsl:variable name="fragment.id">
-    <xsl:if test="contains($fileref.att, '#')">
-      <xsl:value-of select="substring-after($fileref.att, '#')"/>
-    </xsl:if>
-  </xsl:variable>
-
-  <xsl:variable name="filename">
-    <xsl:choose>
-      <xsl:when test="string-length($fragment.id) != 0">
-        <xsl:value-of select="substring-before($fileref.att, '#')"/>
-      </xsl:when>
-      <xsl:otherwise>
-        <xsl:value-of select="$fileref.att"/>
-      </xsl:otherwise>
-    </xsl:choose>
-  </xsl:variable>
-
-  <xsl:variable name="fileref">
-    <xsl:choose>
-      <xsl:when test="$resource/ancestor::d:resources/@xml:base">
-        <xsl:value-of 
-            select="concat($resource/ancestor::d:resources[@xml:base][1]/@xml:base,
-                                 '/', $filename)"/>
-      </xsl:when>
-      <xsl:otherwise>
-        <xsl:value-of select="$filename"/>
-      </xsl:otherwise>
-    </xsl:choose>
-  </xsl:variable>
-
-  <xsl:choose>
-    <xsl:when test="string-length($fileref) = 0">
-      <!-- A resource without @fileref gets its content copied -->
-      <xsl:apply-templates select="$resource/node()" mode="copycontent"/>
-    </xsl:when>
-    <xsl:otherwise>
-
-      <xsl:variable name="ref.file.content" select="document($fileref,/)"/>
-    
-      <!-- selects root or fragmeht depending on if $fragment is blank -->
-      <xsl:variable name="ref.content"
-        select="$ref.file.content/*[1][$fragment.id = ''] |
-                $ref.file.content/*[1][$fragment.id != '']/
-                   descendant-or-self::*[@xml:id = $fragment.id]"/>
-        
-      <xsl:if test="count($ref.content) = 0">
-        <xsl:message terminate="yes">
-          <xsl:text>ERROR: @fileref = '</xsl:text>
-          <xsl:value-of select="$fileref"/>
-          <xsl:text>' has no content or is unresolved.</xsl:text>
-        </xsl:message>
-      </xsl:if>
-
-      <xsl:variable name="element.name">
-        <xsl:apply-templates select="." mode="compute.element.name">
-          <xsl:with-param name="ref.name" select="local-name($ref.content)"/>
-        </xsl:apply-templates>
-      </xsl:variable>
-
-      <xsl:variable name="omittitles.property">
-        <xsl:call-template name="compute.output.value">
-          <xsl:with-param name="property">omittitles</xsl:with-param>
-        </xsl:call-template>
-      </xsl:variable>
-    
-      <xsl:variable name="contentonly.property">
-        <xsl:call-template name="compute.output.value">
-          <xsl:with-param name="property">contentonly</xsl:with-param>
-        </xsl:call-template>
-      </xsl:variable>
-    
-      <xsl:choose>
-        <xsl:when test="$contentonly.property = 'true' or 
-                        $contentonly.property = 'yes' or
-                        $contentonly.property = '1'">
-          <xsl:apply-templates select="$ref.content/node()" mode="copycontent">
-            <xsl:with-param name="omittitles" select="$omittitles.property"/>
-          </xsl:apply-templates>
-        </xsl:when>
-        <!-- use xsl:copy if using the ref element itself to get its namespaces -->
-        <xsl:when test="$element.name = local-name($ref.content)">
-          <!-- must use for-each to set context node for xsl:copy -->
-          <xsl:for-each select="$ref.content">
-            <xsl:copy>
-              <xsl:copy-of select="@*[not(name() = 'xml:id')]"/>
-              <xsl:choose>
-                <!-- Use the module's xml:id if it has one -->
-                <xsl:when test="$module/@xml:id">
-                  <xsl:attribute name="xml:id">
-                    <xsl:value-of select="$module/@xml:id"/>
-                  </xsl:attribute>
-                </xsl:when>
-                <!-- otherwise use the resource's id -->
-                <xsl:otherwise>
-                  <xsl:copy-of select="@xml:id"/>
-                </xsl:otherwise>
-              </xsl:choose>
-          
-              <xsl:call-template name="merge.info">
-                <xsl:with-param name="merge.element" select="$module/d:merge"/>
-                <xsl:with-param name="ref.content" select="$ref.content"/>
-                <xsl:with-param name="omittitles" select="$omittitles.property"/>
-              </xsl:call-template>
-      
-              <!-- copy through all but titles, which moved to info -->
-              <xsl:apply-templates select="node()
-                       [not(local-name() = 'title') and
-                        not(local-name() = 'subtitle') and
-                        not(local-name() = 'info') and
-                        not(local-name() = 'titleabbrev')]" mode="copycontent"/>
-          
-              <xsl:apply-templates select="$module/node()"> 
-                <xsl:with-param name="parent" select="$element.name"/>
-              </xsl:apply-templates>
-            </xsl:copy>
-          </xsl:for-each>
-        </xsl:when>
-        <xsl:otherwise>
-          <!-- create the element instead of copying it -->
-          <xsl:element name="{$element.name}" namespace="http://docbook.org/ns/docbook">
-            <xsl:copy-of select="$ref.content/@*[not(name() = 'xml:id')]"/>
-            <xsl:choose>
-              <!-- Use the module's xml:id if it has one -->
-              <xsl:when test="@xml:id">
-                <xsl:attribute name="xml:id">
-                  <xsl:value-of select="@xml:id"/>
-                </xsl:attribute>
-              </xsl:when>
-              <!-- otherwise use the resource's id -->
-              <xsl:when test="$ref.content/@xml:id">
-                <xsl:attribute name="xml:id">
-                  <xsl:value-of select="$ref.content/@xml:id"/>
-                </xsl:attribute>
-              </xsl:when>
-            </xsl:choose>
-        
-            <xsl:call-template name="merge.info">
-              <xsl:with-param name="merge.element" select="d:merge"/>
-              <xsl:with-param name="ref.content" select="$ref.content"/>
-              <xsl:with-param name="omittitles" select="$omittitles.property"/>
-            </xsl:call-template>
-    
-            <!-- copy through all but titles, which moved to info -->
-            <xsl:apply-templates select="$ref.content/node()
-                     [not(local-name() = 'title') and
-                      not(local-name() = 'subtitle') and
-                      not(local-name() = 'info') and
-                      not(local-name() = 'titleabbrev')]" mode="copycontent"/>
-        
-            <xsl:apply-templates> 
-              <xsl:with-param name="parent" select="$element.name"/>
-            </xsl:apply-templates>
-          </xsl:element>
-        </xsl:otherwise>
-      </xsl:choose>
-    </xsl:otherwise>
-  </xsl:choose>
-</xsl:template>
-
-<xsl:template name="merge.info">
-  <xsl:param name="merge.element" select="NOTANODE"/>
-  <xsl:param name="ref.content" select="NOTANODE"/>
-  <xsl:param name="omittitles"/> 
-
-  <!-- a merge element may use resourceref as well as literal content -->
-  <!-- any literal content overrides the merge resourceref content -->
-  <xsl:variable name="merge.ref.content">
-    <xsl:if test="$merge.element/@resourceref">
-      <xsl:variable name="resourceref" select="$merge.element/@resourceref"/>
-      <xsl:variable name="resource" select="key('id', $resourceref)"/>
-
-      <xsl:choose>
-        <xsl:when test="not($resource)">
-          <xsl:message terminate="yes">
-            <xsl:text>ERROR: no xml:id matches @resourceref = '</xsl:text>
-            <xsl:value-of select="$resourceref"/>
-            <xsl:text>'.</xsl:text>
-          </xsl:message>
-        </xsl:when>
-        <xsl:when test="not($resource/self::d:resource)">
-          <xsl:message terminate="yes">
-            <xsl:text>ERROR: xml:id matching @resourceref = '</xsl:text>
-            <xsl:value-of select="$resourceref"/>
-            <xsl:text> is not a resource element'.</xsl:text>
-          </xsl:message>
-        </xsl:when>
-      </xsl:choose>
-
-      <xsl:variable name="fileref.att" select="$resource/@fileref"/>
-
-      <xsl:variable name="fileref">
-        <xsl:choose>
-          <xsl:when test="$resource/ancestor::d:resources/@xml:base">
-            <xsl:value-of 
-                select="concat($resource/ancestor::d:resources[@xml:base][1]/@xml:base,
-                               '/', $fileref.att)"/>
-          </xsl:when>
-          <xsl:otherwise>
-            <xsl:value-of select="$fileref.att"/>
-          </xsl:otherwise>
-        </xsl:choose>
-      </xsl:variable>
-
-      <xsl:if test="string-length($fileref) != 0">
-        <xsl:copy-of select="document($fileref,/)"/>
-      </xsl:if>
-    </xsl:if>
-  </xsl:variable>
-
-  <xsl:variable name="merge.ref.info" 
-                select="exsl:node-set($merge.ref.content)//d:info[1]"/>
-
-  <xsl:if test="$merge.element/@resourceref and not($merge.ref.info)">
-    <xsl:message terminate="yes">
-      <xsl:text>ERROR: merge element with resourceref '</xsl:text>
-      <xsl:value-of select="$merge.element/@resourceref"/>
-      <xsl:text>' must point to something with an info element.'</xsl:text>
-    </xsl:message>
-  </xsl:if>
-
-  <xsl:variable name="omittitles.boolean">
-    <xsl:choose>
-      <xsl:when test="$omittitles = 'yes' or $omittitles = 'true' or omittitles = '1'">
-        <xsl:value-of select="1"/>
-      </xsl:when>
-      <xsl:otherwise>
-        <xsl:value-of select="0"/>
-      </xsl:otherwise>
-    </xsl:choose>
-  </xsl:variable>
-  <!-- output info if there is any -->
-  <xsl:if test="$merge.element/node() or 
-                $merge.ref.info/node() or
-                $ref.content/d:info/node() or
-                $ref.content/d:title[$omittitles.boolean = 0] or
-                $ref.content/d:subtitle[$omittitles.boolean = 0] or
-                $ref.content/d:titleabbrev[$omittitles.boolean = 0]">
-
-    <xsl:variable name="ref.info" select="$ref.content/d:info"/>
-    <xsl:variable name="ref.title" select="$ref.content/d:title"/>
-    <xsl:variable name="ref.subtitle" select="$ref.content/d:subtitle"/>
-    <xsl:variable name="ref.titleabbrev" select="$ref.content/d:titleabbrev"/>
-    <xsl:variable name="ref.info.title" select="$ref.content/d:info/d:title"/>
-    <xsl:variable name="ref.info.subtitle" select="$ref.content/d:info/d:subtitle"/>
-    <xsl:variable name="ref.info.titleabbrev" select="$ref.content/d:info/d:titleabbrev"/>
-
-    <info>
-      <!-- First copy through any merge attributes and elements and comments -->
-      <xsl:copy-of select="$merge.element/@*[not(local-name(.) = 'resourceref')]"/>
-
-      <!-- And copy any resource info attributes not in merge-->
-      <xsl:for-each select="$ref.info/@*">
-        <xsl:variable name="resource.att" select="local-name(.)"/>
-        <xsl:choose>
-          <xsl:when test="$merge.element/@*[local-name(.) = $resource.att]">
-            <!-- do nothing because overridden -->
-          </xsl:when>
-          <xsl:otherwise>
-            <!-- copy through if not overridden -->
-            <xsl:copy-of select="."/>
-          </xsl:otherwise>
-        </xsl:choose>
-      </xsl:for-each>
-
-      <!-- Copy through the merge children as they have highest priority -->
-      <xsl:copy-of select="$merge.element/node()"/>
-
-      <!-- and copy through those merge resource elements not in merge element -->
-      <xsl:for-each select="$merge.ref.info/node()">
-        <xsl:variable name="resource.node" select="local-name(.)"/>
-        <xsl:choose>
-          <xsl:when test="$merge.element/node()[local-name(.) = $resource.node]">
-            <!-- do nothing because overridden -->
-          </xsl:when>
-          <xsl:otherwise>
-            <!-- copy through -->
-            <xsl:copy-of select="."/>
-          </xsl:otherwise>
-        </xsl:choose>
-      </xsl:for-each>
-
-      <!-- And copy any module's resource info node not in merge or merge.ref -->
-      <xsl:for-each select="$ref.info/node() | 
-                            $ref.title[$omittitles.boolean = 0] |
-                            $ref.subtitle[$omittitles.boolean = 0] |
-                            $ref.titleabbrev[$omittitles.boolean = 0] |
-                            $ref.info.title[$omittitles.boolean = 0] |
-                            $ref.info.subtitle[$omittitles.boolean = 0] |
-                            $ref.info.titleabbrev[$omittitles.boolean = 0]">
-        <xsl:variable name="resource.node" select="local-name(.)"/>
-        <xsl:choose>
-          <xsl:when test="$merge.element/node()[local-name(.) = $resource.node]">
-            <!-- do nothing because overridden -->
-          </xsl:when>
-          <xsl:when test="$merge.ref.info/node()[local-name(.) = $resource.node]">
-            <!-- do nothing because overridden -->
-          </xsl:when>
-          <xsl:otherwise>
-            <!-- copy through -->
-            <xsl:copy-of select="."/>
-          </xsl:otherwise>
-        </xsl:choose>
-      </xsl:for-each>
-
-    </info>
-  </xsl:if>
-</xsl:template>
-
-<xsl:template match="d:relationships">
-  <xsl:message>
-    <xsl:text>WARNING: the &lt;relationships&gt; element is not currently </xsl:text>
-    <xsl:text>supported by this stylesheet.</xsl:text>
-  </xsl:message>
-</xsl:template>
-
-<xsl:template match="d:transforms">
-  <xsl:message>
-    <xsl:text>WARNING: the &lt;transforms&gt; element is not currently </xsl:text>
-    <xsl:text>supported by this stylesheet.</xsl:text>
-  </xsl:message>
-</xsl:template>
-
-<xsl:template match="d:filterin">
-  <xsl:message>
-    <xsl:text>WARNING: the &lt;filterin&gt; element is not currently </xsl:text>
-    <xsl:text>supported by this stylesheet.</xsl:text>
-  </xsl:message>
-</xsl:template>
-
-<xsl:template match="d:filterout">
-  <xsl:message>
-    <xsl:text>WARNING: the &lt;filterin&gt; element is not currently </xsl:text>
-    <xsl:text>supported by this stylesheet.</xsl:text>
-  </xsl:message>
-</xsl:template>
-
-</xsl:stylesheet>

+ 0 - 11035
stylesheets/lfs-xsl/docbook-xsl-1.78.1/assembly/schema/assembly51b7.rnc

@@ -1,11035 +0,0 @@
-namespace a = "http://relaxng.org/ns/compatibility/annotations/1.0"
-namespace ctrl = "http://nwalsh.com/xmlns/schema-control/"
-default namespace db = "http://docbook.org/ns/docbook"
-namespace html = "http://www.w3.org/1999/xhtml"
-namespace mml = "http://www.w3.org/1998/Math/MathML"
-namespace rng = "http://relaxng.org/ns/structure/1.0"
-namespace s = "http://purl.oclc.org/dsdl/schematron"
-namespace svg = "http://www.w3.org/2000/svg"
-namespace xlink = "http://www.w3.org/1999/xlink"
-
-# This file is part of DocBook Assembly V5.1b7
-# 
-# Copyright 2008-2011 HaL Computer Systems, Inc.,
-# O'Reilly & Associates, Inc., ArborText, Inc., Fujitsu Software
-# Corporation, Norman Walsh, Sun Microsystems, Inc., and the
-# Organization for the Advancement of Structured Information
-# Standards (OASIS).
-# 
-# Permission to use, copy, modify and distribute the DocBook schema
-# and its accompanying documentation for any purpose and without fee
-# is hereby granted in perpetuity, provided that the above copyright
-# notice and this paragraph appear in all copies. The copyright
-# holders make no representation about the suitability of the schema
-# for any purpose. It is provided "as is" without expressed or implied
-# warranty.
-# 
-# If you modify the DocBook schema in any way, label your schema as a
-# variant of DocBook. See the reference documentation
-# (http://docbook.org/tdg5/en/html/ch05.html#s-notdocbook)
-# for more information.
-# 
-# Please direct all questions, bug reports, or suggestions for changes
-# to the docbook@lists.oasis-open.org mailing list. For more
-# information, see http://www.oasis-open.org/docbook/.
-# 
-# ======================================================================
-div {
-  db._any.attribute =
-    
-    ## Any attribute, including any attribute in any namespace.
-    attribute * { text }
-  db._any =
-    
-    ## Any element from almost any namespace
-    element * - (db:* | html:*) {
-      (db._any.attribute | text | db._any)*
-    }
-}
-db.arch.attribute =
-  
-  ## Designates the computer or chip architecture to which the element applies
-  attribute arch { text }
-db.audience.attribute =
-  
-  ## Designates the intended audience to which the element applies, for example, system administrators, programmers, or new users.
-  attribute audience { text }
-db.condition.attribute =
-  
-  ## provides a standard place for application-specific effectivity
-  attribute condition { text }
-db.conformance.attribute =
-  
-  ## Indicates standards conformance characteristics of the element
-  attribute conformance { text }
-db.os.attribute =
-  
-  ## Indicates the operating system to which the element is applicable
-  attribute os { text }
-db.revision.attribute =
-  
-  ## Indicates the editorial revision to which the element belongs
-  attribute revision { text }
-db.security.attribute =
-  
-  ## Indicates something about the security level associated with the element to which it applies
-  attribute security { text }
-db.userlevel.attribute =
-  
-  ## Indicates the level of user experience for which the element applies
-  attribute userlevel { text }
-db.vendor.attribute =
-  
-  ## Indicates the computer vendor to which the element applies.
-  attribute vendor { text }
-db.wordsize.attribute =
-  
-  ## Indicates the word size (width in bits) of the computer architecture to which the element applies
-  attribute wordsize { text }
-db.effectivity.attributes =
-  db.arch.attribute?
-  & db.audience.attribute?
-  & db.condition.attribute?
-  & db.conformance.attribute?
-  & db.os.attribute?
-  & db.revision.attribute?
-  & db.security.attribute?
-  & db.userlevel.attribute?
-  & db.vendor.attribute?
-  & db.wordsize.attribute?
-db.endterm.attribute =
-  
-  ## Points to the element whose content is to be used as the text of the link
-  attribute endterm { xsd:IDREF }
-db.linkend.attribute =
-  
-  ## Points to an internal link target by identifying the value of its xml:id attribute
-  attribute linkend { xsd:IDREF }
-db.linkends.attribute =
-  
-  ## Points to one or more internal link targets by identifying the value of their xml:id attributes
-  attribute linkends { xsd:IDREFS }
-db.xlink.href.attribute =
-  
-  ## Identifies a link target with a URI
-  attribute xlink:href { xsd:anyURI }
-db.xlink.simple.type.attribute =
-  
-  ## Identifies the XLink link type
-  attribute xlink:type {
-    
-    ## An XLink simple link type
-    "simple"
-  }
-db.xlink.role.attribute =
-  
-  ## Identifies the XLink role of the link
-  attribute xlink:role { xsd:anyURI }
-db.xlink.arcrole.attribute =
-  
-  ## Identifies the XLink arcrole of the link
-  attribute xlink:arcrole { xsd:anyURI }
-db.xlink.title.attribute =
-  
-  ## Identifies the XLink title of the link
-  attribute xlink:title { text }
-db.xlink.show.enumeration =
-  
-  ## An application traversing to the ending resource should load it in a new window, frame, pane, or other relevant presentation context.
-  "new"
-  | 
-    ## An application traversing to the ending resource should load the resource in the same window, frame, pane, or other relevant presentation context in which the starting resource was loaded.
-    "replace"
-  | 
-    ## An application traversing to the ending resource should load its presentation in place of the presentation of the starting resource.
-    "embed"
-  | 
-    ## The behavior of an application traversing to the ending resource is unconstrained by XLink. The application should look for other markup present in the link to determine the appropriate behavior.
-    "other"
-  | 
-    ## The behavior of an application traversing to the ending resource is unconstrained by this specification. No other markup is present to help the application determine the appropriate behavior.
-    "none"
-db.xlink.show.attribute =
-  
-  ## Identifies the XLink show behavior of the link
-  attribute xlink:show { db.xlink.show.enumeration }
-db.xlink.actuate.enumeration =
-  
-  ## An application should traverse to the ending resource immediately on loading the starting resource.
-  "onLoad"
-  | 
-    ## An application should traverse from the starting resource to the ending resource only on a post-loading event triggered for the purpose of traversal.
-    "onRequest"
-  | 
-    ## The behavior of an application traversing to the ending resource is unconstrained by this specification. The application should look for other markup present in the link to determine the appropriate behavior.
-    "other"
-  | 
-    ## The behavior of an application traversing to the ending resource is unconstrained by this specification. No other markup is present to help the application determine the appropriate behavior.
-    "none"
-db.xlink.actuate.attribute =
-  
-  ## Identifies the XLink actuate behavior of the link
-  attribute xlink:actuate { db.xlink.actuate.enumeration }
-db.xlink.simple.link.attributes =
-  db.xlink.simple.type.attribute?
-  & db.xlink.href.attribute?
-  & db.xlink.role.attribute?
-  & db.xlink.arcrole.attribute?
-  & db.xlink.title.attribute?
-  & db.xlink.show.attribute?
-  & db.xlink.actuate.attribute?
-db.xlink.attributes =
-  db.xlink.simple.link.attributes
-  | (db.xlink.extended.link.attributes
-     | db.xlink.locator.link.attributes
-     | db.xlink.arc.link.attributes
-     | db.xlink.resource.link.attributes
-     | db.xlink.title.link.attributes)
-db.xml.id.attribute =
-  
-  ## Identifies the unique ID value of the element
-  attribute xml:id { xsd:ID }
-db.version.attribute =
-  
-  ## Specifies the DocBook version of the element and its descendants
-  attribute version { text }
-db.xml.lang.attribute =
-  
-  ## Specifies the natural language of the element and its descendants
-  attribute xml:lang { text }
-db.xml.base.attribute =
-  
-  ## Specifies the base URI of the element and its descendants
-  attribute xml:base { xsd:anyURI }
-db.remap.attribute =
-  
-  ## Provides the name or similar semantic identifier assigned to the content in some previous markup scheme
-  attribute remap { text }
-db.xreflabel.attribute =
-  
-  ## Provides the text that is to be generated for a cross reference to the element
-  attribute xreflabel { text }
-db.xrefstyle.attribute =
-  
-  ## Specifies a keyword or keywords identifying additional style information
-  attribute xrefstyle { text }
-db.revisionflag.enumeration =
-  
-  ## The element has been changed.
-  "changed"
-  | 
-    ## The element is new (has been added to the document).
-    "added"
-  | 
-    ## The element has been deleted.
-    "deleted"
-  | 
-    ## Explicitly turns off revision markup for this element.
-    "off"
-db.revisionflag.attribute =
-  
-  ## Identifies the revision status of the element
-  attribute revisionflag { db.revisionflag.enumeration }
-db.dir.enumeration =
-  
-  ## Left-to-right text
-  "ltr"
-  | 
-    ## Right-to-left text
-    "rtl"
-  | 
-    ## Left-to-right override
-    "lro"
-  | 
-    ## Right-to-left override
-    "rlo"
-db.dir.attribute =
-  
-  ## Identifies the direction of text in an element
-  attribute dir { db.dir.enumeration }
-db.common.base.attributes =
-  db.version.attribute?
-  & db.xml.lang.attribute?
-  & db.xml.base.attribute?
-  & db.remap.attribute?
-  & db.xreflabel.attribute?
-  & db.revisionflag.attribute?
-  & db.dir.attribute?
-  & db.effectivity.attributes
-db.common.attributes =
-  db.xml.id.attribute?
-  & db.common.base.attributes
-  & db.annotations.attribute?
-db.common.idreq.attributes =
-  db.xml.id.attribute
-  & db.common.base.attributes
-  & db.annotations.attribute?
-db.common.linking.attributes =
-  (db.linkend.attribute | db.xlink.attributes)?
-db.common.req.linking.attributes =
-  db.linkend.attribute | db.xlink.attributes
-db.common.data.attributes =
-  
-  ## Specifies the format of the data
-  attribute format { text }?,
-  (
-   ## Indentifies the location of the data by URI
-   attribute fileref { xsd:anyURI }
-   | 
-     ## Identifies the location of the data by external identifier (entity name)
-     attribute entityref { xsd:ENTITY })
-db.verbatim.continuation.enumeration =
-  
-  ## Line numbering continues from the immediately preceding element with the same name.
-  "continues"
-  | 
-    ## Line numbering restarts (begins at 1, usually).
-    "restarts"
-db.verbatim.continuation.attribute =
-  
-  ## Determines whether line numbering continues from the previous element or restarts.
-  attribute continuation { db.verbatim.continuation.enumeration }
-db.verbatim.linenumbering.enumeration =
-  
-  ## Lines are numbered.
-  "numbered"
-  | 
-    ## Lines are not numbered.
-    "unnumbered"
-db.verbatim.linenumbering.attribute =
-  
-  ## Determines whether lines are numbered.
-  attribute linenumbering { db.verbatim.linenumbering.enumeration }
-db.verbatim.startinglinenumber.attribute =
-  
-  ## Specifies the initial line number.
-  attribute startinglinenumber { xsd:integer }
-db.verbatim.language.attribute =
-  
-  ## Identifies the language (i.e. programming language) of the verbatim content.
-  attribute language { text }
-db.verbatim.xml.space.attribute =
-  
-  ## Can be used to indicate explicitly that whitespace in the verbatim environment is preserved. Whitespace must always be preserved in verbatim environments whether this attribute is specified or not.
-  attribute xml:space {
-    
-    ## Whitespace must be preserved.
-    "preserve"
-  }
-db.verbatim.common.attributes =
-  db.verbatim.continuation.attribute?
-  & db.verbatim.linenumbering.attribute?
-  & db.verbatim.startinglinenumber.attribute?
-  & db.verbatim.xml.space.attribute?
-db.verbatim.attributes =
-  db.verbatim.common.attributes & db.verbatim.language.attribute?
-db.label.attribute =
-  
-  ## Specifies an identifying string for presentation purposes
-  attribute label { text }
-db.width.characters.attribute =
-  
-  ## Specifies the width (in characters) of the element
-  attribute width { xsd:nonNegativeInteger }
-db.spacing.enumeration =
-  
-  ## The spacing should be "compact".
-  "compact"
-  | 
-    ## The spacing should be "normal".
-    "normal"
-db.spacing.attribute =
-  
-  ## Specifies (a hint about) the spacing of the content
-  attribute spacing { db.spacing.enumeration }
-db.pgwide.enumeration =
-  
-  ## The element should be rendered in the current text flow (with the flow column width).
-  "0"
-  | 
-    ## The element should be rendered across the full text page.
-    "1"
-db.pgwide.attribute =
-  
-  ## Indicates if the element is rendered across the column or the page
-  attribute pgwide { db.pgwide.enumeration }
-db.language.attribute =
-  
-  ## Identifies the language (i.e. programming language) of the content.
-  attribute language { text }
-db.performance.enumeration =
-  
-  ## The content describes an optional step or steps.
-  "optional"
-  | 
-    ## The content describes a required step or steps.
-    "required"
-db.performance.attribute =
-  
-  ## Specifies if the content is required or optional.
-  attribute performance { db.performance.enumeration }
-db.floatstyle.attribute =
-  
-  ## Specifies style information to be used when rendering the float
-  attribute floatstyle { text }
-db.width.attribute =
-  
-  ## Specifies the width of the element
-  attribute width { text }
-db.depth.attribute =
-  
-  ## Specifies the depth of the element
-  attribute depth { text }
-db.contentwidth.attribute =
-  
-  ## Specifies the width of the content rectangle
-  attribute contentwidth { text }
-db.contentdepth.attribute =
-  
-  ## Specifies the depth of the content rectangle
-  attribute contentdepth { text }
-db.scalefit.enumeration =
-  
-  ## False (do not scale-to-fit; anamorphic scaling may occur)
-  "0"
-  | 
-    ## True (scale-to-fit; anamorphic scaling is forbidden)
-    "1"
-db.scale.attribute =
-  
-  ## Specifies the scaling factor
-  attribute scale { xsd:positiveInteger }
-db.classid.attribute =
-  
-  ## Specifies a classid for a media object player
-  attribute classid { text }
-db.autoplay.attribute =
-  
-  ## Specifies the autoplay setting for a media object player
-  attribute autoplay { text }
-db.halign.enumeration =
-  
-  ## Centered horizontally
-  "center"
-  | 
-    ## Aligned horizontally on the specified character
-    "char"
-  | 
-    ## Fully justified (left and right margins or edges)
-    "justify"
-  | 
-    ## Left aligned
-    "left"
-  | 
-    ## Right aligned
-    "right"
-db.valign.enumeration =
-  
-  ## Aligned on the bottom of the region
-  "bottom"
-  | 
-    ## Centered vertically
-    "middle"
-  | 
-    ## Aligned on the top of the region
-    "top"
-db.biblio.class.enumeration =
-  
-  ## A digital object identifier.
-  "doi"
-  | 
-    ## An international standard book number.
-    "isbn"
-  | 
-    ## An international standard technical report number (ISO 10444).
-    "isrn"
-  | 
-    ## An international standard serial number.
-    "issn"
-  | 
-    ## An international standard text code.
-    "istc"
-  | 
-    ## A Library of Congress reference number.
-    "libraryofcongress"
-  | 
-    ## A publication number (an internal number or possibly organizational standard).
-    "pubsnumber"
-  | 
-    ## A Uniform Resource Identifier
-    "uri"
-db.biblio.class-enum.attribute =
-  
-  ## Identifies the kind of bibliographic identifier
-  attribute class { db.biblio.class.enumeration }?
-db.biblio.class-other.attribute =
-  
-  ## Identifies the nature of the non-standard bibliographic identifier
-  attribute otherclass { xsd:NMTOKEN }
-db.biblio.class-other.attributes =
-  
-  ## Identifies the kind of bibliographic identifier
-  attribute class {
-    
-    ## Indicates that the identifier is some 'other' kind.
-    "other"
-  }
-  & db.biblio.class-other.attribute
-db.biblio.class.attribute =
-  db.biblio.class-enum.attribute | db.biblio.class-other.attributes
-db.ubiq.inlines =
-  (db.inlinemediaobject
-   | db.remark
-   | db.link.inlines
-   | db.alt
-   | db.trademark
-   | # below, effectively the publishing inlines (as of 5.0)
-     db.abbrev
-   | db.acronym
-   | db.date
-   | db._emphasis
-   | db.footnote
-   | db.footnoteref
-   | db._foreignphrase
-   | db._phrase
-   | db._quote
-   | db.subscript
-   | db.superscript
-   | db.wordasword)
-  | db.annotation
-  | (db._firstterm | db._glossterm)
-  | db.indexterm
-  | db.coref
-db._text = (text | db.ubiq.inlines | db._phrase | db.replaceable)*
-db._title = db.title? & db.titleabbrev? & db.subtitle?
-db._title.req = db.title & db.titleabbrev? & db.subtitle?
-db._title.only = db.title? & db.titleabbrev?
-db._title.onlyreq = db.title & db.titleabbrev?
-db._info = (db._title, db.titleforbidden.info?) | db.info?
-db._info.title.req =
-  (db._title.req, db.titleforbidden.info?) | db.titlereq.info
-db._info.title.only =
-  (db._title.only, db.titleforbidden.info?) | db.titleonly.info
-db._info.title.onlyreq =
-  (db._title.onlyreq, db.titleforbidden.info?) | db.titleonlyreq.info
-db._info.title.forbidden = db.titleforbidden.info?
-db.all.inlines =
-  text | db.ubiq.inlines | db.general.inlines | db.domain.inlines
-db.general.inlines =
-  db.publishing.inlines
-  | db.product.inlines
-  | db.bibliography.inlines
-  | db.graphic.inlines
-  | db.indexing.inlines
-  | db.link.inlines
-db.domain.inlines =
-  db.technical.inlines
-  | db.math.inlines
-  | db.markup.inlines
-  | db.gui.inlines
-  | db.keyboard.inlines
-  | db.os.inlines
-  | db.programming.inlines
-  | db.error.inlines
-db.technical.inlines =
-  (db.replaceable | db.package | db.parameter)
-  | db.termdef
-  | db.nonterminal
-  | (db.systemitem | db.option | db.optional | db.property)
-db.product.inlines =
-  db.trademark
-  | (db.productnumber
-     | db.productname
-     | db.database
-     | db.application
-     | db.hardware)
-db.bibliography.inlines =
-  db.citation
-  | db.citerefentry
-  | db.citetitle
-  | db.citebiblioid
-  | db.author
-  | db.person
-  | db.personname
-  | db.org
-  | db.orgname
-  | db.editor
-  | db.jobtitle
-db.publishing.inlines =
-  (db.abbrev
-   | db.acronym
-   | db.date
-   | db.emphasis
-   | db.footnote
-   | db.footnoteref
-   | db.foreignphrase
-   | db.phrase
-   | db.quote
-   | db.subscript
-   | db.superscript
-   | db.wordasword)
-  | db.glossary.inlines
-  | db.coref
-db.graphic.inlines = db.inlinemediaobject
-db.indexing.inlines = notAllowed | db.indexterm
-db.link.inlines =
-  (db.xref | db.link | db.olink | db.anchor) | db.biblioref
-db.nopara.blocks =
-  (db.list.blocks
-   | db.formal.blocks
-   | db.informal.blocks
-   | db.publishing.blocks
-   | db.graphic.blocks
-   | db.technical.blocks
-   | db.verbatim.blocks
-   | db.bridgehead
-   | db.remark
-   | db.revhistory)
-  | db.indexterm
-  | db.synopsis.blocks
-  | db.admonition.blocks
-db.para.blocks = db.anchor | db.para | db.formalpara | db.simpara
-db.all.blocks = (db.nopara.blocks | db.para.blocks) | db.annotation
-db.formal.blocks = (db.example | db.figure | db.table) | db.equation
-db.informal.blocks =
-  (db.informalexample | db.informalfigure | db.informaltable)
-  | db.informalequation
-db.publishing.blocks =
-  db.sidebar | db.blockquote | db.address | db.epigraph
-db.graphic.blocks = db.mediaobject | db.screenshot
-db.technical.blocks =
-  db.procedure
-  | db.task
-  | (db.productionset | db.constraintdef)
-  | db.msgset
-db.list.blocks =
-  (db.itemizedlist
-   | db.orderedlist
-   | db.procedure
-   | db.simplelist
-   | db.variablelist
-   | db.segmentedlist)
-  | db.glosslist
-  | db.bibliolist
-  | db.calloutlist
-  | db.qandaset
-db.verbatim.blocks =
-  (db.screen | db.literallayout)
-  | (db.programlistingco | db.screenco)
-  | (db.programlisting | db.synopsis)
-db.info.extension = db._any
-db.info.elements =
-  (db.abstract
-   | db.address
-   | db.artpagenums
-   | db.author
-   | db.authorgroup
-   | db.authorinitials
-   | db.bibliocoverage
-   | db.biblioid
-   | db.bibliosource
-   | db.collab
-   | db.confgroup
-   | db.contractsponsor
-   | db.contractnum
-   | db.copyright
-   | db.cover
-   | db.date
-   | db.edition
-   | db.editor
-   | db.issuenum
-   | db.keywordset
-   | db.legalnotice
-   | db.mediaobject
-   | db.org
-   | db.orgname
-   | db.othercredit
-   | db.pagenums
-   | db.printhistory
-   | db.pubdate
-   | db.publisher
-   | db.publishername
-   | db.releaseinfo
-   | db.revhistory
-   | db.seriesvolnums
-   | db.subjectset
-   | db.volumenum
-   | db.info.extension)
-  | db.annotation
-  | db.extendedlink
-  | (db.bibliomisc | db.bibliomset | db.bibliorelation | db.biblioset)
-  | db.itermset
-  | (db.productname | db.productnumber)
-db.bibliographic.elements =
-  db.info.elements
-  | db.publishing.inlines
-  | db.citerefentry
-  | db.citetitle
-  | db.citebiblioid
-  | db.person
-  | db.personblurb
-  | db.personname
-  | db.subtitle
-  | db.title
-  | db.titleabbrev
-div {
-  db.title.role.attribute = attribute role { text }
-  db.title.attlist =
-    db.title.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.title =
-    
-    ## The text of the title of a section of a document or of a formal block-level element
-    element title { db.title.attlist, db.all.inlines* }
-}
-div {
-  db.titleabbrev.role.attribute = attribute role { text }
-  db.titleabbrev.attlist =
-    db.titleabbrev.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.titleabbrev =
-    
-    ## The abbreviation of a title
-    element titleabbrev { db.titleabbrev.attlist, db.all.inlines* }
-}
-div {
-  db.subtitle.role.attribute = attribute role { text }
-  db.subtitle.attlist =
-    db.subtitle.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.subtitle =
-    
-    ## The subtitle of a document
-    element subtitle { db.subtitle.attlist, db.all.inlines* }
-}
-div {
-  db.info.role.attribute = attribute role { text }
-  db.info.attlist = db.info.role.attribute? & db.common.attributes
-  db.info =
-    
-    ## A wrapper for information about a component or other block
-    element info { db.info.attlist, (db._title & db.info.elements*) }
-}
-div {
-  db.titlereq.info.role.attribute = attribute role { text }
-  db.titlereq.info.attlist =
-    db.titlereq.info.role.attribute? & db.common.attributes
-  db.titlereq.info =
-    
-    ## A wrapper for information about a component or other block with a required title
-    element info {
-      db.titlereq.info.attlist, (db._title.req & db.info.elements*)
-    }
-}
-div {
-  db.titleonly.info.role.attribute = attribute role { text }
-  db.titleonly.info.attlist =
-    db.titleonly.info.role.attribute? & db.common.attributes
-  db.titleonly.info =
-    
-    ## A wrapper for information about a component or other block with only a title
-    element info {
-      db.titleonly.info.attlist, (db._title.only & db.info.elements*)
-    }
-}
-div {
-  db.titleonlyreq.info.role.attribute = attribute role { text }
-  db.titleonlyreq.info.attlist =
-    db.titleonlyreq.info.role.attribute? & db.common.attributes
-  db.titleonlyreq.info =
-    
-    ## A wrapper for information about a component or other block with only a required title
-    element info {
-      db.titleonlyreq.info.attlist,
-      (db._title.onlyreq & db.info.elements*)
-    }
-}
-div {
-  db.titleforbidden.info.role.attribute = attribute role { text }
-  db.titleforbidden.info.attlist =
-    db.titleforbidden.info.role.attribute? & db.common.attributes
-  db.titleforbidden.info =
-    
-    ## A wrapper for information about a component or other block without a title
-    element info { db.titleforbidden.info.attlist, db.info.elements* }
-}
-div {
-  db.subjectset.role.attribute = attribute role { text }
-  db.subjectset.scheme.attribute =
-    
-    ## Identifies the controlled vocabulary used by this set's terms
-    attribute scheme { xsd:NMTOKEN }
-  db.subjectset.attlist =
-    db.subjectset.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.subjectset.scheme.attribute?
-  db.subjectset =
-    
-    ## A set of terms describing the subject matter of a document
-    element subjectset { db.subjectset.attlist, db.subject+ }
-}
-div {
-  db.subject.role.attribute = attribute role { text }
-  db.subject.weight.attribute =
-    
-    ## Specifies a ranking for this subject relative to other subjects in the same set
-    attribute weight { text }
-  db.subject.attlist =
-    db.subject.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.subject.weight.attribute?
-  db.subject =
-    
-    ## One of a group of terms describing the subject matter of a document
-    element subject { db.subject.attlist, db.subjectterm+ }
-}
-div {
-  db.subjectterm.role.attribute = attribute role { text }
-  db.subjectterm.attlist =
-    db.subjectterm.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.subjectterm =
-    
-    ## A term in a group of terms describing the subject matter of a document
-    element subjectterm { db.subjectterm.attlist, text }
-}
-div {
-  db.keywordset.role.attribute = attribute role { text }
-  db.keywordset.attlist =
-    db.keywordset.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.keywordset =
-    
-    ## A set of keywords describing the content of a document
-    element keywordset { db.keywordset.attlist, db.keyword+ }
-}
-div {
-  db.keyword.role.attribute = attribute role { text }
-  db.keyword.attlist =
-    db.keyword.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.keyword =
-    
-    ## One of a set of keywords describing the content of a document
-    element keyword { db.keyword.attlist, text }
-}
-db.table.choice = notAllowed | db.cals.table | db.html.table
-db.informaltable.choice =
-  notAllowed | db.cals.informaltable | db.html.informaltable
-db.table = db.table.choice
-db.informaltable = db.informaltable.choice
-div {
-  db.procedure.role.attribute = attribute role { text }
-  db.procedure.attlist =
-    db.procedure.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.procedure.info = db._info.title.only
-  db.procedure =
-    
-    ## A list of operations to be performed in a well-defined sequence
-    element procedure {
-      db.procedure.attlist, db.procedure.info, db.all.blocks*, db.step+
-    }
-}
-div {
-  db.step.role.attribute = attribute role { text }
-  db.step.attlist =
-    db.step.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.performance.attribute?
-  db.step.info = db._info.title.only
-  # This content model is blocks*, step|stepalternatives, blocks* but
-  # expressed this way it avoids UPA issues in XSD and DTD versions
-  db.step =
-    
-    ## A unit of action in a procedure
-    element step {
-      db.step.attlist,
-      db.step.info,
-      ((db.all.blocks+,
-        ((db.substeps | db.stepalternatives), db.all.blocks*)?)
-       | ((db.substeps | db.stepalternatives), db.all.blocks*))
-    }
-}
-div {
-  db.stepalternatives.role.attribute = attribute role { text }
-  db.stepalternatives.attlist =
-    db.stepalternatives.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.performance.attribute?
-  db.stepalternatives.info = db._info.title.forbidden
-  db.stepalternatives =
-    
-    ## Alternative steps in a procedure
-    element stepalternatives {
-      db.stepalternatives.attlist, db.stepalternatives.info, db.step+
-    }
-}
-div {
-  db.substeps.role.attribute = attribute role { text }
-  db.substeps.attlist =
-    db.substeps.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.performance.attribute?
-  db.substeps =
-    
-    ## A wrapper for steps that occur within steps in a procedure
-    element substeps { db.substeps.attlist, db.step+ }
-}
-div {
-  db.sidebar.floatstyle.attribute = db.floatstyle.attribute
-  db.sidebar.role.attribute = attribute role { text }
-  db.sidebar.attlist =
-    db.sidebar.role.attribute?
-    & db.sidebar.floatstyle.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.sidebar.info = db._info
-  db.sidebar =
-    
-    ## A portion of a document that is isolated from the main narrative flow
-    [
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:sidebar"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:sidebar)"
-            "sidebar must not occur among the children or descendants of sidebar"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element sidebar {
-      db.sidebar.attlist, db.sidebar.info, db.all.blocks+
-    }
-}
-div {
-  db.abstract.role.attribute = attribute role { text }
-  db.abstract.attlist =
-    db.abstract.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.abstract.info = db._info.title.only
-  db.abstract =
-    
-    ## A summary
-    element abstract {
-      db.abstract.attlist, db.abstract.info, db.para.blocks+
-    }
-}
-div {
-  db.personblurb.role.attribute = attribute role { text }
-  db.personblurb.attlist =
-    db.personblurb.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.personblurb.info = db._info.title.only
-  db.personblurb =
-    
-    ## A short description or note about a person
-    element personblurb {
-      db.personblurb.attlist, db.personblurb.info, db.para.blocks+
-    }
-}
-div {
-  db.blockquote.role.attribute = attribute role { text }
-  db.blockquote.attlist =
-    db.blockquote.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.blockquote.info = db._info.title.only
-  db.blockquote =
-    
-    ## A quotation set off from the main text
-    element blockquote {
-      db.blockquote.attlist,
-      db.blockquote.info,
-      db.attribution?,
-      db.all.blocks+
-    }
-}
-div {
-  db.attribution.role.attribute = attribute role { text }
-  db.attribution.attlist =
-    db.attribution.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.attribution =
-    
-    ## The source of a block quote or epigraph
-    element attribution {
-      db.attribution.attlist,
-      (db._text
-       | db.person
-       | db.personname
-       | db.citetitle
-       | db.citation)*
-    }
-}
-div {
-  db.bridgehead.renderas.enumeration =
-    
-    ## Render as a first-level section
-    "sect1"
-    | 
-      ## Render as a second-level section
-      "sect2"
-    | 
-      ## Render as a third-level section
-      "sect3"
-    | 
-      ## Render as a fourth-level section
-      "sect4"
-    | 
-      ## Render as a fifth-level section
-      "sect5"
-  db.bridgehead.renderas-enum.attribute =
-    
-    ## Indicates how the bridge head should be rendered
-    attribute renderas { db.bridgehead.renderas.enumeration }?
-  db.bridgehead.renderas-other.attribute =
-    
-    ## Identifies the nature of the non-standard rendering
-    attribute otherrenderas { xsd:NMTOKEN }
-  db.bridgehead.renderas-other.attributes =
-    
-    ## Indicates how the bridge head should be rendered
-    attribute renderas {
-      
-      ## Identifies a non-standard rendering
-      "other"
-    }
-    & db.bridgehead.renderas-other.attribute
-  db.bridgehead.renderas.attribute =
-    db.bridgehead.renderas-enum.attribute
-    | db.bridgehead.renderas-other.attributes
-  db.bridgehead.role.attribute = attribute role { text }
-  db.bridgehead.attlist =
-    db.bridgehead.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.bridgehead.renderas.attribute?
-  db.bridgehead =
-    
-    ## A free-floating heading
-    element bridgehead { db.bridgehead.attlist, db.all.inlines* }
-}
-div {
-  db.remark.role.attribute = attribute role { text }
-  db.remark.attlist =
-    db.remark.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.remark =
-    
-    ## A remark (or comment) intended for presentation in a draft manuscript
-    element remark { db.remark.attlist, db.all.inlines* }
-}
-div {
-  db.epigraph.role.attribute = attribute role { text }
-  db.epigraph.attlist =
-    db.epigraph.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.epigraph.info = db._info.title.forbidden
-  db.epigraph =
-    
-    ## A short inscription at the beginning of a document or component
-    element epigraph {
-      db.epigraph.attlist,
-      db.epigraph.info,
-      db.attribution?,
-      (db.para.blocks | db.literallayout)+
-    }
-}
-div {
-  db.footnote.role.attribute = attribute role { text }
-  db.footnote.label.attribute =
-    
-    ## Identifies the desired footnote mark
-    attribute label { xsd:NMTOKEN }
-  db.footnote.attlist =
-    db.footnote.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.footnote.label.attribute?
-  db.footnote =
-    
-    ## A footnote
-    [
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:footnote"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:footnote)"
-            "footnote must not occur among the children or descendants of footnote"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:footnote"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:example)"
-            "example must not occur among the children or descendants of footnote"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:footnote"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:figure)"
-            "figure must not occur among the children or descendants of footnote"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:footnote"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:table)"
-            "table must not occur among the children or descendants of footnote"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:footnote"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:equation)"
-            "equation must not occur among the children or descendants of footnote"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:footnote"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:sidebar)"
-            "sidebar must not occur among the children or descendants of footnote"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:footnote"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:task)"
-            "task must not occur among the children or descendants of footnote"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:footnote"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:epigraph)"
-            "epigraph must not occur among the children or descendants of footnote"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:footnote"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:caution)"
-            "caution must not occur among the children or descendants of footnote"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:footnote"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:important)"
-            "important must not occur among the children or descendants of footnote"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:footnote"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:note)"
-            "note must not occur among the children or descendants of footnote"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:footnote"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:tip)"
-            "tip must not occur among the children or descendants of footnote"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:footnote"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:warning)"
-            "warning must not occur among the children or descendants of footnote"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element footnote { db.footnote.attlist, db.all.blocks+ }
-}
-div {
-  db.formalpara.role.attribute = attribute role { text }
-  db.formalpara.attlist =
-    db.formalpara.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.formalpara.info = db._info.title.onlyreq
-  db.formalpara =
-    
-    ## A paragraph with a title
-    element formalpara {
-      db.formalpara.attlist,
-      db.formalpara.info,
-      db.indexing.inlines*,
-      db.para
-    }
-}
-div {
-  db.para.role.attribute = attribute role { text }
-  db.para.attlist =
-    db.para.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.para.info = db._info.title.forbidden
-  db.para =
-    
-    ## A paragraph
-    element para {
-      db.para.attlist,
-      db.para.info,
-      (db.all.inlines | db.nopara.blocks)*
-    }
-}
-div {
-  db.simpara.role.attribute = attribute role { text }
-  db.simpara.attlist =
-    db.simpara.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.simpara.info = db._info.title.forbidden
-  db.simpara =
-    
-    ## A paragraph that contains only text and inline markup, no block elements
-    element simpara {
-      db.simpara.attlist, db.simpara.info, db.all.inlines*
-    }
-}
-div {
-  db.itemizedlist.role.attribute = attribute role { text }
-  db.itemizedlist.mark.attribute =
-    
-    ## Identifies the type of mark to be used on items in this list
-    attribute mark { xsd:NMTOKEN }
-  db.itemizedlist.attlist =
-    db.itemizedlist.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.spacing.attribute?
-    & db.itemizedlist.mark.attribute?
-  db.itemizedlist.info = db._info.title.only
-  db.itemizedlist =
-    
-    ## A list in which each entry is marked with a bullet or other dingbat
-    element itemizedlist {
-      db.itemizedlist.attlist,
-      db.itemizedlist.info,
-      db.all.blocks*,
-      db.listitem+
-    }
-}
-div {
-  db.orderedlist.role.attribute = attribute role { text }
-  db.orderedlist.continuation.enumeration =
-    
-    ## Specifies that numbering should begin where the preceding list left off
-    "continues"
-    | 
-      ## Specifies that numbering should begin again at 1
-      "restarts"
-  db.orderedlist.continuation.attribute =
-    
-    ## Indicates how list numbering should begin relative to the immediately preceding list
-    attribute continuation { db.orderedlist.continuation.enumeration }
-  db.orderedlist.startingnumber.attribute =
-    
-    ## Specifies the initial line number.
-    attribute startingnumber { xsd:integer }
-  db.orderedlist.inheritnum.enumeration =
-    
-    ## Specifies that numbering should ignore list nesting
-    "ignore"
-    | 
-      ## Specifies that numbering should inherit from outer-level lists
-      "inherit"
-  db.orderedlist.inheritnum.attribute =
-    
-    ## Indicates whether or not item numbering should be influenced by list nesting
-    attribute inheritnum { db.orderedlist.inheritnum.enumeration }
-  db.orderedlist.numeration.enumeration =
-    
-    ## Specifies Arabic numeration (1, 2, 3, …)
-    "arabic"
-    | 
-      ## Specifies upper-case alphabetic numeration (A, B, C, …)
-      "upperalpha"
-    | 
-      ## Specifies lower-case alphabetic numeration (a, b, c, …)
-      "loweralpha"
-    | 
-      ## Specifies upper-case Roman numeration (I, II, III, …)
-      "upperroman"
-    | 
-      ## Specifies lower-case Roman numeration (i, ii, iii …)
-      "lowerroman"
-  db.orderedlist.numeration.attribute =
-    
-    ## Indicates the desired numeration
-    attribute numeration { db.orderedlist.numeration.enumeration }
-  db.orderedlist.attlist =
-    db.orderedlist.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.spacing.attribute?
-    & (db.orderedlist.continuation.attribute
-       | db.orderedlist.startingnumber.attribute)?
-    & db.orderedlist.inheritnum.attribute?
-    & db.orderedlist.numeration.attribute?
-  db.orderedlist.info = db._info.title.only
-  db.orderedlist =
-    
-    ## A list in which each entry is marked with a sequentially incremented label
-    element orderedlist {
-      db.orderedlist.attlist,
-      db.orderedlist.info,
-      db.all.blocks*,
-      db.listitem+
-    }
-}
-div {
-  db.listitem.role.attribute = attribute role { text }
-  db.listitem.override.attribute =
-    
-    ## Specifies the keyword for the type of mark that should be used on this
-    ##  item, instead of the mark that would be used by default
-    attribute override { xsd:NMTOKEN }
-  db.listitem.attlist =
-    db.listitem.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.listitem.override.attribute?
-  db.listitem =
-    
-    ## A wrapper for the elements of a list item
-    element listitem { db.listitem.attlist, db.all.blocks+ }
-}
-div {
-  db.segmentedlist.role.attribute = attribute role { text }
-  db.segmentedlist.attlist =
-    db.segmentedlist.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.segmentedlist.info = db._info.title.only
-  db.segmentedlist =
-    
-    ## A segmented list, a list of sets of elements
-    element segmentedlist {
-      db.segmentedlist.attlist,
-      db.segmentedlist.info,
-      db.segtitle+,
-      db.seglistitem+
-    }
-}
-div {
-  db.segtitle.role.attribute = attribute role { text }
-  db.segtitle.attlist =
-    db.segtitle.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.segtitle =
-    
-    ## The title of an element of a list item in a segmented list
-    element segtitle { db.segtitle.attlist, db.all.inlines* }
-}
-div {
-  db.seglistitem.role.attribute = attribute role { text }
-  db.seglistitem.attlist =
-    db.seglistitem.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.seglistitem =
-    
-    ## A list item in a segmented list
-    [
-      s:pattern [
-        name = "Cardinality of segments and titles"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:seglistitem"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "count(db:seg) = count(../db:segtitle)"
-            "The number of seg elements must be the same as the number of segtitle elements in the parent segmentedlist"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element seglistitem { db.seglistitem.attlist, db.seg+ }
-}
-div {
-  db.seg.role.attribute = attribute role { text }
-  db.seg.attlist =
-    db.seg.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.seg =
-    
-    ## An element of a list item in a segmented list
-    element seg { db.seg.attlist, db.all.inlines* }
-}
-div {
-  db.simplelist.role.attribute = attribute role { text }
-  db.simplelist.type.enumeration =
-    
-    ## A tabular presentation in row-major order.
-    "horiz"
-    | 
-      ## A tabular presentation in column-major order.
-      "vert"
-    | 
-      ## An inline presentation, usually a comma-delimited list.
-      "inline"
-  db.simplelist.type.attribute =
-    
-    ## Specifies the type of list presentation.
-    [ a:defaultValue = "vert" ]
-    attribute type { db.simplelist.type.enumeration }
-  db.simplelist.columns.attribute =
-    
-    ## Specifies the number of columns for horizontal or vertical presentation
-    attribute columns { xsd:integer }
-  db.simplelist.attlist =
-    db.simplelist.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.simplelist.type.attribute?
-    & db.simplelist.columns.attribute?
-  db.simplelist =
-    
-    ## An undecorated list of single words or short phrases
-    element simplelist { db.simplelist.attlist, db.member+ }
-}
-div {
-  db.member.role.attribute = attribute role { text }
-  db.member.attlist =
-    db.member.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.member =
-    
-    ## An element of a simple list
-    element member { db.member.attlist, db.all.inlines* }
-}
-div {
-  db.variablelist.role.attribute = attribute role { text }
-  db.variablelist.termlength.attribute =
-    
-    ## Indicates a length beyond which the presentation system may consider a term too long and select an alternate presentation for that term, item, or list
-    attribute termlength { text }
-  db.variablelist.attlist =
-    db.variablelist.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.spacing.attribute?
-    & db.variablelist.termlength.attribute?
-  db.variablelist.info = db._info.title.only
-  db.variablelist =
-    
-    ## A list in which each entry is composed of a set of one or more terms and an associated description
-    element variablelist {
-      db.variablelist.attlist,
-      db.variablelist.info,
-      db.all.blocks*,
-      db.varlistentry+
-    }
-}
-div {
-  db.varlistentry.role.attribute = attribute role { text }
-  db.varlistentry.attlist =
-    db.varlistentry.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.varlistentry =
-    
-    ## A wrapper for a set of terms and the associated description in a variable list
-    element varlistentry {
-      db.varlistentry.attlist, db.term+, db.listitem
-    }
-}
-div {
-  db.term.role.attribute = attribute role { text }
-  db.term.attlist =
-    db.term.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.term =
-    
-    ## The word or phrase being defined or described in a variable list
-    element term { db.term.attlist, db.all.inlines* }
-}
-div {
-  db.example.role.attribute = attribute role { text }
-  db.example.label.attribute = db.label.attribute
-  db.example.width.attribute = db.width.characters.attribute
-  db.example.pgwide.attribute = db.pgwide.attribute
-  db.example.floatstyle.attribute = db.floatstyle.attribute
-  db.example.attlist =
-    db.example.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.example.label.attribute?
-    & db.example.floatstyle.attribute?
-    & (db.example.width.attribute | db.example.pgwide.attribute)?
-  db.example.info = db._info.title.onlyreq
-  db.example =
-    
-    ## A formal example, with a title
-    [
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:example"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:example)"
-            "example must not occur among the children or descendants of example"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:example"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:figure)"
-            "figure must not occur among the children or descendants of example"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:example"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:table)"
-            "table must not occur among the children or descendants of example"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:example"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:equation)"
-            "equation must not occur among the children or descendants of example"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:example"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:caution)"
-            "caution must not occur among the children or descendants of example"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:example"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:important)"
-            "important must not occur among the children or descendants of example"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:example"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:note)"
-            "note must not occur among the children or descendants of example"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:example"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:tip)"
-            "tip must not occur among the children or descendants of example"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:example"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:warning)"
-            "warning must not occur among the children or descendants of example"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element example {
-      db.example.attlist, db.example.info, db.all.blocks+, db.caption?
-    }
-}
-div {
-  db.informalexample.role.attribute = attribute role { text }
-  db.informalexample.width.attribute = db.width.characters.attribute
-  db.informalexample.pgwide.attribute = db.pgwide.attribute
-  db.informalexample.floatstyle.attribute = db.floatstyle.attribute
-  db.informalexample.attlist =
-    db.informalexample.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.informalexample.floatstyle.attribute?
-    & (db.informalexample.width.attribute
-       | db.informalexample.pgwide.attribute)?
-  db.informalexample.info = db._info.title.forbidden
-  db.informalexample =
-    
-    ## A displayed example without a title
-    element informalexample {
-      db.informalexample.attlist,
-      db.informalexample.info,
-      db.all.blocks+,
-      db.caption?
-    }
-}
-db.verbatim.inlines = (db.all.inlines | db.lineannotation) | db.co
-db.verbatim.contentmodel =
-  db._info.title.forbidden, (db.textobject | db.verbatim.inlines*)
-div {
-  db.literallayout.role.attribute = attribute role { text }
-  db.literallayout.class.enumeration =
-    
-    ## The literal layout should be formatted with a monospaced font
-    "monospaced"
-    | 
-      ## The literal layout should be formatted with the current font
-      "normal"
-  db.literallayout.class.attribute =
-    
-    ## Specifies the class of literal layout
-    attribute class { db.literallayout.class.enumeration }
-  db.literallayout.attlist =
-    db.literallayout.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.verbatim.attributes
-    & db.literallayout.class.attribute?
-  db.literallayout =
-    
-    ## A block of text in which line breaks and white space are to be reproduced faithfully
-    element literallayout {
-      db.literallayout.attlist, db.verbatim.contentmodel
-    }
-}
-div {
-  db.screen.role.attribute = attribute role { text }
-  db.screen.width.attribute = db.width.characters.attribute
-  db.screen.attlist =
-    db.screen.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.verbatim.attributes
-    & db.screen.width.attribute?
-  db.screen =
-    
-    ## Text that a user sees or might see on a computer screen
-    element screen { db.screen.attlist, db.verbatim.contentmodel }
-}
-div {
-  db.screenshot.role.attribute = attribute role { text }
-  db.screenshot.attlist =
-    db.screenshot.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.screenshot.info = db._info
-  db.screenshot =
-    
-    ## A representation of what the user sees or might see on a computer screen
-    element screenshot {
-      db.screenshot.attlist, db.screenshot.info, db.mediaobject
-    }
-}
-div {
-  db.figure.role.attribute = attribute role { text }
-  db.figure.label.attribute = db.label.attribute
-  db.figure.pgwide.attribute = db.pgwide.attribute
-  db.figure.floatstyle.attribute = db.floatstyle.attribute
-  db.figure.attlist =
-    db.figure.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.figure.label.attribute?
-    & db.figure.pgwide.attribute?
-    & db.figure.floatstyle.attribute?
-  db.figure.info = db._info.title.onlyreq
-  db.figure =
-    
-    ## A formal figure, generally an illustration, with a title
-    [
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:figure"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:example)"
-            "example must not occur among the children or descendants of figure"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:figure"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:figure)"
-            "figure must not occur among the children or descendants of figure"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:figure"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:table)"
-            "table must not occur among the children or descendants of figure"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:figure"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:equation)"
-            "equation must not occur among the children or descendants of figure"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:figure"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:caution)"
-            "caution must not occur among the children or descendants of figure"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:figure"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:important)"
-            "important must not occur among the children or descendants of figure"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:figure"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:note)"
-            "note must not occur among the children or descendants of figure"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:figure"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:tip)"
-            "tip must not occur among the children or descendants of figure"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:figure"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:warning)"
-            "warning must not occur among the children or descendants of figure"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element figure {
-      db.figure.attlist, db.figure.info, db.all.blocks+, db.caption?
-    }
-}
-div {
-  db.informalfigure.role.attribute = attribute role { text }
-  db.informalfigure.label.attribute = db.label.attribute
-  db.informalfigure.pgwide.attribute = db.pgwide.attribute
-  db.informalfigure.floatstyle.attribute = db.floatstyle.attribute
-  db.informalfigure.attlist =
-    db.informalfigure.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.informalfigure.label.attribute?
-    & db.informalfigure.pgwide.attribute?
-    & db.informalfigure.floatstyle.attribute?
-  db.informalfigure.info = db._info.title.forbidden
-  db.informalfigure =
-    
-    ## A untitled figure
-    element informalfigure {
-      db.informalfigure.attlist,
-      db.informalfigure.info,
-      db.all.blocks+,
-      db.caption?
-    }
-}
-db.mediaobject.content =
-  (db.videoobject | db.audioobject | db.imageobject | db.textobject)
-  | db.imageobjectco
-div {
-  db.mediaobject.role.attribute = attribute role { text }
-  db.mediaobject.attlist =
-    db.mediaobject.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.mediaobject.info = db._info.title.forbidden
-  db.mediaobject =
-    
-    ## A displayed media object (video, audio, image, etc.)
-    element mediaobject {
-      db.mediaobject.attlist,
-      db.mediaobject.info,
-      db.alt?,
-      db.mediaobject.content+,
-      db.caption?
-    }
-}
-div {
-  db.inlinemediaobject.role.attribute = attribute role { text }
-  db.inlinemediaobject.attlist =
-    db.inlinemediaobject.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.inlinemediaobject.info = db._info.title.forbidden
-  db.inlinemediaobject =
-    
-    ## An inline media object (video, audio, image, and so on)
-    element inlinemediaobject {
-      db.inlinemediaobject.attlist,
-      db.inlinemediaobject.info,
-      db.alt?,
-      db.mediaobject.content+
-    }
-}
-div {
-  db.videoobject.role.attribute = attribute role { text }
-  db.videoobject.attlist =
-    db.videoobject.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.videoobject.info = db._info.title.forbidden
-  db.videoobject =
-    
-    ## A wrapper for video data and its associated meta-information
-    element videoobject {
-      db.videoobject.attlist,
-      db.videoobject.info,
-      db.videodata,
-      db.multimediaparam*
-    }
-}
-div {
-  db.audioobject.role.attribute = attribute role { text }
-  db.audioobject.attlist =
-    db.audioobject.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.audioobject.info = db._info.title.forbidden
-  db.audioobject =
-    
-    ## A wrapper for audio data and its associated meta-information
-    element audioobject {
-      db.audioobject.attlist,
-      db.audioobject.info,
-      db.audiodata,
-      db.multimediaparam*
-    }
-}
-db.imageobject.content =
-  db.imagedata | db.imagedata.mathml | db.imagedata.svg
-div {
-  db.imageobject.role.attribute = attribute role { text }
-  db.imageobject.attlist =
-    db.imageobject.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.imageobject.info = db._info.title.forbidden
-  db.imageobject =
-    
-    ## A wrapper for image data and its associated meta-information
-    element imageobject {
-      db.imageobject.attlist,
-      db.imageobject.info,
-      db.imageobject.content
-    }
-}
-div {
-  db.textobject.role.attribute = attribute role { text }
-  db.textobject.attlist =
-    db.textobject.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.textobject.info = db._info.title.forbidden
-  db.textobject =
-    
-    ## A wrapper for a text description of an object and its associated meta-information
-    element textobject {
-      db.textobject.attlist,
-      db.textobject.info,
-      (db.phrase | db.textdata | db.all.blocks+)
-    }
-}
-div {
-  db.videodata.role.attribute = attribute role { text }
-  db.videodata.align.enumeration = db.halign.enumeration
-  db.videodata.align.attribute =
-    
-    ## Specifies the (horizontal) alignment of the video data
-    attribute align { db.videodata.align.enumeration }
-  db.videodata.autoplay.attribute = db.autoplay.attribute
-  db.videodata.classid.attribute = db.classid.attribute
-  db.videodata.valign.enumeration = db.valign.enumeration
-  db.videodata.valign.attribute =
-    
-    ## Specifies the vertical alignment of the video data
-    attribute valign { db.videodata.valign.enumeration }
-  db.videodata.width.attribute = db.width.attribute
-  db.videodata.depth.attribute = db.depth.attribute
-  db.videodata.contentwidth.attribute = db.contentwidth.attribute
-  db.videodata.contentdepth.attribute = db.contentdepth.attribute
-  db.videodata.scalefit.enumeration = db.scalefit.enumeration
-  db.videodata.scalefit.attribute =
-    
-    ## Determines if anamorphic scaling is forbidden
-    attribute scalefit { db.videodata.scalefit.enumeration }
-  db.videodata.scale.attribute = db.scale.attribute
-  db.videodata.attlist =
-    db.videodata.role.attribute?
-    & db.common.attributes
-    & db.common.data.attributes
-    & db.videodata.align.attribute?
-    & db.videodata.valign.attribute?
-    & db.videodata.width.attribute?
-    & db.videodata.contentwidth.attribute?
-    & db.videodata.scalefit.attribute?
-    & db.videodata.scale.attribute?
-    & db.videodata.depth.attribute?
-    & db.videodata.contentdepth.attribute?
-    & db.videodata.autoplay.attribute?
-    & db.videodata.classid.attribute?
-  db.videodata.info = db._info.title.forbidden
-  db.videodata =
-    
-    ## Pointer to external video data
-    element videodata { db.videodata.attlist, db.videodata.info }
-}
-div {
-  db.audiodata.role.attribute = attribute role { text }
-  db.audiodata.align.enumeration = db.halign.enumeration
-  db.audiodata.align.attribute =
-    
-    ## Specifies the (horizontal) alignment of the video data
-    attribute align { db.audiodata.align.enumeration }
-  db.audiodata.autoplay.attribute = db.autoplay.attribute
-  db.audiodata.classid.attribute = db.classid.attribute
-  db.audiodata.contentwidth.attribute = db.contentwidth.attribute
-  db.audiodata.contentdepth.attribute = db.contentdepth.attribute
-  db.audiodata.depth.attribute = db.depth.attribute
-  db.audiodata.scale.attribute = db.scale.attribute
-  db.audiodata.scalefit.enumeration = db.scalefit.enumeration
-  db.audiodata.scalefit.attribute =
-    
-    ## Determines if anamorphic scaling is forbidden
-    attribute scalefit { db.audiodata.scalefit.enumeration }
-  db.audiodata.valign.enumeration = db.valign.enumeration
-  db.audiodata.valign.attribute =
-    
-    ## Specifies the vertical alignment of the video data
-    attribute valign { db.audiodata.valign.enumeration }
-  db.audiodata.width.attribute = db.width.attribute
-  db.audiodata.attlist =
-    db.audiodata.role.attribute?
-    & db.common.attributes
-    & db.common.data.attributes
-    & db.audiodata.align.attribute?
-    & db.audiodata.autoplay.attribute?
-    & db.audiodata.classid.attribute?
-    & db.audiodata.contentdepth.attribute?
-    & db.audiodata.contentwidth.attribute?
-    & db.audiodata.depth.attribute?
-    & db.audiodata.scale.attribute?
-    & db.audiodata.scalefit.attribute?
-    & db.audiodata.valign.attribute?
-    & db.audiodata.width.attribute?
-  db.audiodata.info = db._info.title.forbidden
-  db.audiodata =
-    
-    ## Pointer to external audio data
-    element audiodata { db.audiodata.attlist, db.audiodata.info }
-}
-div {
-  db.imagedata.role.attribute = attribute role { text }
-  db.imagedata.align.enumeration = db.halign.enumeration
-  db.imagedata.align.attribute =
-    
-    ## Specifies the (horizontal) alignment of the image data
-    attribute align { db.imagedata.align.enumeration }
-  db.imagedata.valign.enumeration = db.valign.enumeration
-  db.imagedata.valign.attribute =
-    
-    ## Specifies the vertical alignment of the image data
-    attribute valign { db.imagedata.valign.enumeration }
-  db.imagedata.width.attribute = db.width.attribute
-  db.imagedata.depth.attribute = db.depth.attribute
-  db.imagedata.contentwidth.attribute = db.contentwidth.attribute
-  db.imagedata.contentdepth.attribute = db.contentdepth.attribute
-  db.imagedata.scalefit.enumeration = db.scalefit.enumeration
-  db.imagedata.scalefit.attribute =
-    
-    ## Determines if anamorphic scaling is forbidden
-    attribute scalefit { db.imagedata.scalefit.enumeration }
-  db.imagedata.scale.attribute = db.scale.attribute
-  db.imagedata.attlist =
-    db.imagedata.role.attribute?
-    & db.common.attributes
-    & db.common.data.attributes
-    & db.imagedata.align.attribute?
-    & db.imagedata.valign.attribute?
-    & db.imagedata.width.attribute?
-    & db.imagedata.contentwidth.attribute?
-    & db.imagedata.scalefit.attribute?
-    & db.imagedata.scale.attribute?
-    & db.imagedata.depth.attribute?
-    & db.imagedata.contentdepth.attribute?
-  db.imagedata.info = db._info.title.forbidden
-  db.imagedata =
-    
-    ## Pointer to external image data
-    element imagedata { db.imagedata.attlist, db.imagedata.info }
-}
-div {
-  db.textdata.role.attribute = attribute role { text }
-  db.textdata.encoding.attribute =
-    
-    ## Identifies the encoding of the text in the external file
-    attribute encoding { text }
-  db.textdata.attlist =
-    db.textdata.role.attribute?
-    & db.common.attributes
-    & db.common.data.attributes
-    & db.textdata.encoding.attribute?
-  db.textdata.info = db._info.title.forbidden
-  db.textdata =
-    
-    ## Pointer to external text data
-    element textdata { db.textdata.attlist, db.textdata.info }
-}
-div {
-  db.multimediaparam.role.attribute = attribute role { text }
-  db.multimediaparam.name.attribute =
-    
-    ## Specifies the name of the parameter
-    attribute name { text }
-  db.multimediaparam.value.attribute =
-    
-    ## Specifies the value of the parameter
-    attribute value { text }
-  db.multimediaparam.valuetype.attribute =
-    
-    ## Specifies the type of the value of the parameter
-    attribute valuetype { text }
-  db.multimediaparam.attlist =
-    db.multimediaparam.role.attribute?
-    & db.common.attributes
-    & db.multimediaparam.name.attribute
-    & db.multimediaparam.value.attribute
-    & db.multimediaparam.valuetype.attribute?
-  db.multimediaparam =
-    
-    ## Application specific parameters for a media player
-    element multimediaparam { db.multimediaparam.attlist, empty }
-}
-div {
-  db.caption.role.attribute = attribute role { text }
-  db.caption.attlist =
-    db.caption.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.caption.info = db._info.title.forbidden
-  db.caption =
-    
-    ## A caption
-    [
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:caption"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:example)"
-            "example must not occur among the children or descendants of caption"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:caption"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:figure)"
-            "figure must not occur among the children or descendants of caption"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:caption"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:table)"
-            "table must not occur among the children or descendants of caption"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:caption"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:equation)"
-            "equation must not occur among the children or descendants of caption"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:caption"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:sidebar)"
-            "sidebar must not occur among the children or descendants of caption"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:caption"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:task)"
-            "task must not occur among the children or descendants of caption"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:caption"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:caution)"
-            "caution must not occur among the children or descendants of caption"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:caption"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:important)"
-            "important must not occur among the children or descendants of caption"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:caption"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:note)"
-            "note must not occur among the children or descendants of caption"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:caption"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:tip)"
-            "tip must not occur among the children or descendants of caption"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:caption"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:warning)"
-            "warning must not occur among the children or descendants of caption"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element caption {
-      db.caption.attlist, db.caption.info, db.all.blocks+
-    }
-}
-div {
-  db.address.role.attribute = attribute role { text }
-  db.address.attlist =
-    db.address.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.verbatim.attributes
-  db.address =
-    
-    ## A real-world address, generally a postal address
-    element address {
-      db.address.attlist,
-      (db._text
-       | db.personname
-       | db.orgname
-       | db.pob
-       | db.street
-       | db.city
-       | db.state
-       | db.postcode
-       | db.country
-       | db.phone
-       | db.fax
-       | db.email
-       | db.uri
-       | db.otheraddr)*
-    }
-}
-div {
-  db.street.role.attribute = attribute role { text }
-  db.street.attlist =
-    db.street.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.street =
-    
-    ## A street address in an address
-    element street { db.street.attlist, db._text }
-}
-div {
-  db.pob.role.attribute = attribute role { text }
-  db.pob.attlist =
-    db.pob.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.pob =
-    
-    ## A post office box in an address
-    element pob { db.pob.attlist, db._text }
-}
-div {
-  db.postcode.role.attribute = attribute role { text }
-  db.postcode.attlist =
-    db.postcode.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.postcode =
-    
-    ## A postal code in an address
-    element postcode { db.postcode.attlist, db._text }
-}
-div {
-  db.city.role.attribute = attribute role { text }
-  db.city.attlist =
-    db.city.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.city =
-    
-    ## The name of a city in an address
-    element city { db.city.attlist, db._text }
-}
-div {
-  db.state.role.attribute = attribute role { text }
-  db.state.attlist =
-    db.state.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.state =
-    
-    ## A state or province in an address
-    element state { db.state.attlist, db._text }
-}
-div {
-  db.country.role.attribute = attribute role { text }
-  db.country.attlist =
-    db.country.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.country =
-    
-    ## The name of a country
-    element country { db.country.attlist, db._text }
-}
-div {
-  db.phone.role.attribute = attribute role { text }
-  db.phone.attlist =
-    db.phone.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.phone =
-    
-    ## A telephone number
-    element phone { db.phone.attlist, db._text }
-}
-div {
-  db.fax.role.attribute = attribute role { text }
-  db.fax.attlist =
-    db.fax.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.fax =
-    
-    ## A fax number
-    element fax { db.fax.attlist, db._text }
-}
-div {
-  db.otheraddr.role.attribute = attribute role { text }
-  db.otheraddr.attlist =
-    db.otheraddr.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.otheraddr =
-    
-    ## Uncategorized information in address
-    element otheraddr { db.otheraddr.attlist, db._text }
-}
-div {
-  db.affiliation.role.attribute = attribute role { text }
-  db.affiliation.attlist =
-    db.affiliation.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.affiliation =
-    
-    ## The institutional affiliation of an individual
-    element affiliation {
-      db.affiliation.attlist,
-      db.shortaffil?,
-      db.jobtitle*,
-      (db.org? | (db.orgname?, db.orgdiv*, db.address*))
-    }
-}
-div {
-  db.shortaffil.role.attribute = attribute role { text }
-  db.shortaffil.attlist =
-    db.shortaffil.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.shortaffil =
-    
-    ## A brief description of an affiliation
-    element shortaffil { db.shortaffil.attlist, db._text }
-}
-div {
-  db.jobtitle.role.attribute = attribute role { text }
-  db.jobtitle.attlist =
-    db.jobtitle.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.jobtitle =
-    
-    ## The title of an individual in an organization
-    element jobtitle { db.jobtitle.attlist, db._text }
-}
-div {
-  db.orgname.class.enumeration =
-    
-    ## A consortium
-    "consortium"
-    | 
-      ## A corporation
-      "corporation"
-    | 
-      ## An informal organization
-      "informal"
-    | 
-      ## A non-profit organization
-      "nonprofit"
-  db.orgname.class-enum.attribute =
-    
-    ## Specifies the nature of the organization
-    attribute class { db.orgname.class.enumeration }
-  db.orgname.class-other.attributes =
-    
-    ## Specifies the nature of the organization
-    attribute class {
-      
-      ## Indicates a non-standard organization class
-      "other"
-    },
-    
-    ## Identifies the non-standard nature of the organization
-    attribute otherclass { text }
-  db.orgname.class.attribute =
-    db.orgname.class-enum.attribute | db.orgname.class-other.attributes
-  db.orgname.role.attribute = attribute role { text }
-  db.orgname.attlist =
-    db.orgname.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.orgname.class.attribute?
-  db.orgname =
-    
-    ## The name of an organization
-    element orgname { db.orgname.attlist, db._text }
-}
-div {
-  db.orgdiv.role.attribute = attribute role { text }
-  db.orgdiv.attlist =
-    db.orgdiv.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.orgdiv =
-    
-    ## A division of an organization
-    element orgdiv { db.orgdiv.attlist, db.all.inlines* }
-}
-div {
-  db.artpagenums.role.attribute = attribute role { text }
-  db.artpagenums.attlist =
-    db.artpagenums.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.artpagenums =
-    
-    ## The page numbers of an article as published
-    element artpagenums { db.artpagenums.attlist, db._text }
-}
-div {
-  db.personname.role.attribute = attribute role { text }
-  db.personname.attlist =
-    db.personname.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.personname =
-    
-    ## The personal name of an individual
-    element personname {
-      db.personname.attlist,
-      (db._text
-       | (db.honorific
-          | db.firstname
-          | db.surname
-          | db.lineage
-          | db.othername)+
-       | (db.honorific
-          | db.givenname
-          | db.surname
-          | db.lineage
-          | db.othername)+)
-    }
-}
-db.person.author.contentmodel =
-  db.personname,
-  (db.personblurb
-   | db.affiliation
-   | db.email
-   | db.uri
-   | db.address
-   | db.contrib)*
-db.org.author.contentmodel =
-  db.orgname,
-  (db.orgdiv
-   | db.affiliation
-   | db.email
-   | db.uri
-   | db.address
-   | db.contrib)*
-db.credit.contentmodel =
-  db.person.author.contentmodel | db.org.author.contentmodel
-div {
-  db.author.role.attribute = attribute role { text }
-  db.author.attlist =
-    db.author.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.author =
-    
-    ## The name of an individual author
-    element author { db.author.attlist, db.credit.contentmodel }
-}
-div {
-  db.authorgroup.role.attribute = attribute role { text }
-  db.authorgroup.attlist =
-    db.authorgroup.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.authorgroup =
-    
-    ## Wrapper for author information when a document has multiple authors or collaborators
-    element authorgroup {
-      db.authorgroup.attlist, (db.author | db.editor | db.othercredit)+
-    }
-}
-div {
-  db.collab.role.attribute = attribute role { text }
-  db.collab.attlist =
-    db.collab.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.collab =
-    
-    ## Identifies a collaborator
-    element collab {
-      db.collab.attlist,
-      (db.person | db.personname | db.org | db.orgname)+,
-      db.affiliation*
-    }
-}
-div {
-  db.authorinitials.role.attribute = attribute role { text }
-  db.authorinitials.attlist =
-    db.authorinitials.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.authorinitials =
-    
-    ## The initials or other short identifier for an author
-    element authorinitials { db.authorinitials.attlist, db._text }
-}
-div {
-  db.person.role.attribute = attribute role { text }
-  db.person.attlist =
-    db.person.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.person =
-    
-    ## A person and associated metadata
-    element person {
-      db.person.attlist,
-      db.personname,
-      (db.address
-       | db.affiliation
-       | db.email
-       | db.uri
-       | db.personblurb)*
-    }
-}
-div {
-  db.org.role.attribute = attribute role { text }
-  db.org.attlist =
-    db.org.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.org =
-    
-    ## An organization and associated metadata
-    element org {
-      db.org.attlist,
-      db.orgname,
-      (db.address | db.affiliation | db.email | db.uri | db.orgdiv)*
-    }
-}
-div {
-  db.confgroup.role.attribute = attribute role { text }
-  db.confgroup.attlist =
-    db.confgroup.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.confgroup =
-    
-    ## A wrapper for document meta-information about a conference
-    element confgroup {
-      db.confgroup.attlist,
-      (db.confdates
-       | db.conftitle
-       | db.confnum
-       | db.confsponsor
-       | db.address)*
-    }
-}
-div {
-  db.confdates.role.attribute = attribute role { text }
-  db.confdates.attlist =
-    db.confdates.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.confdates =
-    
-    ## The dates of a conference for which a document was written
-    element confdates { db.confdates.attlist, db._text }
-}
-div {
-  db.conftitle.role.attribute = attribute role { text }
-  db.conftitle.attlist =
-    db.conftitle.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.conftitle =
-    
-    ## The title of a conference for which a document was written
-    element conftitle { db.conftitle.attlist, db._text }
-}
-div {
-  db.confnum.role.attribute = attribute role { text }
-  db.confnum.attlist =
-    db.confnum.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.confnum =
-    
-    ## An identifier, frequently numerical, associated with a conference for which a document was written
-    element confnum { db.confnum.attlist, db._text }
-}
-div {
-  db.confsponsor.role.attribute = attribute role { text }
-  db.confsponsor.attlist =
-    db.confsponsor.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.confsponsor =
-    
-    ## The sponsor of a conference for which a document was written
-    element confsponsor { db.confsponsor.attlist, db._text }
-}
-div {
-  db.contractnum.role.attribute = attribute role { text }
-  db.contractnum.attlist =
-    db.contractnum.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.contractnum =
-    
-    ## The contract number of a document
-    element contractnum { db.contractnum.attlist, db._text }
-}
-div {
-  db.contractsponsor.role.attribute = attribute role { text }
-  db.contractsponsor.attlist =
-    db.contractsponsor.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.contractsponsor =
-    
-    ## The sponsor of a contract
-    element contractsponsor { db.contractsponsor.attlist, db._text }
-}
-div {
-  db.copyright.role.attribute = attribute role { text }
-  db.copyright.attlist =
-    db.copyright.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.copyright =
-    
-    ## Copyright information about a document
-    element copyright { db.copyright.attlist, db.year+, db.holder* }
-}
-div {
-  db.year.role.attribute = attribute role { text }
-  db.year.attlist =
-    db.year.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.year =
-    
-    ## The year of publication of a document
-    element year { db.year.attlist, db._text }
-}
-div {
-  db.holder.role.attribute = attribute role { text }
-  db.holder.attlist =
-    db.holder.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.holder =
-    
-    ## The name of the individual or organization that holds a copyright
-    element holder { db.holder.attlist, db._text }
-}
-db.cover.contentmodel =
-  (db.para.blocks
-   | db.list.blocks
-   | db.informal.blocks
-   | db.publishing.blocks
-   | db.graphic.blocks
-   | db.technical.blocks
-   | db.verbatim.blocks
-   | db.bridgehead
-   | db.remark
-   | db.revhistory)
-  | db.synopsis.blocks
-div {
-  db.cover.role.attribute = attribute role { text }
-  db.cover.attlist =
-    db.cover.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.cover =
-    
-    ## Additional content for the cover of a publication
-    element cover { db.cover.attlist, db.cover.contentmodel+ }
-}
-db.date.contentmodel =
-  xsd:date | xsd:dateTime | xsd:gYearMonth | xsd:gYear | text
-div {
-  db.date.role.attribute = attribute role { text }
-  db.date.attlist =
-    db.date.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.date =
-    
-    ## The date of publication or revision of a document
-    element date { db.date.attlist, db.date.contentmodel }
-}
-div {
-  db.edition.role.attribute = attribute role { text }
-  db.edition.attlist =
-    db.edition.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.edition =
-    
-    ## The name or number of an edition of a document
-    element edition { db.edition.attlist, db._text }
-}
-div {
-  db.editor.role.attribute = attribute role { text }
-  db.editor.attlist =
-    db.editor.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.editor =
-    
-    ## The name of the editor of a document
-    element editor { db.editor.attlist, db.credit.contentmodel }
-}
-div {
-  db.biblioid.role.attribute = attribute role { text }
-  db.biblioid.attlist =
-    db.biblioid.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.biblio.class.attribute
-  db.biblioid =
-    
-    ## An identifier for a document
-    element biblioid { db.biblioid.attlist, db._text }
-}
-div {
-  db.citebiblioid.role.attribute = attribute role { text }
-  db.citebiblioid.attlist =
-    db.citebiblioid.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.biblio.class.attribute
-  db.citebiblioid =
-    
-    ## A citation of a bibliographic identifier
-    element citebiblioid { db.citebiblioid.attlist, db._text }
-}
-div {
-  db.bibliosource.role.attribute = attribute role { text }
-  db.bibliosource.attlist =
-    db.bibliosource.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.biblio.class.attribute
-  db.bibliosource =
-    
-    ## The source of a document
-    element bibliosource { db.bibliosource.attlist, db._text }
-}
-div {
-  db.bibliorelation.type.enumeration =
-    
-    ## The described resource pre-existed the referenced resource, which is essentially the same intellectual content presented in another format
-    "hasformat"
-    | 
-      ## The described resource includes the referenced resource either physically or logically
-      "haspart"
-    | 
-      ## The described resource has a version, edition, or adaptation, namely, the referenced resource
-      "hasversion"
-    | 
-      ## The described resource is the same intellectual content of the referenced resource, but presented in another format
-      "isformatof"
-    | 
-      ## The described resource is a physical or logical part of the referenced resource
-      "ispartof"
-    | 
-      ## The described resource is referenced, cited, or otherwise pointed to by the referenced resource
-      "isreferencedby"
-    | 
-      ## The described resource is supplanted, displaced, or superceded by the referenced resource
-      "isreplacedby"
-    | 
-      ## The described resource is required by the referenced resource, either physically or logically
-      "isrequiredby"
-    | 
-      ## The described resource is a version, edition, or adaptation of the referenced resource; changes in version imply substantive changes in content rather than differences in format
-      "isversionof"
-    | 
-      ## The described resource references, cites, or otherwise points to the referenced resource
-      "references"
-    | 
-      ## The described resource supplants, displaces, or supersedes the referenced resource
-      "replaces"
-    | 
-      ## The described resource requires the referenced resource to support its function, delivery, or coherence of content
-      "requires"
-  db.bibliorelation.type-enum.attribute =
-    
-    ## Identifies the type of relationship
-    attribute type { db.bibliorelation.type.enumeration }?
-  db.bibliorelation.type-other.attributes =
-    
-    ## Identifies the type of relationship
-    attribute type {
-      
-      ## The described resource has a non-standard relationship with the referenced resource
-      "othertype"
-    }?,
-    
-    ## A keyword that identififes the type of the non-standard relationship
-    attribute othertype { xsd:NMTOKEN }
-  db.bibliorelation.type.attribute =
-    db.bibliorelation.type-enum.attribute
-    | db.bibliorelation.type-other.attributes
-  db.bibliorelation.role.attribute = attribute role { text }
-  db.bibliorelation.attlist =
-    db.bibliorelation.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.biblio.class.attribute
-    & db.bibliorelation.type.attribute
-  db.bibliorelation =
-    
-    ## The relationship of a document to another
-    element bibliorelation { db.bibliorelation.attlist, db._text }
-}
-div {
-  db.bibliocoverage.spacial.enumeration =
-    
-    ## The DCMI Point identifies a point in space using its geographic coordinates
-    "dcmipoint"
-    | 
-      ## ISO 3166 Codes for the representation of names of countries
-      "iso3166"
-    | 
-      ## The DCMI Box identifies a region of space using its geographic limits
-      "dcmibox"
-    | 
-      ## The Getty Thesaurus of Geographic Names
-      "tgn"
-  db.bibliocoverage.spatial-enum.attribute =
-    
-    ## Specifies the type of spatial coverage
-    attribute spatial { db.bibliocoverage.spacial.enumeration }?
-  db.bibliocoverage.spatial-other.attributes =
-    
-    ## Specifies the type of spatial coverage
-    attribute spatial {
-      
-      ## Identifies a non-standard type of coverage
-      "otherspatial"
-    }?,
-    
-    ## A keyword that identifies the type of non-standard coverage
-    attribute otherspatial { xsd:NMTOKEN }
-  db.bibliocoverage.spatial.attribute =
-    db.bibliocoverage.spatial-enum.attribute
-    | db.bibliocoverage.spatial-other.attributes
-  db.bibliocoverage.temporal.enumeration =
-    
-    ## A specification of the limits of a time interval
-    "dcmiperiod"
-    | 
-      ## W3C Encoding rules for dates and times—a profile based on ISO 8601
-      "w3c-dtf"
-  db.bibliocoverage.temporal-enum.attribute =
-    
-    ## Specifies the type of temporal coverage
-    attribute temporal { db.bibliocoverage.temporal.enumeration }?
-  db.bibliocoverage.temporal-other.attributes =
-    
-    ## Specifies the type of temporal coverage
-    attribute temporal {
-      
-      ## Specifies a non-standard type of coverage
-      "othertemporal"
-    }?,
-    
-    ## A keyword that identifies the type of non-standard coverage
-    attribute othertemporal { xsd:NMTOKEN }
-  db.bibliocoverage.temporal.attribute =
-    db.bibliocoverage.temporal-enum.attribute
-    | db.bibliocoverage.temporal-other.attributes
-  db.bibliocoverage.coverage.attrib =
-    db.bibliocoverage.spatial.attribute
-    & db.bibliocoverage.temporal.attribute
-  db.bibliocoverage.role.attribute = attribute role { text }
-  db.bibliocoverage.attlist =
-    db.bibliocoverage.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.bibliocoverage.coverage.attrib
-  db.bibliocoverage =
-    
-    ## The spatial or temporal coverage of a document
-    element bibliocoverage { db.bibliocoverage.attlist, db._text }
-}
-div {
-  db.legalnotice.role.attribute = attribute role { text }
-  db.legalnotice.attlist =
-    db.legalnotice.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.legalnotice.info = db._info.title.only
-  db.legalnotice =
-    
-    ## A statement of legal obligations or requirements
-    element legalnotice {
-      db.legalnotice.attlist, db.legalnotice.info, db.all.blocks+
-    }
-}
-div {
-  db.othercredit.class.enumeration =
-    
-    ## A copy editor
-    "copyeditor"
-    | 
-      ## A graphic designer
-      "graphicdesigner"
-    | 
-      ## Some other contributor
-      "other"
-    | 
-      ## A production editor
-      "productioneditor"
-    | 
-      ## A technical editor
-      "technicaleditor"
-    | 
-      ## A translator
-      "translator"
-    | 
-      ## An indexer
-      "indexer"
-    | 
-      ## A proof-reader
-      "proofreader"
-    | 
-      ## A cover designer
-      "coverdesigner"
-    | 
-      ## An interior designer
-      "interiordesigner"
-    | 
-      ## An illustrator
-      "illustrator"
-    | 
-      ## A reviewer
-      "reviewer"
-    | 
-      ## A typesetter
-      "typesetter"
-    | 
-      ## A converter (a persons responsible for conversion, not an application)
-      "conversion"
-  db.othercredit.class-enum.attribute =
-    
-    ## Identifies the nature of the contributor
-    attribute class { db.othercredit.class.enumeration }?
-  db.othercredit.class-other.attribute =
-    
-    ## Identifies the nature of the non-standard contribution
-    attribute otherclass { xsd:NMTOKEN }
-  db.othercredit.class-other.attributes =
-    
-    ## Identifies the nature of the contributor
-    attribute class {
-      
-      ## Identifies a non-standard contribution
-      "other"
-    }
-    & db.othercredit.class-other.attribute
-  db.othercredit.class.attribute =
-    db.othercredit.class-enum.attribute
-    | db.othercredit.class-other.attributes
-  db.othercredit.role.attribute = attribute role { text }
-  db.othercredit.attlist =
-    db.othercredit.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.othercredit.class.attribute
-  db.othercredit =
-    
-    ## A person or entity, other than an author or editor, credited in a document
-    element othercredit {
-      db.othercredit.attlist, db.credit.contentmodel
-    }
-}
-div {
-  db.pagenums.role.attribute = attribute role { text }
-  db.pagenums.attlist =
-    db.pagenums.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.pagenums =
-    
-    ## The numbers of the pages in a book, for use in a bibliographic entry
-    element pagenums { db.pagenums.attlist, db._text }
-}
-div {
-  db.contrib.role.attribute = attribute role { text }
-  db.contrib.attlist =
-    db.contrib.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.contrib =
-    
-    ## A summary of the contributions made to a document by a credited source
-    element contrib { db.contrib.attlist, db.all.inlines* }
-}
-div {
-  db.honorific.role.attribute = attribute role { text }
-  db.honorific.attlist =
-    db.honorific.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.honorific =
-    
-    ## The title of a person
-    element honorific { db.honorific.attlist, db._text }
-}
-div {
-  db.firstname.role.attribute = attribute role { text }
-  db.firstname.attlist =
-    db.firstname.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.firstname =
-    
-    ## A given name of a person
-    element firstname { db.firstname.attlist, db._text }
-}
-div {
-  db.givenname.role.attribute = attribute role { text }
-  db.givenname.attlist =
-    db.givenname.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.givenname =
-    
-    ## The given name of a person
-    element givenname { db.givenname.attlist, db._text }
-}
-div {
-  db.surname.role.attribute = attribute role { text }
-  db.surname.attlist =
-    db.surname.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.surname =
-    
-    ## An inherited or family name; in western cultures the last name
-    element surname { db.surname.attlist, db._text }
-}
-div {
-  db.lineage.role.attribute = attribute role { text }
-  db.lineage.attlist =
-    db.lineage.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.lineage =
-    
-    ## The portion of a person's name indicating a relationship to ancestors
-    element lineage { db.lineage.attlist, db._text }
-}
-div {
-  db.othername.role.attribute = attribute role { text }
-  db.othername.attlist =
-    db.othername.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.othername =
-    
-    ## A component of a person's name that is not a first name, surname, or lineage
-    element othername { db.othername.attlist, db._text }
-}
-div {
-  db.printhistory.role.attribute = attribute role { text }
-  db.printhistory.attlist =
-    db.printhistory.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.printhistory =
-    
-    ## The printing history of a document
-    element printhistory { db.printhistory.attlist, db.para.blocks+ }
-}
-div {
-  db.pubdate.role.attribute = attribute role { text }
-  db.pubdate.attlist =
-    db.pubdate.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.pubdate =
-    
-    ## The date of publication of a document
-    element pubdate { db.pubdate.attlist, db.date.contentmodel }
-}
-div {
-  db.publisher.role.attribute = attribute role { text }
-  db.publisher.attlist =
-    db.publisher.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.publisher =
-    
-    ## The publisher of a document
-    element publisher {
-      db.publisher.attlist, db.publishername, db.address*
-    }
-}
-div {
-  db.publishername.role.attribute = attribute role { text }
-  db.publishername.attlist =
-    db.publishername.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.publishername =
-    
-    ## The name of the publisher of a document
-    element publishername { db.publishername.attlist, db._text }
-}
-div {
-  db.releaseinfo.role.attribute = attribute role { text }
-  db.releaseinfo.attlist =
-    db.releaseinfo.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.releaseinfo =
-    
-    ## Information about a particular release of a document
-    element releaseinfo { db.releaseinfo.attlist, db._text }
-}
-div {
-  db.revhistory.role.attribute = attribute role { text }
-  db.revhistory.attlist =
-    db.revhistory.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.revhistory.info = db._info.title.only
-  db.revhistory =
-    
-    ## A history of the revisions to a document
-    element revhistory {
-      db.revhistory.attlist, db.revhistory.info, db.revision+
-    }
-}
-div {
-  db.revision.role.attribute = attribute role { text }
-  db.revision.attlist =
-    db.revision.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.revision =
-    
-    ## An entry describing a single revision in the history of the revisions to a document
-    element revision {
-      db.revision.attlist,
-      db.revnumber?,
-      db.date,
-      (db.authorinitials | db.author)*,
-      (db.revremark | db.revdescription)?
-    }
-}
-div {
-  db.revnumber.role.attribute = attribute role { text }
-  db.revnumber.attlist =
-    db.revnumber.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.revnumber =
-    
-    ## A document revision number
-    element revnumber { db.revnumber.attlist, db._text }
-}
-div {
-  db.revremark.role.attribute = attribute role { text }
-  db.revremark.attlist =
-    db.revremark.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.revremark =
-    
-    ## A description of a revision to a document
-    element revremark { db.revremark.attlist, db._text }
-}
-div {
-  db.revdescription.role.attribute = attribute role { text }
-  db.revdescription.attlist =
-    db.revdescription.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.revdescription =
-    
-    ## A extended description of a revision to a document
-    element revdescription { db.revdescription.attlist, db.all.blocks* }
-}
-div {
-  db.seriesvolnums.role.attribute = attribute role { text }
-  db.seriesvolnums.attlist =
-    db.seriesvolnums.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.seriesvolnums =
-    
-    ## Numbers of the volumes in a series of books
-    element seriesvolnums { db.seriesvolnums.attlist, db._text }
-}
-div {
-  db.volumenum.role.attribute = attribute role { text }
-  db.volumenum.attlist =
-    db.volumenum.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.volumenum =
-    
-    ## The volume number of a document in a set (as of books in a set or articles in a journal)
-    element volumenum { db.volumenum.attlist, db._text }
-}
-div {
-  db.issuenum.role.attribute = attribute role { text }
-  db.issuenum.attlist =
-    db.issuenum.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.issuenum =
-    
-    ## The number of an issue of a journal
-    element issuenum { db.issuenum.attlist, db._text }
-}
-div {
-  db.package.role.attribute = attribute role { text }
-  db.package.attlist =
-    db.package.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.package =
-    
-    ## A software or application package
-    element package { db.package.attlist, db._text }
-}
-div {
-  db.email.role.attribute = attribute role { text }
-  db.email.attlist =
-    db.email.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.email =
-    
-    ## An email address
-    element email { db.email.attlist, db._text }
-}
-div {
-  db.lineannotation.role.attribute = attribute role { text }
-  db.lineannotation.attlist =
-    db.lineannotation.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.lineannotation =
-    
-    ## A comment on a line in a verbatim listing
-    element lineannotation { db.lineannotation.attlist, db._text }
-}
-div {
-  db.parameter.class.enumeration =
-    
-    ## A command
-    "command"
-    | 
-      ## A function
-      "function"
-    | 
-      ## An option
-      "option"
-  db.parameter.class.attribute =
-    
-    ## Identifies the class of parameter
-    attribute class { db.parameter.class.enumeration }
-  db.parameter.role.attribute = attribute role { text }
-  db.parameter.attlist =
-    db.parameter.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.parameter.class.attribute?
-  db.parameter =
-    
-    ## A value or a symbolic reference to a value
-    element parameter { db.parameter.attlist, db._text }
-}
-db.replaceable.inlines = db._text | db.co
-div {
-  db.replaceable.class.enumeration =
-    
-    ## A command
-    "command"
-    | 
-      ## A function
-      "function"
-    | 
-      ## An option
-      "option"
-    | 
-      ## A parameter
-      "parameter"
-  db.replaceable.class.attribute =
-    
-    ## Identifies the nature of the replaceable text
-    attribute class { db.replaceable.class.enumeration }
-  db.replaceable.role.attribute = attribute role { text }
-  db.replaceable.attlist =
-    db.replaceable.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.replaceable.class.attribute?
-  db.replaceable =
-    
-    ## Content that may or must be replaced by the user
-    element replaceable {
-      db.replaceable.attlist, db.replaceable.inlines*
-    }
-}
-div {
-  db.uri.type.attribute =
-    
-    ## Identifies the type of URI specified
-    attribute type { text }?
-  db.uri.role.attribute = attribute role { text }
-  db.uri.attlist =
-    db.uri.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.uri.type.attribute
-  db.uri =
-    
-    ## A Uniform Resource Identifier
-    element uri { db.uri.attlist, db._text }
-}
-div {
-  db.abbrev.role.attribute = attribute role { text }
-  db.abbrev.attlist =
-    db.abbrev.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.abbrev =
-    
-    ## An abbreviation, especially one followed by a period
-    element abbrev {
-      db.abbrev.attlist,
-      (db._text | db.superscript | db.subscript | db.trademark)*
-    }
-}
-div {
-  db.acronym.role.attribute = attribute role { text }
-  db.acronym.attlist =
-    db.acronym.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.acronym =
-    
-    ## An often pronounceable word made from the initial (or selected) letters of a name or phrase
-    element acronym {
-      db.acronym.attlist,
-      (db._text | db.superscript | db.subscript | db.trademark)*
-    }
-}
-div {
-  db.citation.role.attribute = attribute role { text }
-  db.citation.attlist =
-    db.citation.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.citation =
-    
-    ## An inline bibliographic reference to another published work
-    element citation { db.citation.attlist, db.all.inlines* }
-}
-div {
-  db.citerefentry.role.attribute = attribute role { text }
-  db.citerefentry.attlist =
-    db.citerefentry.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.citerefentry =
-    
-    ## A citation to a reference page
-    element citerefentry {
-      db.citerefentry.attlist, db.refentrytitle, db.manvolnum?
-    }
-}
-div {
-  db.refentrytitle.role.attribute = attribute role { text }
-  db.refentrytitle.attlist =
-    db.refentrytitle.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.refentrytitle =
-    
-    ## The title of a reference page
-    element refentrytitle { db.refentrytitle.attlist, db.all.inlines* }
-}
-div {
-  db.manvolnum.role.attribute = attribute role { text }
-  db.manvolnum.attlist =
-    db.manvolnum.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.manvolnum =
-    
-    ## A reference volume number
-    element manvolnum { db.manvolnum.attlist, db._text }
-}
-div {
-  db.citetitle.pubwork.enumeration =
-    
-    ## An article
-    "article"
-    | 
-      ## A bulletin board system
-      "bbs"
-    | 
-      ## A book
-      "book"
-    | 
-      ## A CD-ROM
-      "cdrom"
-    | 
-      ## A chapter (as of a book)
-      "chapter"
-    | 
-      ## A DVD
-      "dvd"
-    | 
-      ## An email message
-      "emailmessage"
-    | 
-      ## A gopher page
-      "gopher"
-    | 
-      ## A journal
-      "journal"
-    | 
-      ## A manuscript
-      "manuscript"
-    | 
-      ## A posting to a newsgroup
-      "newsposting"
-    | 
-      ## A part (as of a book)
-      "part"
-    | 
-      ## A reference entry
-      "refentry"
-    | 
-      ## A section (as of a book or article)
-      "section"
-    | 
-      ## A series
-      "series"
-    | 
-      ## A set (as of books)
-      "set"
-    | 
-      ## A web page
-      "webpage"
-    | 
-      ## A wiki page
-      "wiki"
-  db.citetitle.pubwork.attribute =
-    
-    ## Identifies the nature of the publication being cited
-    attribute pubwork { db.citetitle.pubwork.enumeration }
-  db.citetitle.role.attribute = attribute role { text }
-  db.citetitle.attlist =
-    db.citetitle.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.citetitle.pubwork.attribute?
-  db.citetitle =
-    
-    ## The title of a cited work
-    element citetitle { db.citetitle.attlist, db.all.inlines* }
-}
-div {
-  db.emphasis.role.attribute = attribute role { text }
-  db.emphasis.attlist =
-    db.emphasis.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.emphasis =
-    
-    ## Emphasized text
-    element emphasis { db.emphasis.attlist, db.all.inlines* }
-}
-div {
-  db._emphasis =
-    
-    ## A limited span of emphasized text
-    element emphasis { db.emphasis.attlist, db._text }
-}
-div {
-  db.foreignphrase.role.attribute = attribute role { text }
-  db.foreignphrase.attlist =
-    db.foreignphrase.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.foreignphrase =
-    
-    ## A word or phrase in a language other than the primary language of the document
-    element foreignphrase {
-      db.foreignphrase.attlist, (text | db.general.inlines)*
-    }
-}
-div {
-  db._foreignphrase.role.attribute = attribute role { text }
-  db._foreignphrase.attlist =
-    db._foreignphrase.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db._foreignphrase =
-    
-    ## A limited word or phrase in a language other than the primary language of the document
-    element foreignphrase { db._foreignphrase.attlist, db._text }
-}
-div {
-  db.phrase.role.attribute = attribute role { text }
-  db.phrase.attlist =
-    db.phrase.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.phrase =
-    
-    ## A span of text
-    element phrase { db.phrase.attlist, db.all.inlines* }
-}
-div {
-  db._phrase =
-    
-    ## A limited span of text
-    element phrase { db.phrase.attlist, db._text }
-}
-div {
-  db.quote.role.attribute = attribute role { text }
-  db.quote.attlist =
-    db.quote.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.quote =
-    
-    ## An inline quotation
-    element quote { db.quote.attlist, db.all.inlines* }
-}
-div {
-  db._quote.role.attribute = attribute role { text }
-  db._quote.attlist =
-    db._quote.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db._quote =
-    
-    ## A limited inline quotation
-    element quote { db._quote.attlist, db._text }
-}
-div {
-  db.subscript.role.attribute = attribute role { text }
-  db.subscript.attlist =
-    db.subscript.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.subscript =
-    
-    ## A subscript (as in H2
-    ## O, the molecular formula for water)
-    element subscript { db.subscript.attlist, db._text }
-}
-div {
-  db.superscript.role.attribute = attribute role { text }
-  db.superscript.attlist =
-    db.superscript.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.superscript =
-    
-    ## A superscript (as in x2
-    ## , the mathematical notation for x multiplied by itself)
-    element superscript { db.superscript.attlist, db._text }
-}
-div {
-  db.trademark.class.enumeration =
-    
-    ## A copyright
-    "copyright"
-    | 
-      ## A registered copyright
-      "registered"
-    | 
-      ## A service
-      "service"
-    | 
-      ## A trademark
-      "trade"
-  db.trademark.class.attribute =
-    
-    ## Identifies the class of trade mark
-    attribute class { db.trademark.class.enumeration }
-  db.trademark.role.attribute = attribute role { text }
-  db.trademark.attlist =
-    db.trademark.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.trademark.class.attribute?
-  db.trademark =
-    
-    ## A trademark
-    element trademark { db.trademark.attlist, db._text }
-}
-div {
-  db.wordasword.role.attribute = attribute role { text }
-  db.wordasword.attlist =
-    db.wordasword.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.wordasword =
-    
-    ## A word meant specifically as a word and not representing anything else
-    element wordasword { db.wordasword.attlist, db._text }
-}
-div {
-  db.footnoteref.role.attribute = attribute role { text }
-  db.footnoteref.label.attribute = db.label.attribute
-  db.footnoteref.attlist =
-    db.footnoteref.role.attribute?
-    & db.common.attributes
-    & db.linkend.attribute
-    & db.footnoteref.label.attribute?
-  db.footnoteref =
-    
-    ## A cross reference to a footnote (a footnote mark)
-    [
-      s:pattern [
-        name = "Footnote reference type constraint"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:footnoteref"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test =
-              "local-name(//*[@xml:id=current()/@linkend]) = 'footnote' and namespace-uri(//*[@xml:id=current()/@linkend]) = 'http://docbook.org/ns/docbook'"
-            "@linkend on footnoteref must point to a footnote."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element footnoteref { db.footnoteref.attlist, empty }
-}
-div {
-  db.xref.role.attribute = attribute role { text }
-  db.xref.xrefstyle.attribute = db.xrefstyle.attribute
-  db.xref.endterm.attribute = db.endterm.attribute
-  db.xref.attlist =
-    db.xref.role.attribute?
-    & db.common.attributes
-    & db.common.req.linking.attributes
-    & db.xref.xrefstyle.attribute?
-    & db.xref.endterm.attribute?
-  db.xref =
-    
-    ## A cross reference to another part of the document
-    element xref { db.xref.attlist, empty }
-}
-div {
-  db.link.role.attribute = attribute role { text }
-  db.link.xrefstyle.attribute = db.xrefstyle.attribute
-  db.link.endterm.attribute = db.endterm.attribute
-  db.link.attlist =
-    db.link.role.attribute?
-    & db.common.attributes
-    & db.common.req.linking.attributes
-    & db.link.xrefstyle.attribute?
-    & db.link.endterm.attribute?
-  db.link =
-    
-    ## A hypertext link
-    element link { db.link.attlist, db.all.inlines* }
-}
-div {
-  db.olink.role.attribute = attribute role { text }
-  db.olink.xrefstyle.attribute = db.xrefstyle.attribute
-  db.olink.localinfo.attribute =
-    
-    ## Holds additional information that may be used by the application when resolving the link
-    attribute localinfo { text }
-  db.olink.targetdoc.attribute =
-    
-    ## Specifies the URI of the document in which the link target appears
-    attribute targetdoc { xsd:anyURI }
-  db.olink.targetptr.attribute =
-    
-    ## Specifies the location of the link target in the document
-    attribute targetptr { text }
-  db.olink.type.attribute =
-    
-    ## Identifies application-specific customization of the link behavior
-    attribute type { text }
-  db.olink.attlist =
-    db.common.attributes
-    & db.olink.targetdoc.attribute?
-    & db.olink.role.attribute?
-    & db.olink.xrefstyle.attribute?
-    & db.olink.localinfo.attribute?
-    & db.olink.targetptr.attribute?
-    & db.olink.type.attribute?
-  db.olink =
-    
-    ## A link that addresses its target indirectly
-    element olink { db.olink.attlist, db.all.inlines* }
-}
-div {
-  db.anchor.role.attribute = attribute role { text }
-  db.anchor.attlist =
-    db.anchor.role.attribute? & db.common.idreq.attributes
-  db.anchor =
-    
-    ## A spot in the document
-    element anchor { db.anchor.attlist, empty }
-}
-div {
-  db.alt.role.attribute = attribute role { text }
-  db.alt.attlist = db.alt.role.attribute? & db.common.attributes
-  db.alt =
-    
-    ## A text-only annotation, often used for accessibility
-    element alt { db.alt.attlist, (text | db.inlinemediaobject)* }
-}
-db.status.attribute =
-  
-  ## Identifies the editorial or publication status of the element on which it occurs
-  attribute status { text }
-db.toplevel.sections =
-  ((db.section+, db.simplesect*) | db.simplesect+)
-  | (db.sect1+, db.simplesect*)
-  | db.refentry+
-db.toplevel.blocks.or.sections =
-  (db.all.blocks+, db.toplevel.sections?) | db.toplevel.sections
-db.recursive.sections =
-  ((db.section+, db.simplesect*) | db.simplesect+)
-  | db.refentry+
-db.recursive.blocks.or.sections =
-  (db.all.blocks+, db.recursive.sections?) | db.recursive.sections
-db.divisions = db.part | db.reference
-db.components =
-  db.dedication
-  | db.acknowledgements
-  | db.preface
-  | db.chapter
-  | db.appendix
-  | db.article
-  | db.colophon
-db.navigation.components =
-  notAllowed | db.glossary | db.bibliography | db.index | db.toc
-db.component.contentmodel =
-  db.navigation.components*,
-  db.toplevel.blocks.or.sections,
-  db.navigation.components*
-db.setindex.components = notAllowed | db.setindex
-db.toc.components = notAllowed | db.toc
-db.set.components = db.set | db.book
-div {
-  db.set.status.attribute = db.status.attribute
-  db.set.role.attribute = attribute role { text }
-  db.set.attlist =
-    db.set.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.label.attribute?
-    & db.set.status.attribute?
-  db.set.info = db._info.title.req
-  db.set =
-    
-    ## A collection of books
-    element set {
-      db.set.attlist,
-      db.set.info,
-      db.toc.components?,
-      db.set.components+,
-      db.setindex.components?
-    }
-}
-db.book.components =
-  (db.navigation.components | db.components | db.divisions)* | db.topic*
-div {
-  db.book.status.attribute = db.status.attribute
-  db.book.role.attribute = attribute role { text }
-  db.book.attlist =
-    db.book.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.label.attribute?
-    & db.book.status.attribute?
-  db.book.info = db._info
-  db.book =
-    
-    ## A book
-    element book { db.book.attlist, db.book.info, db.book.components }
-}
-div {
-  db.dedication.status.attribute = db.status.attribute
-  db.dedication.role.attribute = attribute role { text }
-  db.dedication.attlist =
-    db.dedication.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.label.attribute?
-    & db.dedication.status.attribute?
-  db.dedication.info = db._info
-  db.dedication =
-    
-    ## The dedication of a book or other component
-    element dedication {
-      db.dedication.attlist, db.dedication.info, db.all.blocks+
-    }
-}
-div {
-  db.acknowledgements.status.attribute = db.status.attribute
-  db.acknowledgements.role.attribute = attribute role { text }
-  db.acknowledgements.attlist =
-    db.acknowledgements.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.label.attribute?
-    & db.acknowledgements.status.attribute?
-  db.acknowledgements.info = db._info
-  db.acknowledgements =
-    
-    ## Acknowledgements of a book or other component
-    element acknowledgements {
-      db.acknowledgements.attlist,
-      db.acknowledgements.info,
-      db.all.blocks+
-    }
-}
-div {
-  db.colophon.status.attribute = db.status.attribute
-  db.colophon.role.attribute = attribute role { text }
-  db.colophon.attlist =
-    db.colophon.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.label.attribute?
-    & db.colophon.status.attribute?
-  db.colophon.info = db._info
-  db.colophon =
-    
-    ## Text at the back of a book describing facts about its production
-    element colophon {
-      db.colophon.attlist,
-      db.colophon.info,
-      ((db.all.blocks+, db.simplesect*)
-       | (db.all.blocks*, db.simplesect+))
-    }
-}
-db.appendix.contentmodel = db.component.contentmodel | db.topic+
-div {
-  db.appendix.status.attribute = db.status.attribute
-  db.appendix.role.attribute = attribute role { text }
-  db.appendix.attlist =
-    db.appendix.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.label.attribute?
-    & db.appendix.status.attribute?
-  db.appendix.info = db._info.title.req
-  db.appendix =
-    
-    ## An appendix in a book or article
-    element appendix {
-      db.appendix.attlist, db.appendix.info, db.appendix.contentmodel?
-    }
-}
-db.chapter.contentmodel = db.component.contentmodel | db.topic+
-div {
-  db.chapter.status.attribute = db.status.attribute
-  db.chapter.role.attribute = attribute role { text }
-  db.chapter.attlist =
-    db.chapter.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.label.attribute?
-    & db.chapter.status.attribute?
-  db.chapter.info = db._info.title.req
-  db.chapter =
-    
-    ## A chapter, as of a book
-    element chapter {
-      db.chapter.attlist, db.chapter.info, db.chapter.contentmodel?
-    }
-}
-db.part.components =
-  (db.navigation.components | db.components)
-  | (db.refentry | db.reference)
-db.part.contentmodel = db.part.components+ | db.topic+
-div {
-  db.part.status.attribute = db.status.attribute
-  db.part.role.attribute = attribute role { text }
-  db.part.attlist =
-    db.part.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.label.attribute?
-    & db.part.status.attribute?
-  db.part.info = db._info.title.req
-  db.part =
-    
-    ## A division in a book
-    element part {
-      db.part.attlist,
-      db.part.info,
-      db.partintro?,
-      db.part.contentmodel?
-    }
-}
-div {
-  db.preface.status.attribute = db.status.attribute
-  db.preface.role.attribute = attribute role { text }
-  db.preface.attlist =
-    db.preface.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.label.attribute?
-    & db.preface.status.attribute?
-  db.preface.info = db._info.title.req
-  db.preface =
-    
-    ## Introductory matter preceding the first chapter of a book
-    element preface {
-      db.preface.attlist, db.preface.info, db.component.contentmodel?
-    }
-}
-div {
-  db.partintro.status.attribute = db.status.attribute
-  db.partintro.role.attribute = attribute role { text }
-  db.partintro.attlist =
-    db.partintro.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.label.attribute?
-    & db.partintro.status.attribute?
-  db.partintro.info = db._info
-  db.partintro =
-    
-    ## An introduction to the contents of a part
-    element partintro {
-      db.partintro.attlist,
-      db.partintro.info,
-      db.toplevel.blocks.or.sections?
-    }
-}
-div {
-  db.section.status.attribute = db.status.attribute
-  db.section.role.attribute = attribute role { text }
-  db.section.attlist =
-    db.section.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.label.attribute?
-    & db.section.status.attribute?
-  db.section.info = db._info.title.req
-  db.section =
-    
-    ## A recursive section
-    element section {
-      db.section.attlist,
-      db.section.info,
-      db.recursive.blocks.or.sections?,
-      db.navigation.components*
-    }
-}
-div {
-  db.simplesect.status.attribute = db.status.attribute
-  db.simplesect.role.attribute = attribute role { text }
-  db.simplesect.attlist =
-    db.simplesect.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.label.attribute?
-    & db.simplesect.status.attribute?
-  db.simplesect.info = db._info.title.req
-  db.simplesect =
-    
-    ## A section of a document with no subdivisions
-    element simplesect {
-      db.simplesect.attlist, db.simplesect.info, db.all.blocks*
-    }
-}
-db.article.components = db.toplevel.sections
-db.article.navcomponents =
-  db.navigation.components
-  | db.acknowledgements
-  | db.dedication
-  | db.appendix
-  | db.colophon
-div {
-  db.article.status.attribute = db.status.attribute
-  db.article.class.enumeration =
-    
-    ## A collection of frequently asked questions.
-    "faq"
-    | 
-      ## An article in a journal or other periodical.
-      "journalarticle"
-    | 
-      ## A description of a product.
-      "productsheet"
-    | 
-      ## A specification.
-      "specification"
-    | 
-      ## A technical report.
-      "techreport"
-    | 
-      ## A white paper.
-      "whitepaper"
-  db.article.class.attribute =
-    
-    ## Identifies the nature of the article
-    attribute class { db.article.class.enumeration }
-  db.article.role.attribute = attribute role { text }
-  db.article.attlist =
-    db.article.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.label.attribute?
-    & db.article.status.attribute?
-    & db.article.class.attribute?
-  db.article.info = db._info.title.req
-  db.article =
-    
-    ## An article
-    element article {
-      db.article.attlist,
-      db.article.info,
-      db.article.navcomponents*,
-      ((db.all.blocks+, db.article.components?)
-       | db.article.components),
-      db.article.navcomponents*
-    }
-}
-db.annotations.attribute =
-  
-  ## Identifies one or more annotations that apply to this element
-  attribute annotations { text }
-div {
-  db.annotation.role.attribute = attribute role { text }
-  db.annotation.annotates.attribute =
-    
-    ## Identifies one ore more elements to which this annotation applies
-    attribute annotates { text }
-  db.annotation.attlist =
-    db.annotation.role.attribute?
-    & db.annotation.annotates.attribute?
-    & db.common.attributes
-  db.annotation.info = db._info.title.only
-  db.annotation =
-    
-    ## An annotation
-    [
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:annotation"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:annotation)"
-            "annotation must not occur among the children or descendants of annotation"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element annotation {
-      db.annotation.attlist, db.annotation.info, db.all.blocks+
-    }
-}
-db.xlink.extended.type.attribute =
-  
-  ## Identifies the XLink extended link type
-  [
-    s:pattern [
-      name = "XLink extended placement"
-      "\x{a}" ~
-      "            "
-      s:rule [
-        context = "*[@xlink:type='extended']"
-        "\x{a}" ~
-        "               "
-        s:assert [
-          test = "not(parent::*[@xlink:type='extended'])"
-          "An XLink extended type element may not occur as the direct child of an XLink extended type element."
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      "\x{a}" ~
-      "         "
-    ]
-  ]
-  attribute xlink:type {
-    
-    ## An XLink extended link type
-    "extended"
-  }
-db.xlink.locator.type.attribute =
-  
-  ## Identifies the XLink locator link type
-  [
-    s:pattern [
-      name = "XLink locator placement"
-      "\x{a}" ~
-      "            "
-      s:rule [
-        context = "*[@xlink:type='locator']"
-        "\x{a}" ~
-        "               "
-        s:assert [
-          test = "not(parent::*[@xlink:type='extended'])"
-          "An XLink locator type element must occur as the direct child of an XLink extended type element."
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      "\x{a}" ~
-      "         "
-    ]
-  ]
-  attribute xlink:type {
-    
-    ## An XLink locator link type
-    "locator"
-  }
-db.xlink.arc.type.attribute =
-  
-  ## Identifies the XLink arc link type
-  [
-    s:pattern [
-      name = "XLink arc placement"
-      "\x{a}" ~
-      "            "
-      s:rule [
-        context = "*[@xlink:type='arc']"
-        "\x{a}" ~
-        "               "
-        s:assert [
-          test = "parent::*[@xlink:type='extended']"
-          "An XLink arc type element must occur as the direct child of an XLink extended type element."
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      "\x{a}" ~
-      "         "
-    ]
-  ]
-  attribute xlink:type {
-    
-    ## An XLink arc link type
-    "arc"
-  }
-db.xlink.resource.type.attribute =
-  
-  ## Identifies the XLink resource link type
-  [
-    s:pattern [
-      name = "XLink resource placement"
-      "\x{a}" ~
-      "            "
-      s:rule [
-        context = "*[@xlink:type='resource']"
-        "\x{a}" ~
-        "               "
-        s:assert [
-          test = "not(parent::*[@xlink:type='extended'])"
-          "An XLink resource type element must occur as the direct child of an XLink extended type element."
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      "\x{a}" ~
-      "         "
-    ]
-  ]
-  attribute xlink:type {
-    
-    ## An XLink resource link type
-    "resource"
-  }
-db.xlink.title.type.attribute =
-  
-  ## Identifies the XLink title link type
-  [
-    s:pattern [
-      name = "XLink title placement"
-      "\x{a}" ~
-      "            "
-      s:rule [
-        context = "*[@xlink:type='title']"
-        "\x{a}" ~
-        "               "
-        s:assert [
-          test =
-            "not(parent::*[@xlink:type='extended']) and not(parent::*[@xlink:type='locator']) and not(parent::*[@xlink:type='arc'])"
-          "An XLink title type element must occur as the direct child of an XLink extended, locator, or arc type element."
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      "\x{a}" ~
-      "         "
-    ]
-  ]
-  attribute xlink:type {
-    
-    ## An XLink title link type
-    "title"
-  }
-db.xlink.extended.link.attributes =
-  db.xlink.extended.type.attribute
-  & db.xlink.role.attribute?
-  & db.xlink.title.attribute?
-db.xlink.locator.link.attributes =
-  db.xlink.locator.type.attribute
-  & db.xlink.href.attribute
-  & db.xlink.role.attribute?
-  & db.xlink.title.attribute?
-  & db.xlink.label.attribute?
-db.xlink.arc.link.attributes =
-  db.xlink.arc.type.attribute
-  & db.xlink.arcrole.attribute?
-  & db.xlink.title.attribute?
-  & db.xlink.show.attribute?
-  & db.xlink.actuate.attribute?
-  & db.xlink.from.attribute?
-  & db.xlink.to.attribute?
-db.xlink.resource.link.attributes =
-  db.xlink.resource.type.attribute
-  & db.xlink.role.attribute?
-  & db.xlink.title.attribute?
-  & db.xlink.label.attribute?
-db.xlink.title.link.attributes = db.xlink.title.type.attribute
-db.xlink.from.attribute =
-  
-  ## Specifies the XLink traversal-from
-  attribute xlink:from { xsd:NMTOKEN }
-db.xlink.label.attribute =
-  
-  ## Specifies the XLink label
-  attribute xlink:label { xsd:NMTOKEN }
-db.xlink.to.attribute =
-  
-  ## Specifies the XLink traversal-to
-  attribute xlink:to { xsd:NMTOKEN }
-div {
-  db.extendedlink.role.attribute = attribute role { text }
-  db.extendedlink.attlist =
-    db.extendedlink.role.attribute?
-    & db.common.attributes
-    & 
-      ## Identifies the XLink link type 
-      [ a:defaultValue = "extended" ]
-      attribute xlink:type {
-        
-        ## An XLink extended link
-        "extended"
-      }?
-    & db.xlink.role.attribute?
-    & db.xlink.title.attribute?
-  db.extendedlink =
-    
-    ## An XLink extended link
-    element extendedlink {
-      db.extendedlink.attlist, (db.locator | db.arc | db.link)+
-    }
-}
-div {
-  db.locator.role.attribute = attribute role { text }
-  db.locator.attlist =
-    db.locator.role.attribute?
-    & db.common.attributes
-    & 
-      ## Identifies the XLink link type 
-      [ a:defaultValue = "locator" ]
-      attribute xlink:type {
-        
-        ## An XLink locator link
-        "locator"
-      }?
-    & db.xlink.href.attribute
-    & db.xlink.role.attribute?
-    & db.xlink.title.attribute?
-    & db.xlink.label.attribute?
-  db.locator =
-    
-    ## An XLink locator in an extendedlink
-    element locator { db.locator.attlist, empty }
-}
-div {
-  db.arc.role.attribute = attribute role { text }
-  db.arc.attlist =
-    db.arc.role.attribute?
-    & db.common.attributes
-    & 
-      ## Identifies the XLink link type 
-      [ a:defaultValue = "arc" ]
-      attribute xlink:type {
-        
-        ## An XLink arc link
-        "arc"
-      }?
-    & db.xlink.arcrole.attribute?
-    & db.xlink.title.attribute?
-    & db.xlink.show.attribute?
-    & db.xlink.actuate.attribute?
-    & db.xlink.from.attribute?
-    & db.xlink.to.attribute?
-  db.arc =
-    
-    ## An XLink arc in an extendedlink
-    element arc { db.arc.attlist, empty }
-}
-db.sect1.sections = (db.sect2+, db.simplesect*) | db.simplesect+
-div {
-  db.sect1.status.attribute = db.status.attribute
-  db.sect1.role.attribute = attribute role { text }
-  db.sect1.attlist =
-    db.sect1.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.label.attribute?
-    & db.sect1.status.attribute?
-  db.sect1.info = db._info.title.req
-  db.sect1 =
-    
-    ## A top-level section of document
-    element sect1 {
-      db.sect1.attlist,
-      db.sect1.info,
-      ((db.all.blocks+, db.sect1.sections?) | db.sect1.sections)?,
-      db.navigation.components*
-    }
-}
-db.sect2.sections = (db.sect3+, db.simplesect*) | db.simplesect+
-div {
-  db.sect2.status.attribute = db.status.attribute
-  db.sect2.role.attribute = attribute role { text }
-  db.sect2.attlist =
-    db.sect2.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.label.attribute?
-    & db.sect2.status.attribute?
-  db.sect2.info = db._info.title.req
-  db.sect2 =
-    
-    ## A subsection within a sect1
-    element sect2 {
-      db.sect2.attlist,
-      db.sect2.info,
-      ((db.all.blocks+, db.sect2.sections?) | db.sect2.sections)?,
-      db.navigation.components*
-    }
-}
-db.sect3.sections = (db.sect4+, db.simplesect*) | db.simplesect+
-div {
-  db.sect3.status.attribute = db.status.attribute
-  db.sect3.role.attribute = attribute role { text }
-  db.sect3.attlist =
-    db.sect3.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.label.attribute?
-    & db.sect3.status.attribute?
-  db.sect3.info = db._info.title.req
-  db.sect3 =
-    
-    ## A subsection within a sect2
-    element sect3 {
-      db.sect3.attlist,
-      db.sect3.info,
-      ((db.all.blocks+, db.sect3.sections?) | db.sect3.sections)?,
-      db.navigation.components*
-    }
-}
-db.sect4.sections = (db.sect5+, db.simplesect*) | db.simplesect+
-div {
-  db.sect4.status.attribute = db.status.attribute
-  db.sect4.role.attribute = attribute role { text }
-  db.sect4.attlist =
-    db.sect4.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.label.attribute?
-    & db.sect4.status.attribute?
-  db.sect4.info = db._info.title.req
-  db.sect4 =
-    
-    ## A subsection within a sect3
-    element sect4 {
-      db.sect4.attlist,
-      db.sect4.info,
-      ((db.all.blocks+, db.sect4.sections?) | db.sect4.sections)?,
-      db.navigation.components*
-    }
-}
-db.sect5.sections = db.simplesect+
-div {
-  db.sect5.status.attribute = db.status.attribute
-  db.sect5.role.attribute = attribute role { text }
-  db.sect5.attlist =
-    db.sect5.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.label.attribute?
-    & db.sect5.status.attribute?
-  db.sect5.info = db._info.title.req
-  db.sect5 =
-    
-    ## A subsection within a sect4
-    element sect5 {
-      db.sect5.attlist,
-      db.sect5.info,
-      ((db.all.blocks+, db.sect5.sections?) | db.sect5.sections)?,
-      db.navigation.components*
-    }
-}
-db.toplevel.refsection = db.refsection+ | db.refsect1+
-db.secondlevel.refsection = db.refsection+ | db.refsect2+
-db.reference.components = db.refentry
-div {
-  db.reference.status.attribute = db.status.attribute
-  db.reference.role.attribute = attribute role { text }
-  db.reference.attlist =
-    db.reference.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.reference.status.attribute?
-    & db.label.attribute?
-  db.reference.info = db._info.title.req
-  db.reference =
-    
-    ## A collection of reference entries
-    element reference {
-      db.reference.attlist,
-      db.reference.info,
-      db.partintro?,
-      db.reference.components*
-    }
-}
-div {
-  db.refentry.status.attribute = db.status.attribute
-  db.refentry.role.attribute = attribute role { text }
-  db.refentry.attlist =
-    db.refentry.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.refentry.status.attribute?
-    & db.label.attribute?
-  db.refentry.info = db._info.title.forbidden
-  db.refentry =
-    
-    ## A reference page (originally a UNIX man-style reference page)
-    element refentry {
-      db.refentry.attlist,
-      db.indexterm*,
-      db.refentry.info,
-      db.refmeta?,
-      db.refnamediv+,
-      db.refsynopsisdiv?,
-      db.toplevel.refsection
-    }
-}
-div {
-  db.refmeta.role.attribute = attribute role { text }
-  db.refmeta.attlist =
-    db.refmeta.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.refmeta =
-    
-    ## Meta-information for a reference entry
-    element refmeta {
-      db.refmeta.attlist,
-      db.indexterm*,
-      db.refentrytitle,
-      db.manvolnum?,
-      db.refmiscinfo*,
-      db.indexterm*
-    }
-}
-db.refmiscinfo.class.enumeration =
-  
-  ## The name of the software product or component to which this topic applies
-  "source"
-  | 
-    ## The version of the software product or component to which this topic applies
-    "version"
-  | 
-    ## The section title of the reference page (e.g., User Commands)
-    "manual"
-  | 
-    ## The section title of the reference page (believed synonymous with "manual" but in wide use)
-    "sectdesc"
-  | 
-    ## The name of the software product or component to which this topic applies (e.g., SunOS x.y; believed synonymous with "source" but in wide use)
-    "software"
-db.refmiscinfo.class-enum.attribute =
-  
-  ## Identifies the kind of miscellaneous information
-  attribute class { db.refmiscinfo.class.enumeration }?
-db.refmiscinfo.class-other.attribute =
-  
-  ## Identifies the nature of non-standard miscellaneous information
-  attribute otherclass { text }
-db.refmiscinfo.class-other.attributes =
-  
-  ## Identifies the kind of miscellaneious information
-  attribute class {
-    
-    ## Indicates that the information is some 'other' kind.
-    "other"
-  }
-  & db.refmiscinfo.class-other.attribute
-db.refmiscinfo.class.attribute =
-  db.refmiscinfo.class-enum.attribute
-  | db.refmiscinfo.class-other.attributes
-div {
-  db.refmiscinfo.role.attribute = attribute role { text }
-  db.refmiscinfo.attlist =
-    db.refmiscinfo.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.refmiscinfo.class.attribute?
-  db.refmiscinfo =
-    
-    ## Meta-information for a reference entry other than the title and volume number
-    element refmiscinfo { db.refmiscinfo.attlist, db._text }
-}
-div {
-  db.refnamediv.role.attribute = attribute role { text }
-  db.refnamediv.attlist =
-    db.refnamediv.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.refnamediv =
-    
-    ## The name, purpose, and classification of a reference page
-    element refnamediv {
-      db.refnamediv.attlist,
-      db.refdescriptor?,
-      db.refname+,
-      db.refpurpose,
-      db.refclass*
-    }
-}
-div {
-  db.refdescriptor.role.attribute = attribute role { text }
-  db.refdescriptor.attlist =
-    db.refdescriptor.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.refdescriptor =
-    
-    ## A description of the topic of a reference page
-    element refdescriptor { db.refdescriptor.attlist, db.all.inlines* }
-}
-div {
-  db.refname.role.attribute = attribute role { text }
-  db.refname.attlist =
-    db.refname.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.refname =
-    
-    ## The name of (one of) the subject(s) of a reference page
-    element refname { db.refname.attlist, db.all.inlines* }
-}
-div {
-  db.refpurpose.role.attribute = attribute role { text }
-  db.refpurpose.attlist =
-    db.refpurpose.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.refpurpose =
-    
-    ## A short (one sentence) synopsis of the topic of a reference page
-    element refpurpose { db.refpurpose.attlist, db.all.inlines* }
-}
-div {
-  db.refclass.role.attribute = attribute role { text }
-  db.refclass.attlist =
-    db.refclass.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.refclass =
-    
-    ## The scope or other indication of applicability of a reference entry
-    element refclass { db.refclass.attlist, (text | db.application)* }
-}
-div {
-  db.refsynopsisdiv.role.attribute = attribute role { text }
-  db.refsynopsisdiv.attlist =
-    db.refsynopsisdiv.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.refsynopsisdiv.info = db._info
-  db.refsynopsisdiv =
-    
-    ## A syntactic synopsis of the subject of the reference page
-    element refsynopsisdiv {
-      db.refsynopsisdiv.attlist,
-      db.refsynopsisdiv.info,
-      ((db.all.blocks+, db.secondlevel.refsection?)
-       | db.secondlevel.refsection)
-    }
-}
-div {
-  db.refsection.status.attribute = db.status.attribute
-  db.refsection.role.attribute = attribute role { text }
-  db.refsection.attlist =
-    db.refsection.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.refsection.status.attribute?
-    & db.label.attribute?
-  db.refsection.info = db._info.title.req
-  db.refsection =
-    
-    ## A recursive section in a refentry
-    element refsection {
-      db.refsection.attlist,
-      db.refsection.info,
-      ((db.all.blocks+, db.refsection*) | db.refsection+)
-    }
-}
-db.refsect1.sections = db.refsect2+
-div {
-  db.refsect1.status.attribute = db.status.attribute
-  db.refsect1.role.attribute = attribute role { text }
-  db.refsect1.attlist =
-    db.refsect1.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.label.attribute?
-    & db.refsect1.status.attribute?
-  db.refsect1.info = db._info.title.req
-  db.refsect1 =
-    
-    ## A major subsection of a reference entry
-    element refsect1 {
-      db.refsect1.attlist,
-      db.refsect1.info,
-      ((db.all.blocks+, db.refsect1.sections?) | db.refsect1.sections)
-    }
-}
-db.refsect2.sections = db.refsect3+
-div {
-  db.refsect2.status.attribute = db.status.attribute
-  db.refsect2.role.attribute = attribute role { text }
-  db.refsect2.attlist =
-    db.refsect2.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.label.attribute?
-    & db.refsect2.status.attribute?
-  db.refsect2.info = db._info.title.req
-  db.refsect2 =
-    
-    ## A subsection of a refsect1
-    element refsect2 {
-      db.refsect2.attlist,
-      db.refsect2.info,
-      ((db.all.blocks+, db.refsect2.sections?) | db.refsect2.sections)
-    }
-}
-div {
-  db.refsect3.status.attribute = db.status.attribute
-  db.refsect3.role.attribute = attribute role { text }
-  db.refsect3.attlist =
-    db.refsect3.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.label.attribute?
-    & db.refsect3.status.attribute?
-  db.refsect3.info = db._info.title.req
-  db.refsect3 =
-    
-    ## A subsection of a refsect2
-    element refsect3 {
-      db.refsect3.attlist, db.refsect3.info, db.all.blocks+
-    }
-}
-db.glossary.inlines =
-  db.firstterm | db.glossterm | db._firstterm | db._glossterm
-db.baseform.attribute =
-  
-  ## Specifies the base form of the term, the one that appears in the glossary. This allows adjectival, plural, and other variations of the term to appear in the element. The element content is the default base form.
-  attribute baseform { text }?
-div {
-  db.glosslist.role.attribute = attribute role { text }
-  db.glosslist.attlist =
-    db.glosslist.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.glosslist.info = db._info.title.only
-  db.glosslist =
-    
-    ## A wrapper for a list of glossary entries
-    element glosslist {
-      db.glosslist.attlist,
-      db.glosslist.info?,
-      db.all.blocks*,
-      db.glossentry+
-    }
-}
-div {
-  db.glossentry.role.attribute = attribute role { text }
-  db.glossentry.sortas.attribute =
-    
-    ## Specifies the string by which the element's content is to be sorted; if unspecified, the content is used
-    attribute sortas { text }
-  db.glossentry.attlist =
-    db.glossentry.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.glossentry.sortas.attribute?
-  db.glossentry =
-    
-    ## An entry in a glossary or glosslist
-    element glossentry {
-      db.glossentry.attlist,
-      db.glossterm,
-      db.acronym?,
-      db.abbrev?,
-      db.indexterm*,
-      (db.glosssee | db.glossdef+)
-    }
-}
-div {
-  db.glossdef.role.attribute = attribute role { text }
-  db.glossdef.subject.attribute =
-    
-    ## Specifies a list of keywords for the definition
-    attribute subject { text }
-  db.glossdef.attlist =
-    db.glossdef.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.glossdef.subject.attribute?
-  db.glossdef =
-    
-    ## A definition in a glossentry
-    element glossdef {
-      db.glossdef.attlist, db.all.blocks+, db.glossseealso*
-    }
-}
-div {
-  db.glosssee.role.attribute = attribute role { text }
-  db.glosssee.otherterm.attribute =
-    
-    ## Identifies the other term
-    attribute otherterm { xsd:IDREF }
-  db.glosssee.attlist =
-    db.glosssee.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.glosssee.otherterm.attribute?
-  db.glosssee =
-    
-    ## A cross-reference from one glossentry
-    ##  to another
-    [
-      s:pattern [
-        name = "Glosssary 'see' type constraint"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:glosssee[@otherterm]"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test =
-              "local-name(//*[@xml:id=current()/@otherterm]) = 'glossentry' and namespace-uri(//*[@xml:id=current()/@otherterm]) = 'http://docbook.org/ns/docbook'"
-            "@otherterm on glosssee must point to a glossentry."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element glosssee { db.glosssee.attlist, db.all.inlines* }
-}
-div {
-  db.glossseealso.role.attribute = attribute role { text }
-  db.glossseealso.otherterm.attribute =
-    
-    ## Identifies the other term
-    attribute otherterm { xsd:IDREF }
-  db.glossseealso.attlist =
-    db.glossseealso.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.glossseealso.otherterm.attribute?
-  db.glossseealso =
-    
-    ## A cross-reference from one glossentry to another
-    [
-      s:pattern [
-        name = "Glossary 'seealso' type constraint"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:glossseealso[@otherterm]"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test =
-              "local-name(//*[@xml:id=current()/@otherterm]) = 'glossentry' and namespace-uri(//*[@xml:id=current()/@otherterm]) = 'http://docbook.org/ns/docbook'"
-            "@otherterm on glossseealso must point to a glossentry."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element glossseealso { db.glossseealso.attlist, db.all.inlines* }
-}
-div {
-  db.firstterm.role.attribute = attribute role { text }
-  db.firstterm.attlist =
-    db.firstterm.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.baseform.attribute
-  db.firstterm =
-    
-    ## The first occurrence of a term
-    [
-      s:pattern [
-        name = "Glossary 'firstterm' type constraint"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:firstterm[@linkend]"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test =
-              "local-name(//*[@xml:id=current()/@linkend]) = 'glossentry' and namespace-uri(//*[@xml:id=current()/@linkend]) = 'http://docbook.org/ns/docbook'"
-            "@linkend on firstterm must point to a glossentry."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element firstterm { db.firstterm.attlist, db.all.inlines* }
-}
-div {
-  db._firstterm.role.attribute = attribute role { text }
-  db._firstterm.attlist =
-    db._firstterm.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.baseform.attribute
-  db._firstterm =
-    
-    ## The first occurrence of a term, with limited content
-    [
-      s:pattern [
-        name = "Glossary 'firstterm' type constraint"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:firstterm[@linkend]"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test =
-              "local-name(//*[@xml:id=current()/@linkend]) = 'glossentry' and namespace-uri(//*[@xml:id=current()/@linkend]) = 'http://docbook.org/ns/docbook'"
-            "@linkend on firstterm must point to a glossentry."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element firstterm { db._firstterm.attlist, db._text }
-}
-div {
-  db.glossterm.role.attribute = attribute role { text }
-  db.glossterm.attlist =
-    db.glossterm.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.baseform.attribute
-  db.glossterm =
-    
-    ## A glossary term
-    [
-      s:pattern [
-        name = "Glossary 'glossterm' type constraint"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:glossterm[@linkend]"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test =
-              "local-name(//*[@xml:id=current()/@linkend]) = 'glossentry' and namespace-uri(//*[@xml:id=current()/@linkend]) = 'http://docbook.org/ns/docbook'"
-            "@linkend on glossterm must point to a glossentry."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element glossterm { db.glossterm.attlist, db.all.inlines* }
-}
-div {
-  db._glossterm.role.attribute = attribute role { text }
-  db._glossterm.attlist =
-    db._glossterm.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.baseform.attribute
-  db._glossterm =
-    
-    ## A glossary term
-    [
-      s:pattern [
-        name = "Glossary 'glossterm' type constraint"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:glossterm[@linkend]"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test =
-              "local-name(//*[@xml:id=current()/@linkend]) = 'glossentry' and namespace-uri(//*[@xml:id=current()/@linkend]) = 'http://docbook.org/ns/docbook'"
-            "@linkend on glossterm must point to a glossentry."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element glossterm { db._glossterm.attlist, db._text }
-}
-div {
-  db.glossary.status.attribute = db.status.attribute
-  db.glossary.role.attribute = attribute role { text }
-  db.glossary.attlist =
-    db.glossary.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.label.attribute?
-    & db.glossary.status.attribute?
-  db.glossary.info = db._info
-  db.glossary =
-    
-    ## A glossary
-    element glossary {
-      db.glossary.attlist,
-      db.glossary.info,
-      db.all.blocks*,
-      (db.glossdiv* | db.glossentry*),
-      db.bibliography?
-    }
-}
-div {
-  db.glossdiv.status.attribute = db.status.attribute
-  db.glossdiv.role.attribute = attribute role { text }
-  db.glossdiv.attlist =
-    db.glossdiv.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.label.attribute?
-    & db.glossdiv.status.attribute?
-  db.glossdiv.info = db._info.title.req
-  db.glossdiv =
-    
-    ## A division in a glossary
-    element glossdiv {
-      db.glossdiv.attlist,
-      db.glossdiv.info,
-      db.all.blocks*,
-      db.glossentry+
-    }
-}
-div {
-  db.termdef.role.attribute = attribute role { text }
-  db.termdef.attlist =
-    db.termdef.role.attribute?
-    & db.glossentry.sortas.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.baseform.attribute
-  db.termdef =
-    
-    ## An inline definition of a term
-    [
-      s:pattern [
-        name = "Glossary term definition constraint"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:termdef"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "count(db:firstterm) = 1"
-            "A termdef must contain exactly one firstterm"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element termdef { db.termdef.attlist, db.all.inlines* }
-}
-db.relation.attribute =
-  
-  ## Identifies the relationship between the bibliographic elemnts
-  attribute relation { text }
-div {
-  db.biblioentry.role.attribute = attribute role { text }
-  db.biblioentry.attlist =
-    db.biblioentry.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.biblioentry =
-    
-    ## A raw entry in a bibliography
-    element biblioentry {
-      db.biblioentry.attlist, db.bibliographic.elements+
-    }
-}
-div {
-  db.bibliomixed.role.attribute = attribute role { text }
-  db.bibliomixed.attlist =
-    db.bibliomixed.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.bibliomixed =
-    
-    ## A cooked entry in a bibliography
-    element bibliomixed {
-      db.bibliomixed.attlist,
-      ((db._text
-        | db.honorific
-        | db.firstname
-        | db.surname
-        | db.lineage
-        | db.othername
-        | db.bibliographic.elements)*
-       | (db._text
-          | db.honorific
-          | db.givenname
-          | db.surname
-          | db.lineage
-          | db.othername
-          | db.bibliographic.elements)*)
-    }
-}
-div {
-  db.biblioset.relation.attribute = db.relation.attribute
-  db.biblioset.role.attribute = attribute role { text }
-  db.biblioset.attlist =
-    db.biblioset.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.biblioset.relation.attribute?
-  db.biblioset =
-    
-    ## A raw container for related bibliographic information
-    element biblioset {
-      db.biblioset.attlist, db.bibliographic.elements+
-    }
-}
-div {
-  db.bibliomset.relation.attribute = db.relation.attribute
-  db.bibliomset.role.attribute = attribute role { text }
-  db.bibliomset.attlist =
-    db.bibliomset.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.bibliomset.relation.attribute?
-  db.bibliomset =
-    
-    ## A cooked container for related bibliographic information
-    element bibliomset {
-      db.bibliomset.attlist,
-      ((db._text
-        | db.honorific
-        | db.firstname
-        | db.surname
-        | db.lineage
-        | db.othername
-        | db.bibliographic.elements)*
-       | (db._text
-          | db.honorific
-          | db.givenname
-          | db.surname
-          | db.lineage
-          | db.othername
-          | db.bibliographic.elements)*)
-    }
-}
-div {
-  db.bibliomisc.role.attribute = attribute role { text }
-  db.bibliomisc.attlist =
-    db.bibliomisc.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.bibliomisc =
-    
-    ## Untyped bibliographic information
-    element bibliomisc { db.bibliomisc.attlist, db._text }
-}
-div {
-  db.bibliography.status.attrib = db.status.attribute
-  db.bibliography.role.attribute = attribute role { text }
-  db.bibliography.attlist =
-    db.bibliography.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.label.attribute?
-    & db.bibliography.status.attrib?
-  db.bibliography.info = db._info
-  db.bibliography =
-    
-    ## A bibliography
-    element bibliography {
-      db.bibliography.attlist,
-      db.bibliography.info,
-      db.all.blocks*,
-      (db.bibliodiv+ | (db.biblioentry | db.bibliomixed)+)
-    }
-}
-div {
-  db.bibliodiv.status.attrib = db.status.attribute
-  db.bibliodiv.role.attribute = attribute role { text }
-  db.bibliodiv.attlist =
-    db.bibliodiv.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.label.attribute?
-    & db.bibliodiv.status.attrib?
-  db.bibliodiv.info = db._info.title.req
-  db.bibliodiv =
-    
-    ## A section of a bibliography
-    element bibliodiv {
-      db.bibliodiv.attlist,
-      db.bibliodiv.info,
-      db.all.blocks*,
-      (db.biblioentry | db.bibliomixed)+
-    }
-}
-div {
-  db.bibliolist.role.attribute = attribute role { text }
-  db.bibliolist.attlist =
-    db.bibliolist.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.bibliolist.info = db._info.title.only
-  db.bibliolist =
-    
-    ## A wrapper for a list of bibliography entries
-    element bibliolist {
-      db.bibliolist.attlist,
-      db.bibliolist.info?,
-      db.all.blocks*,
-      (db.biblioentry | db.bibliomixed)+
-    }
-}
-div {
-  db.biblioref.role.attribute = attribute role { text }
-  db.biblioref.xrefstyle.attribute = db.xrefstyle.attribute
-  db.biblioref.endterm.attribute = db.endterm.attribute
-  db.biblioref.units.attribute =
-    
-    ## The units (for example, pages) used to identify the beginning and ending of a reference.
-    attribute units { xsd:token }
-  db.biblioref.begin.attribute =
-    
-    ## Identifies the beginning of a reference; the location within the work that is being referenced.
-    attribute begin { xsd:token }
-  db.biblioref.end.attribute =
-    
-    ## Identifies the end of a reference.
-    attribute end { xsd:token }
-  db.biblioref.attlist =
-    db.biblioref.role.attribute?
-    & db.common.attributes
-    & db.common.req.linking.attributes
-    & db.biblioref.xrefstyle.attribute?
-    & db.biblioref.endterm.attribute?
-    & db.biblioref.units.attribute?
-    & db.biblioref.begin.attribute?
-    & db.biblioref.end.attribute?
-  db.biblioref =
-    
-    ## A cross-reference to a bibliographic entry
-    element biblioref { db.biblioref.attlist, empty }
-}
-db.significance.enumeration =
-  
-  ## Normal
-  "normal"
-  | 
-    ## Preferred
-    "preferred"
-db.significance.attribute =
-  
-  ## Specifies the significance of the term
-  attribute significance { db.significance.enumeration }
-db.zone.attribute =
-  
-  ## Specifies the IDs of the elements to which this term applies
-  attribute zone { xsd:IDREFS }
-db.indexterm.pagenum.attribute =
-  
-  ## Indicates the page on which this index term occurs in some version of the printed document
-  attribute pagenum { text }
-db.scope.enumeration =
-  
-  ## All indexes
-  "all"
-  | 
-    ## The global index (as for a combined index of a set of books)
-    "global"
-  | 
-    ## The local index (the index for this document only)
-    "local"
-db.scope.attribute =
-  
-  ## Specifies the scope of the index term
-  attribute scope { db.scope.enumeration }
-db.sortas.attribute =
-  
-  ## Specifies the string by which the term is to be sorted; if unspecified, the term content is used
-  attribute sortas { text }
-db.index.type.attribute =
-  
-  ## Specifies the target index for this term
-  attribute type { text }
-div {
-  db.itermset.role.attribute = attribute role { text }
-  db.itermset.attlist =
-    db.itermset.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.itermset =
-    
-    ## A set of index terms in the meta-information of a document
-    element itermset { db.itermset.attlist, db.indexterm.singular+ }
-}
-db.indexterm.contentmodel =
-  db.primary?,
-  ((db.secondary,
-    ((db.tertiary, (db.see | db.seealso+)?)
-     | db.see
-     | db.seealso+)?)
-   | db.see
-   | db.seealso+)?
-div {
-  db.indexterm.singular.role.attribute = attribute role { text }
-  db.indexterm.singular.class.attribute =
-    
-    ## Identifies the class of index term
-    attribute class {
-      
-      ## A singular index term
-      "singular"
-    }
-  db.indexterm.singular.attlist =
-    db.indexterm.singular.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.significance.attribute?
-    & db.zone.attribute?
-    & db.indexterm.pagenum.attribute?
-    & db.scope.attribute?
-    & db.index.type.attribute?
-    & db.indexterm.singular.class.attribute?
-  db.indexterm.singular =
-    
-    ## A wrapper for an indexed term
-    element indexterm {
-      db.indexterm.singular.attlist, db.indexterm.contentmodel
-    }
-}
-div {
-  db.indexterm.startofrange.role.attribute = attribute role { text }
-  db.indexterm.startofrange.class.attribute =
-    
-    ## Identifies the class of index term
-    attribute class {
-      
-      ## The start of a range
-      "startofrange"
-    }
-  db.indexterm.startofrange.attlist =
-    db.indexterm.startofrange.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.significance.attribute?
-    & db.zone.attribute?
-    & db.indexterm.pagenum.attribute?
-    & db.scope.attribute?
-    & db.index.type.attribute?
-    & db.indexterm.startofrange.class.attribute
-  db.indexterm.startofrange =
-    
-    ## A wrapper for an indexed term that covers a range
-    element indexterm {
-      db.indexterm.startofrange.attlist, db.indexterm.contentmodel
-    }
-}
-div {
-  db.indexterm.endofrange.role.attribute = attribute role { text }
-  db.indexterm.endofrange.class.attribute =
-    
-    ## Identifies the class of index term
-    attribute class {
-      
-      ## The end of a range
-      "endofrange"
-    }
-  db.indexterm.endofrange.startref.attribute =
-    
-    ## Points to the start of the range
-    attribute startref { xsd:IDREF }
-  db.indexterm.endofrange.attlist =
-    db.indexterm.endofrange.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.indexterm.endofrange.class.attribute
-    & db.indexterm.endofrange.startref.attribute
-  db.indexterm.endofrange =
-    
-    ## Identifies the end of a range associated with an indexed term
-    element indexterm { db.indexterm.endofrange.attlist, empty }
-}
-div {
-  db.indexterm =
-    db.indexterm.singular
-    | db.indexterm.startofrange
-    | db.indexterm.endofrange
-}
-div {
-  db.primary.role.attribute = attribute role { text }
-  db.primary.attlist =
-    db.primary.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.sortas.attribute?
-  db.primary =
-    
-    ## The primary word or phrase under which an index term should be sorted
-    element primary { db.primary.attlist, db.all.inlines* }
-}
-div {
-  db.secondary.role.attribute = attribute role { text }
-  db.secondary.attlist =
-    db.secondary.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.sortas.attribute?
-  db.secondary =
-    
-    ## A secondary word or phrase in an index term
-    element secondary { db.secondary.attlist, db.all.inlines* }
-}
-div {
-  db.tertiary.role.attribute = attribute role { text }
-  db.tertiary.attlist =
-    db.tertiary.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.sortas.attribute?
-  db.tertiary =
-    
-    ## A tertiary word or phrase in an index term
-    element tertiary { db.tertiary.attlist, db.all.inlines* }
-}
-div {
-  db.see.role.attribute = attribute role { text }
-  db.see.attlist =
-    db.see.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.see =
-    
-    ## Part of an index term directing the reader instead to another entry in the index
-    element see { db.see.attlist, db.all.inlines* }
-}
-div {
-  db.seealso.role.attribute = attribute role { text }
-  db.seealso.attlist =
-    db.seealso.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.seealso =
-    
-    ## Part of an index term directing the reader also to another entry in the index
-    element seealso { db.seealso.attlist, db.all.inlines* }
-}
-div {
-  db.index.status.attribute = db.status.attribute
-  db.index.role.attribute = attribute role { text }
-  db.index.attlist =
-    db.index.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.label.attribute?
-    & db.index.status.attribute?
-    & db.index.type.attribute?
-  db.index.info = db._info
-  # Yes, db.indexdiv* and db.indexentry*; that way an <index/> is valid.
-  # Authors can use an empty index to indicate where a generated index should
-  # appear.
-  db.index =
-    
-    ## An index to a book or part of a book
-    element index {
-      db.index.attlist,
-      db.index.info,
-      db.all.blocks*,
-      (db.indexdiv* | db.indexentry* | db.segmentedlist)
-    }
-}
-div {
-  db.setindex.status.attribute = db.status.attribute
-  db.setindex.role.attribute = attribute role { text }
-  db.setindex.attlist =
-    db.setindex.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.label.attribute?
-    & db.setindex.status.attribute?
-    & db.index.type.attribute?
-  db.setindex.info = db._info
-  db.setindex =
-    
-    ## An index to a set of books
-    element setindex {
-      db.setindex.attlist,
-      db.setindex.info,
-      db.all.blocks*,
-      (db.indexdiv* | db.indexentry*)
-    }
-}
-div {
-  db.indexdiv.status.attribute = db.status.attribute
-  db.indexdiv.role.attribute = attribute role { text }
-  db.indexdiv.attlist =
-    db.indexdiv.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.label.attribute?
-    & db.indexdiv.status.attribute?
-  db.indexdiv.info = db._info.title.req
-  db.indexdiv =
-    
-    ## A division in an index
-    element indexdiv {
-      db.indexdiv.attlist,
-      db.indexdiv.info,
-      db.all.blocks*,
-      (db.indexentry+ | db.segmentedlist)
-    }
-}
-div {
-  db.indexentry.role.attribute = attribute role { text }
-  db.indexentry.attlist =
-    db.indexentry.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.indexentry =
-    
-    ## An entry in an index
-    element indexentry {
-      db.indexentry.attlist,
-      db.primaryie,
-      (db.seeie | db.seealsoie)*,
-      (db.secondaryie, (db.seeie | db.seealsoie | db.tertiaryie)*)*
-    }
-}
-div {
-  db.primaryie.role.attribute = attribute role { text }
-  db.primaryie.attlist =
-    db.primaryie.role.attribute?
-    & db.common.attributes
-    & db.linkends.attribute?
-  db.primaryie =
-    
-    ## A primary term in an index entry, not in the text
-    element primaryie { db.primaryie.attlist, db.all.inlines* }
-}
-div {
-  db.secondaryie.role.attribute = attribute role { text }
-  db.secondaryie.attlist =
-    db.secondaryie.role.attribute?
-    & db.common.attributes
-    & db.linkends.attribute?
-  db.secondaryie =
-    
-    ## A secondary term in an index entry, rather than in the text
-    element secondaryie { db.secondaryie.attlist, db.all.inlines* }
-}
-div {
-  db.tertiaryie.role.attribute = attribute role { text }
-  db.tertiaryie.attlist =
-    db.tertiaryie.role.attribute?
-    & db.common.attributes
-    & db.linkends.attribute?
-  db.tertiaryie =
-    
-    ## A tertiary term in an index entry, rather than in the text
-    element tertiaryie { db.tertiaryie.attlist, db.all.inlines* }
-}
-div {
-  db.seeie.role.attribute = attribute role { text }
-  db.seeie.attlist =
-    db.seeie.role.attribute?
-    & db.common.attributes
-    & db.linkend.attribute?
-  db.seeie =
-    
-    ## A See
-    ## entry in an index, rather than in the text
-    element seeie { db.seeie.attlist, db.all.inlines* }
-}
-div {
-  db.seealsoie.role.attribute = attribute role { text }
-  db.seealsoie.attlist =
-    db.seealsoie.role.attribute?
-    & db.common.attributes
-    & db.linkends.attribute?
-  db.seealsoie =
-    
-    ## A See also
-    ##  entry in an index, rather than in the text
-    element seealsoie { db.seealsoie.attlist, db.all.inlines* }
-}
-db.toc.pagenum.attribute =
-  
-  ## Indicates the page on which this element occurs in some version of the printed document
-  attribute pagenum { text }
-div {
-  db.toc.role.attribute = attribute role { text }
-  db.toc.attlist =
-    db.toc.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.toc.info = db._info.title.only
-  db.toc =
-    
-    ## A table of contents
-    element toc {
-      db.toc.attlist,
-      db.toc.info,
-      db.all.blocks*,
-      (db.tocdiv | db.tocentry)*
-    }
-}
-div {
-  db.tocdiv.role.attribute = attribute role { text }
-  db.tocdiv.pagenum.attribute = db.toc.pagenum.attribute
-  db.tocdiv.attlist =
-    db.tocdiv.role.attribute?
-    & db.common.attributes
-    & db.tocdiv.pagenum.attribute?
-    & db.linkend.attribute?
-  db.tocdiv.info = db._info
-  db.tocdiv =
-    
-    ## A division in a table of contents
-    element tocdiv {
-      db.tocdiv.attlist,
-      db.tocdiv.info,
-      db.all.blocks*,
-      (db.tocdiv | db.tocentry)+
-    }
-}
-div {
-  db.tocentry.role.attribute = attribute role { text }
-  db.tocentry.pagenum.attribute = db.toc.pagenum.attribute
-  db.tocentry.attlist =
-    db.tocentry.role.attribute?
-    & db.common.attributes
-    & db.tocentry.pagenum.attribute?
-    & db.linkend.attribute?
-  db.tocentry =
-    
-    ## A component title in a table of contents
-    element tocentry { db.tocentry.attlist, db.all.inlines* }
-}
-db.task.info = db._info.title.req
-div {
-  db.task.role.attribute = attribute role { text }
-  db.task.attlist =
-    db.task.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.task =
-    
-    ## A task to be completed
-    element task {
-      db.task.attlist,
-      db.task.info,
-      db.tasksummary?,
-      db.taskprerequisites?,
-      db.procedure+,
-      db.example*,
-      db.taskrelated?
-    }
-}
-div {
-  db.tasksummary.role.attribute = attribute role { text }
-  db.tasksummary.attlist =
-    db.tasksummary.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.tasksummary.info = db._info.title.only
-  db.tasksummary =
-    
-    ## A summary of a task
-    element tasksummary {
-      db.tasksummary.attlist, db.tasksummary.info, db.all.blocks+
-    }
-}
-div {
-  db.taskprerequisites.role.attribute = attribute role { text }
-  db.taskprerequisites.attlist =
-    db.taskprerequisites.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.taskprerequisites.info = db._info.title.only
-  db.taskprerequisites =
-    
-    ## The prerequisites for a task
-    element taskprerequisites {
-      db.taskprerequisites.attlist,
-      db.taskprerequisites.info,
-      db.all.blocks+
-    }
-}
-div {
-  db.taskrelated.role.attribute = attribute role { text }
-  db.taskrelated.attlist =
-    db.taskrelated.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.taskrelated.info = db._info.title.only
-  db.taskrelated =
-    
-    ## Information related to a task
-    element taskrelated {
-      db.taskrelated.attlist, db.taskrelated.info, db.all.blocks+
-    }
-}
-db.area.units.enumeration =
-  
-  ## Coordinates expressed as a pair of CALS graphic coordinates.
-  "calspair"
-  | 
-    ## Coordinates expressed as a line and column.
-    "linecolumn"
-  | 
-    ## Coordinates expressed as a pair of lines and columns.
-    "linecolumnpair"
-  | 
-    ## Coordinates expressed as a line range.
-    "linerange"
-db.area.units-enum.attribute =
-  
-  ## Identifies the units used in the coords attribute. The default units vary according to the type of callout specified: calspair
-  ##  for graphics and linecolumn
-  ##  for line-oriented elements.
-  attribute units { db.area.units.enumeration }?
-db.area.units-other.attributes =
-  
-  ## Indicates that non-standard units are used for this area
-  ## . In this case otherunits
-  ##  must be specified.
-  attribute units {
-    
-    ## Coordinates expressed in some non-standard units.
-    "other"
-  }?,
-  
-  ## Identifies the units used in the coords
-  ##  attribute when the units
-  ##  attribute is other
-  ## . This attribute is forbidden otherwise.
-  attribute otherunits { xsd:NMTOKEN }
-db.area.units.attribute =
-  db.area.units-enum.attribute | db.area.units-other.attributes
-div {
-  db.calloutlist.role.attribute = attribute role { text }
-  db.calloutlist.attlist =
-    db.calloutlist.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.calloutlist.info = db._info.title.only
-  db.calloutlist =
-    
-    ## A list of callout
-    ## s
-    element calloutlist {
-      db.calloutlist.attlist,
-      db.calloutlist.info,
-      db.all.blocks*,
-      db.callout+
-    }
-}
-div {
-  db.callout.role.attribute = attribute role { text }
-  db.callout.arearefs.attribute =
-    
-    ## Identifies the areas described by this callout.
-    attribute arearefs { xsd:IDREFS }
-  db.callout.attlist =
-    db.callout.role.attribute?
-    & db.common.attributes
-    & db.callout.arearefs.attribute
-  db.callout =
-    
-    ## A called out
-    ##  description of a marked area
-    element callout { db.callout.attlist, db.all.blocks+ }
-}
-div {
-  db.programlistingco.role.attribute = attribute role { text }
-  db.programlistingco.attlist =
-    db.programlistingco.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.programlistingco.info = db._info.title.forbidden
-  db.programlistingco =
-    
-    ## A program listing with associated areas used in callouts
-    element programlistingco {
-      db.programlistingco.attlist,
-      db.programlistingco.info,
-      db.areaspec,
-      db.programlisting,
-      db.calloutlist*
-    }
-}
-div {
-  db.areaspec.role.attribute = attribute role { text }
-  db.areaspec.attlist =
-    db.areaspec.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.area.units.attribute
-  db.areaspec =
-    
-    ## A collection of regions in a graphic or code example
-    element areaspec { db.areaspec.attlist, (db.area | db.areaset)+ }
-}
-div {
-  db.area.role.attribute = attribute role { text }
-  db.area.linkends.attribute =
-    
-    ## Point to the callout
-    ## s which refer to this area. (This provides bidirectional linking which may be useful in online presentation.)
-    attribute linkends { xsd:IDREFS }
-  db.area.label.attribute =
-    
-    ## Specifies an identifying number or string that may be used in presentation. The area label might be drawn on top of the figure, for example, at the position indicated by the coords attribute.
-    attribute label { text }
-  db.area.coords.attribute =
-    
-    ## Provides the coordinates of the area. The coordinates must be interpreted using the units
-    ##  specified.
-    attribute coords { text }
-  db.area.attlist =
-    db.area.role.attribute?
-    & db.common.idreq.attributes
-    & db.area.units.attribute
-    & (db.area.linkends.attribute | db.xlink.simple.link.attributes)?
-    & db.area.label.attribute?
-    & db.area.coords.attribute
-  db.area =
-    
-    ## A region defined for a callout in a graphic or code example
-    element area { db.area.attlist, db.alt? }
-}
-div {
-  # The only difference is that xml:id is optional
-  db.area.inareaset.attlist =
-    db.area.role.attribute?
-    & db.common.attributes
-    & db.area.units.attribute
-    & (db.area.linkends.attribute | db.xlink.simple.link.attributes)?
-    & db.area.label.attribute?
-    & db.area.coords.attribute
-  db.area.inareaset =
-    
-    ## A region defined for a callout in a graphic or code example
-    element area { db.area.inareaset.attlist, db.alt? }
-}
-div {
-  db.areaset.role.attribute = attribute role { text }
-  db.areaset.linkends.attribute = db.linkends.attribute
-  db.areaset.label.attribute = db.label.attribute
-  db.areaset.attlist =
-    db.areaset.role.attribute?
-    & db.common.idreq.attributes
-    & db.area.units.attribute
-    & (db.areaset.linkends.attribute | db.xlink.simple.link.attributes)?
-    & db.areaset.label.attribute?
-  db.areaset =
-    
-    ## A set of related areas in a graphic or code example
-    element areaset { db.areaset.attlist, db.area.inareaset+ }
-}
-div {
-  db.screenco.role.attribute = attribute role { text }
-  db.screenco.attlist =
-    db.screenco.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.screenco.info = db._info.title.forbidden
-  db.screenco =
-    
-    ## A screen with associated areas used in callouts
-    element screenco {
-      db.screenco.attlist,
-      db.screenco.info,
-      db.areaspec,
-      db.screen,
-      db.calloutlist*
-    }
-}
-div {
-  db.imageobjectco.role.attribute = attribute role { text }
-  db.imageobjectco.attlist =
-    db.imageobjectco.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.imageobjectco.info = db._info.title.forbidden
-  db.imageobjectco =
-    
-    ## A wrapper for an image object with callouts
-    element imageobjectco {
-      db.imageobjectco.attlist,
-      db.imageobjectco.info,
-      db.areaspec,
-      db.imageobject+,
-      db.calloutlist*
-    }
-}
-div {
-  db.co.role.attribute = attribute role { text }
-  db.co.linkends.attribute = db.linkends.attribute
-  db.co.label.attribute = db.label.attribute
-  db.co.attlist =
-    db.co.role.attribute?
-    & db.common.idreq.attributes
-    & db.co.linkends.attribute?
-    & db.co.label.attribute?
-  db.co =
-    
-    ## The location of a callout embedded in text
-    element co { db.co.attlist, empty }
-}
-div {
-  db.coref.role.attribute = attribute role { text }
-  db.coref.label.attribute = db.label.attribute
-  db.coref.attlist =
-    db.coref.role.attribute?
-    & db.common.attributes
-    & db.linkend.attribute
-    & db.coref.label.attribute?
-  db.coref =
-    
-    ## A cross reference to a co
-    element coref { db.coref.attlist, empty }
-}
-div {
-  db.productionset.role.attribute = attribute role { text }
-  db.productionset.attlist =
-    db.productionset.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.productionset.info = db._info.title.only
-  db.productionset =
-    
-    ## A set of EBNF productions
-    element productionset {
-      db.productionset.attlist,
-      db.productionset.info,
-      (db.production | db.productionrecap)+
-    }
-}
-div {
-  db.production.role.attribute = attribute role { text }
-  db.production.attlist =
-    db.production.role.attribute?
-    & db.common.idreq.attributes
-    & db.common.linking.attributes
-  db.production =
-    
-    ## A production in a set of EBNF productions
-    element production {
-      db.production.attlist, db.lhs, db.rhs+, db.constraint*
-    }
-}
-div {
-  db.lhs.role.attribute = attribute role { text }
-  db.lhs.attlist =
-    db.lhs.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.lhs =
-    
-    ## The left-hand side of an EBNF production
-    element lhs { db.lhs.attlist, text }
-}
-div {
-  db.rhs.role.attribute = attribute role { text }
-  db.rhs.attlist =
-    db.rhs.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.rhs =
-    
-    ## The right-hand side of an EBNF production
-    element rhs {
-      db.rhs.attlist,
-      (text | db.nonterminal | db.lineannotation | db.sbr)*
-    }
-}
-div {
-  db.nonterminal.role.attribute = attribute role { text }
-  db.nonterminal.def.attribute =
-    
-    ## Specifies a URI that points to a production
-    ## where the nonterminal
-    ##  is defined
-    attribute def { xsd:anyURI }
-  db.nonterminal.attlist =
-    db.nonterminal.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.nonterminal.def.attribute
-  db.nonterminal =
-    
-    ## A non-terminal in an EBNF production
-    element nonterminal { db.nonterminal.attlist, text }
-}
-div {
-  db.constraint.role.attribute = attribute role { text }
-  db.constraint.attlist =
-    db.constraint.role.attribute?
-    & db.common.attributes
-    & db.common.req.linking.attributes
-  db.constraint =
-    
-    ## A constraint in an EBNF production
-    element constraint { db.constraint.attlist, empty }
-}
-div {
-  db.productionrecap.role.attribute = attribute role { text }
-  db.productionrecap.attlist =
-    db.productionrecap.role.attribute?
-    & db.common.attributes
-    & db.common.req.linking.attributes
-  db.productionrecap =
-    
-    ## A cross-reference to an EBNF production
-    element productionrecap { db.productionrecap.attlist, empty }
-}
-div {
-  db.constraintdef.role.attribute = attribute role { text }
-  db.constraintdef.attlist =
-    db.constraintdef.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.constraintdef.info = db._info.title.only
-  db.constraintdef =
-    
-    ## The definition of a constraint in an EBNF production
-    element constraintdef {
-      db.constraintdef.attlist, db.constraintdef.info, db.all.blocks+
-    }
-}
-db.char.attribute =
-  
-  ## Specifies the alignment character when align
-  ##  is set to char
-  ## .
-  attribute char { text }
-db.charoff.attribute =
-  
-  ## Specifies the percentage of the column's total width that should appear to the left of the first occurance of the character identified in char
-  ##  when align
-  ##  is set to char
-  ## .
-  attribute charoff {
-    xsd:decimal { minExclusive = "0" maxExclusive = "100" }
-  }
-db.frame.attribute =
-  
-  ## Specifies how the table is to be framed. Note that there is no way to obtain a border on only the starting edge (left, in left-to-right writing systems) of the table.
-  attribute frame {
-    
-    ## Frame all four sides of the table. In some environments with limited control over table border formatting, such as HTML, this may imply additional borders.
-    "all"
-    | 
-      ## Frame only the bottom of the table.
-      "bottom"
-    | 
-      ## Place no border on the table. In some environments with limited control over table border formatting, such as HTML, this may disable other borders as well.
-      "none"
-    | 
-      ## Frame the left and right sides of the table.
-      "sides"
-    | 
-      ## Frame the top of the table.
-      "top"
-    | 
-      ## Frame the top and bottom of the table.
-      "topbot"
-  }
-db.colsep.attribute =
-  
-  ## Specifies the presence or absence of the column separator
-  attribute colsep {
-    
-    ## No column separator rule.
-    "0"
-    | 
-      ## Provide a column separator rule on the right
-      "1"
-  }
-db.rowsep.attribute =
-  
-  ## Specifies the presence or absence of the row separator
-  attribute rowsep {
-    
-    ## No row separator rule.
-    "0"
-    | 
-      ## Provide a row separator rule below
-      "1"
-  }
-db.orient.attribute =
-  
-  ## Specifies the orientation of the table
-  attribute orient {
-    
-    ## 90 degrees counter-clockwise from the rest of the text flow.
-    "land"
-    | 
-      ## The same orientation as the rest of the text flow.
-      "port"
-  }
-db.tabstyle.attribute =
-  
-  ## Specifies the table style
-  attribute tabstyle { text }
-db.rowheader.attribute =
-  
-  ## Indicates whether or not the entries in the first column should be considered row headers
-  attribute rowheader {
-    
-    ## Indicates that entries in the first column of the table are functionally row headers (analogous to the way that a thead provides column headers).
-    "firstcol"
-    | 
-      ## Indicates that entries in the first column have no special significance with respect to column headers.
-      "norowheader"
-  }
-db.align.attribute =
-  
-  ## Specifies the horizontal alignment of text in an entry.
-  attribute align {
-    
-    ## Centered.
-    "center"
-    | 
-      ## Aligned on a particular character.
-      "char"
-    | 
-      ## Left and right justified.
-      "justify"
-    | 
-      ## Left justified.
-      "left"
-    | 
-      ## Right justified.
-      "right"
-  }
-db.valign.attribute =
-  
-  ## Specifies the vertical alignment of text in an entry.
-  attribute valign {
-    
-    ## Aligned on the bottom of the entry.
-    "bottom"
-    | 
-      ## Aligned in the middle.
-      "middle"
-    | 
-      ## Aligned at the top of the entry.
-      "top"
-  }
-db.specify-col-by-colname.attributes =
-  
-  ## Specifies a column specification by name.
-  attribute colname { text }
-db.specify-col-by-namest.attributes =
-  
-  ## Specifies a starting column by name.
-  attribute namest { text }
-db.specify-span-by-spanspec.attributes =
-  
-  ## Specifies a span by name.
-  attribute spanname { text }
-db.specify-span-directly.attributes =
-  
-  ## Specifies a starting column by name.
-  attribute namest { text }
-  & 
-    ## Specifies an ending column by name.
-    attribute nameend { text }
-db.column-spec.attributes =
-  db.specify-col-by-colname.attributes
-  | db.specify-col-by-namest.attributes
-  | db.specify-span-by-spanspec.attributes
-  | db.specify-span-directly.attributes
-db.colname.attribute =
-  
-  ## Provides a name for a column specification.
-  attribute colname { text }
-db.spanname.attribute =
-  
-  ## Provides a name for a span specification.
-  attribute spanname { text }
-div {
-  db.tgroup.role.attribute = attribute role { text }
-  db.tgroup.tgroupstyle.attribute =
-    
-    ## Additional style information for downstream processing; typically the name of a style.
-    attribute tgroupstyle { text }
-  db.tgroup.cols.attribute =
-    
-    ## The number of columns in the table. Must be an integer greater than zero.
-    attribute cols { xsd:positiveInteger }
-  db.tgroup.attlist =
-    db.tgroup.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.char.attribute?
-    & db.charoff.attribute?
-    & db.tgroup.tgroupstyle.attribute?
-    & db.tgroup.cols.attribute
-    & db.colsep.attribute?
-    & db.rowsep.attribute?
-    & db.align.attribute?
-  db.tgroup =
-    
-    ## A wrapper for the main content of a table, or part of a table
-    element tgroup {
-      db.tgroup.attlist,
-      db.colspec*,
-      db.spanspec*,
-      db.cals.thead?,
-      db.cals.tfoot?,
-      db.cals.tbody
-    }
-}
-div {
-  db.colspec.role.attribute = attribute role { text }
-  db.colspec.colnum.attribute =
-    
-    ## The number of the column to which this specification applies. Must be greater than any preceding column number. Defaults to one more than the number of the preceding column, if there is one, or one.
-    attribute colnum { xsd:positiveInteger }
-  db.colspec.colwidth.attribute =
-    
-    ## Specifies the width of the column.
-    attribute colwidth { text }
-  db.colspec.attlist =
-    db.colspec.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.colspec.colnum.attribute?
-    & db.char.attribute?
-    & db.colsep.attribute?
-    & db.colspec.colwidth.attribute?
-    & db.charoff.attribute?
-    & db.colname.attribute?
-    & db.rowsep.attribute?
-    & db.align.attribute?
-  db.colspec =
-    
-    ## Specifications for a column in a table
-    element colspec { db.colspec.attlist, empty }
-}
-div {
-  db.spanspec.role.attribute = attribute role { text }
-  db.spanspec.namest.attribute =
-    
-    ## Specifies a starting column by name.
-    attribute namest { text }
-  db.spanspec.nameend.attribute =
-    
-    ## Specifies an ending column by name.
-    attribute nameend { text }
-  db.spanspec.attlist =
-    db.spanspec.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.spanname.attribute
-    & db.spanspec.namest.attribute
-    & db.spanspec.nameend.attribute
-    & db.char.attribute?
-    & db.colsep.attribute?
-    & db.charoff.attribute?
-    & db.rowsep.attribute?
-    & db.align.attribute?
-  db.spanspec =
-    
-    ## Formatting information for a spanned column in a table
-    element spanspec { db.spanspec.attlist, empty }
-}
-div {
-  db.cals.thead.role.attribute = attribute role { text }
-  db.cals.thead.attlist =
-    db.cals.thead.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.valign.attribute?
-  db.cals.thead =
-    
-    ## A table header consisting of one or more rows
-    element thead { db.cals.thead.attlist, db.colspec*, db.row+ }
-}
-div {
-  db.cals.tfoot.role.attribute = attribute role { text }
-  db.cals.tfoot.attlist =
-    db.cals.tfoot.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.valign.attribute?
-  db.cals.tfoot =
-    
-    ## A table footer consisting of one or more rows
-    element tfoot { db.cals.tfoot.attlist, db.colspec*, db.row+ }
-}
-div {
-  db.cals.tbody.role.attribute = attribute role { text }
-  db.cals.tbody.attlist =
-    db.cals.tbody.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.valign.attribute?
-  db.cals.tbody =
-    
-    ## A wrapper for the rows of a table or informal table
-    element tbody { db.cals.tbody.attlist, db.row+ }
-}
-div {
-  db.row.role.attribute = attribute role { text }
-  db.row.attlist =
-    db.row.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.rowsep.attribute?
-    & db.valign.attribute?
-  db.row =
-    
-    ## A row in a table
-    element row { db.row.attlist, (db.entry | db.entrytbl)+ }
-}
-div {
-  db.entry.role.attribute = attribute role { text }
-  db.entry.morerows.attribute =
-    
-    ## Specifies the number of additional rows which this entry occupies. Defaults to zero.
-    attribute morerows { xsd:integer }
-  db.entry.rotate.attribute =
-    
-    ## Specifies the rotation of this entry. A value of 1 (true) rotates the cell 90 degrees counter-clockwise. A value of 0 (false) leaves the cell unrotated.
-    attribute rotate {
-      
-      ## Do not rotate the cell.
-      "0"
-      | 
-        ## Rotate the cell 90 degrees counter-clockwise.
-        "1"
-    }
-  db.entry.attlist =
-    db.entry.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.valign.attribute?
-    & db.char.attribute?
-    & db.colsep.attribute?
-    & db.charoff.attribute?
-    & db.entry.morerows.attribute?
-    & db.column-spec.attributes?
-    & db.rowsep.attribute?
-    & db.entry.rotate.attribute?
-    & db.align.attribute?
-  db.entry =
-    
-    ## A cell in a table
-    [
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:entry"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:table)"
-            "table must not occur among the children or descendants of entry"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:entry"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:informaltable)"
-            "informaltable must not occur among the children or descendants of entry"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element entry {
-      db.entry.attlist, (db.all.inlines* | db.all.blocks*)
-    }
-}
-div {
-  db.entrytbl.role.attribute = attribute role { text }
-  db.entrytbl.tgroupstyle.attribute =
-    
-    ## Additional style information for downstream processing; typically the name of a style.
-    attribute tgroupstyle { text }
-  db.entrytbl.cols.attribute =
-    
-    ## The number of columns in the entry table. Must be an integer greater than zero.
-    attribute cols { xsd:positiveInteger }
-  db.entrytbl.attlist =
-    db.entrytbl.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.char.attribute?
-    & db.charoff.attribute?
-    & db.column-spec.attributes?
-    & db.entrytbl.tgroupstyle.attribute?
-    & db.entrytbl.cols.attribute?
-    & db.colsep.attribute?
-    & db.rowsep.attribute?
-    & db.align.attribute?
-  db.entrytbl =
-    
-    ## A subtable appearing in place of an entry in a table
-    element entrytbl {
-      db.entrytbl.attlist,
-      db.colspec*,
-      db.spanspec*,
-      db.cals.entrytbl.thead?,
-      db.cals.entrytbl.tbody
-    }
-}
-div {
-  db.cals.entrytbl.thead.role.attribute = attribute role { text }
-  db.cals.entrytbl.thead.attlist =
-    db.cals.entrytbl.thead.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.valign.attribute?
-  db.cals.entrytbl.thead =
-    
-    ## A table header consisting of one or more rows
-    element thead {
-      db.cals.entrytbl.thead.attlist, db.colspec*, db.entrytbl.row+
-    }
-}
-div {
-  db.cals.entrytbl.tbody.role.attribute = attribute role { text }
-  db.cals.entrytbl.tbody.attlist =
-    db.cals.entrytbl.tbody.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.valign.attribute?
-  db.cals.entrytbl.tbody =
-    
-    ## A wrapper for the rows of a table or informal table
-    element tbody { db.cals.entrytbl.tbody.attlist, db.entrytbl.row+ }
-}
-div {
-  db.entrytbl.row.role.attribute = attribute role { text }
-  db.entrytbl.row.attlist =
-    db.entrytbl.row.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.rowsep.attribute?
-    & db.valign.attribute?
-  db.entrytbl.row =
-    
-    ## A row in a table
-    element row { db.entrytbl.row.attlist, db.entry+ }
-}
-div {
-  db.cals.table.role.attribute = attribute role { text }
-  db.cals.table.label.attribute = db.label.attribute
-  db.cals.table.attlist =
-    db.cals.table.role.attribute?
-    & db.cals.table.label.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.tabstyle.attribute?
-    & db.floatstyle.attribute?
-    & db.orient.attribute?
-    & db.colsep.attribute?
-    & db.rowsep.attribute?
-    & db.frame.attribute?
-    & db.pgwide.attribute?
-    & 
-      ## Indicates if the short or long title should be used in a List of Tables
-      attribute shortentry {
-        
-        ## Indicates that the full title should be used.
-        "0"
-        | 
-          ## Indicates that the short short title (titleabbrev) should be used.
-          "1"
-      }?
-    & 
-      ## Indicates if the table should appear in a List of Tables
-      attribute tocentry {
-        
-        ## Indicates that the table should not occur in the List of Tables.
-        "0"
-        | 
-          ## Indicates that the table should appear in the List of Tables.
-          "1"
-      }?
-    & db.rowheader.attribute?
-  db.cals.table.info = db._info.title.onlyreq
-  db.cals.table =
-    
-    ## A formal table in a document
-    [
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:table"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:example)"
-            "example must not occur among the children or descendants of table"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:table"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:figure)"
-            "figure must not occur among the children or descendants of table"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:table"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:equation)"
-            "equation must not occur among the children or descendants of table"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:table"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:caution)"
-            "caution must not occur among the children or descendants of table"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:table"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:important)"
-            "important must not occur among the children or descendants of table"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:table"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:note)"
-            "note must not occur among the children or descendants of table"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:table"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:tip)"
-            "tip must not occur among the children or descendants of table"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:table"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:warning)"
-            "warning must not occur among the children or descendants of table"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element table {
-      db.cals.table.attlist,
-      db.cals.table.info,
-      (db.alt? & db.indexing.inlines* & db.textobject*),
-      (db.mediaobject+ | db.tgroup+),
-      db.caption?
-    }
-}
-div {
-  db.cals.informaltable.role.attribute = attribute role { text }
-  db.cals.informaltable.attlist =
-    db.cals.informaltable.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.tabstyle.attribute?
-    & db.floatstyle.attribute?
-    & db.orient.attribute?
-    & db.colsep.attribute?
-    & db.rowsep.attribute?
-    & db.frame.attribute?
-    & db.pgwide.attribute?
-    & db.rowheader.attribute?
-  db.cals.informaltable.info = db._info.title.forbidden
-  db.cals.informaltable =
-    
-    ## A table without a title
-    element informaltable {
-      db.cals.informaltable.attlist,
-      db.cals.informaltable.info,
-      (db.alt? & db.indexing.inlines* & db.textobject*),
-      (db.mediaobject+ | db.tgroup+),
-      db.caption?
-    }
-}
-db.html.coreattrs =
-  
-  ## This attribute assigns a class name or set of class names to an element. Any number of elements may be assigned the same class name or names. Multiple class names must be separated by white space characters.
-  attribute class { text }?
-  & 
-    ## This attribute specifies style information for the current element.
-    attribute style { text }?
-  & 
-    ## This attribute offers advisory information about the element for which it is set.
-    attribute title { text }?
-db.html.i18n =
-  
-  ## This attribute specifies the base language of an element's attribute values and text content. The default value of this attribute is unknown.
-  attribute lang { text }?
-db.html.events =
-  
-  ## Occurs when the pointing device button is clicked over an element.
-  attribute onclick { text }?
-  & 
-    ## Occurs when the pointing device button is double clicked over an element.
-    attribute ondblclick { text }?
-  & 
-    ## Occurs when the pointing device button is pressed over an element.
-    attribute onmousedown { text }?
-  & 
-    ## Occurs when the pointing device button is released over an element.
-    attribute onmouseup { text }?
-  & 
-    ## Occurs when the pointing device is moved onto an element.
-    attribute onmouseover { text }?
-  & 
-    ## Occurs when the pointing device is moved while it is over an element.
-    attribute onmousemove { text }?
-  & 
-    ## Occurs when the pointing device is moved away from an element.
-    attribute onmouseout { text }?
-  & 
-    ## Occurs when a key is pressed and released over an element.
-    attribute onkeypress { text }?
-  & 
-    ## Occurs when a key is pressed down over an element.
-    attribute onkeydown { text }?
-  & 
-    ## Occurs when a key is released over an element.
-    attribute onkeyup { text }?
-db.html.attrs =
-  db.common.attributes
-  & db.html.coreattrs
-  & db.html.i18n
-  & db.html.events
-db.html.cellhalign =
-  
-  ## Specifies the alignment of data and the justification of text in a cell.
-  attribute align {
-    
-    ## Left-flush data/Left-justify text. This is the default value for table data.
-    "left"
-    | 
-      ## Center data/Center-justify text. This is the default value for table headers.
-      "center"
-    | 
-      ## Right-flush data/Right-justify text.
-      "right"
-    | 
-      ## Double-justify text.
-      "justify"
-    | 
-      ## Align text around a specific character. If a user agent doesn't support character alignment, behavior in the presence of this value is unspecified.
-      "char"
-  }?
-  & 
-    ## This attribute specifies a single character within a text fragment to act as an axis for alignment. The default value for this attribute is the decimal point character for the current language as set by the lang attribute (e.g., the period in English and the comma in French). User agents are not required to support this attribute.
-    attribute char { text }?
-  & 
-    ## When present, this attribute specifies the offset to the first occurrence of the alignment character on each line. If a line doesn't include the alignment character, it should be horizontally shifted to end at the alignment position. When charoff is used to set the offset of an alignment character, the direction of offset is determined by the current text direction (set by the dir attribute). In left-to-right texts (the default), offset is from the left margin. In right-to-left texts, offset is from the right margin. User agents are not required to support this attribute.
-    attribute charoff {
-      xsd:integer >> a:documentation [ "An explicit offset." ]
-      | xsd:string { pattern = "[0-9]+%" }
-        >> a:documentation [ "A percentage offset." ]
-    }?
-db.html.cellvalign =
-  
-  ## Specifies the vertical position of data within a cell.
-  attribute valign {
-    
-    ## Cell data is flush with the top of the cell.
-    "top"
-    | 
-      ## Cell data is centered vertically within the cell. This is the default value.
-      "middle"
-    | 
-      ## Cell data is flush with the bottom of the cell.
-      "bottom"
-    | 
-      ## All cells in the same row as a cell whose valign attribute has this value should have their textual data positioned so that the first text line occurs on a baseline common to all cells in the row. This constraint does not apply to subsequent text lines in these cells.
-      "baseline"
-  }?
-db.html.table.attributes =
-  
-  ## Provides a summary of the table's purpose and structure for user agents rendering to non-visual media such as speech and Braille.
-  attribute summary { text }?
-  & 
-    ## Specifies the desired width of the entire table and is intended for visual user agents. When the value is a percentage value, the value is relative to the user agent's available horizontal space. In the absence of any width specification, table width is determined by the user agent.
-    attribute width {
-      xsd:integer >> a:documentation [ "An explicit width." ]
-      | xsd:string { pattern = "[0-9]+%" }
-        >> a:documentation [ "A percentage width." ]
-    }?
-  & 
-    ## Specifies the width (in pixels only) of the frame around a table.
-    attribute border { xsd:nonNegativeInteger }?
-  & 
-    ## Specifies which sides of the frame surrounding a table will be visible.
-    attribute frame {
-      
-      ## No sides. This is the default value.
-      "void"
-      | 
-        ## The top side only.
-        "above"
-      | 
-        ## The bottom side only.
-        "below"
-      | 
-        ## The top and bottom sides only.
-        "hsides"
-      | 
-        ## The left-hand side only.
-        "lhs"
-      | 
-        ## The right-hand side only.
-        "rhs"
-      | 
-        ## The right and left sides only.
-        "vsides"
-      | 
-        ## All four sides.
-        "box"
-      | 
-        ## All four sides.
-        "border"
-    }?
-  & 
-    ## Specifies which rules will appear between cells within a table. The rendering of rules is user agent dependent.
-    attribute rules {
-      
-      ## No rules. This is the default value.
-      "none"
-      | 
-        ## Rules will appear between row groups (see thead, tfoot, and tbody) and column groups (see colgroup and col) only.
-        "groups"
-      | 
-        ## Rules will appear between rows only.
-        "rows"
-      | 
-        ## Rules will appear between columns only.
-        "cols"
-      | 
-        ## Rules will appear between all rows and columns.
-        "all"
-    }?
-  & 
-    ## Specifies how much space the user agent should leave between the left side of the table and the left-hand side of the leftmost column, the top of the table and the top side of the topmost row, and so on for the right and bottom of the table. The attribute also specifies the amount of space to leave between cells.
-    attribute cellspacing {
-      xsd:integer >> a:documentation [ "An explicit spacing." ]
-      | xsd:string { pattern = "[0-9]+%" }
-        >> a:documentation [ "A percentage spacing." ]
-    }?
-  & 
-    ## Specifies the amount of space between the border of the cell and its contents. If the value of this attribute is a pixel length, all four margins should be this distance from the contents. If the value of the attribute is a percentage length, the top and bottom margins should be equally separated from the content based on a percentage of the available vertical space, and the left and right margins should be equally separated from the content based on a percentage of the available horizontal space.
-    attribute cellpadding {
-      xsd:integer >> a:documentation [ "An explicit padding." ]
-      | xsd:string { pattern = "[0-9]+%" }
-        >> a:documentation [ "A percentage padding." ]
-    }?
-db.html.tablecell.attributes =
-  
-  ## Provides an abbreviated form of the cell's content and may be rendered by user agents when appropriate in place of the cell's content. Abbreviated names should be short since user agents may render them repeatedly. For instance, speech synthesizers may render the abbreviated headers relating to a particular cell before rendering that cell's content.
-  attribute abbr { text }?
-  & 
-    ## This attribute may be used to place a cell into conceptual categories that can be considered to form axes in an n-dimensional space. User agents may give users access to these categories (e.g., the user may query the user agent for all cells that belong to certain categories, the user agent may present a table in the form of a table of contents, etc.). Please consult an HTML reference for more details.
-    attribute axis { text }?
-  & 
-    ## Specifies the list of header cells that provide header information for the current data cell. The value of this attribute is a space-separated list of cell names; those cells must be named by setting their id attribute. Authors generally use the headers attribute to help non-visual user agents render header information about data cells (e.g., header information is spoken prior to the cell data), but the attribute may also be used in conjunction with style sheets.
-    attribute headers { text }?
-  & 
-    ## Specifies the set of data cells for which the current header cell provides header information. This attribute may be used in place of the headers attribute, particularly for simple tables.
-    attribute scope {
-      
-      ## The current cell provides header information for the rest of the row that contains it
-      "row"
-      | 
-        ## The current cell provides header information for the rest of the column that contains it.
-        "col"
-      | 
-        ## The header cell provides header information for the rest of the row group that contains it.
-        "rowgroup"
-      | 
-        ## The header cell provides header information for the rest of the column group that contains it.
-        "colgroup"
-    }?
-  & 
-    ## Specifies the number of rows spanned by the current cell. The default value of this attribute is one (1
-    ## ). The value zero (0
-    ## ) means that the cell spans all rows from the current row to the last row of the table section (thead
-    ## , tbody
-    ## , or tfoot
-    ## ) in which the cell is defined.
-    attribute rowspan { xsd:nonNegativeInteger }?
-  & 
-    ## Specifies the number of columns spanned by the current cell. The default value of this attribute is one (1
-    ## ). The value zero (0
-    ## ) means that the cell spans all columns from the current column to the last column of the column group (colgroup
-    ## ) in which the cell is defined.
-    attribute colspan { xsd:nonNegativeInteger }?
-db.html.table.info = db._info.title.forbidden
-db.html.table.model =
-  db.html.table.info?,
-  db.html.caption,
-  (db.html.col* | db.html.colgroup*),
-  db.html.thead?,
-  db.html.tfoot?,
-  (db.html.tbody+ | db.html.tr+)
-db.html.informaltable.info = db._info.title.forbidden
-db.html.informaltable.model =
-  db.html.informaltable.info?,
-  (db.html.col* | db.html.colgroup*),
-  db.html.thead?,
-  db.html.tfoot?,
-  (db.html.tbody+ | db.html.tr+)
-div {
-  db.html.table.role.attribute = attribute role { text }
-  db.html.table.label.attribute = db.label.attribute
-  db.html.table.attlist =
-    db.html.attrs
-    & db.html.table.attributes
-    & db.html.table.role.attribute?
-    & db.html.table.label.attribute?
-    & db.orient.attribute?
-    & db.pgwide.attribute?
-    & db.tabstyle.attribute?
-    & db.floatstyle.attribute?
-  db.html.table =
-    
-    ## A formal (captioned) HTML table in a document
-    [
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:table"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:example)"
-            "example must not occur among the children or descendants of table"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:table"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:figure)"
-            "figure must not occur among the children or descendants of table"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:table"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:equation)"
-            "equation must not occur among the children or descendants of table"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:table"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:caution)"
-            "caution must not occur among the children or descendants of table"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:table"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:important)"
-            "important must not occur among the children or descendants of table"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:table"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:note)"
-            "note must not occur among the children or descendants of table"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:table"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:tip)"
-            "tip must not occur among the children or descendants of table"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:table"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:warning)"
-            "warning must not occur among the children or descendants of table"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element table { db.html.table.attlist, db.html.table.model }
-}
-div {
-  db.html.informaltable.role.attribute = attribute role { text }
-  db.html.informaltable.label.attribute = db.label.attribute
-  db.html.informaltable.attlist =
-    db.html.attrs
-    & db.html.table.attributes
-    & db.html.informaltable.role.attribute?
-    & db.html.informaltable.label.attribute?
-    & db.orient.attribute?
-    & db.pgwide.attribute?
-    & db.tabstyle.attribute?
-    & db.floatstyle.attribute?
-  db.html.informaltable =
-    
-    ## An HTML table without a title
-    element informaltable {
-      db.html.informaltable.attlist, db.html.informaltable.model
-    }
-}
-div {
-  db.html.caption.attlist = db.html.attrs
-  db.html.caption =
-    
-    ## An HTML table caption
-    [
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:caption"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:example)"
-            "example must not occur among the children or descendants of caption"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:caption"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:figure)"
-            "figure must not occur among the children or descendants of caption"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:caption"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:table)"
-            "table must not occur among the children or descendants of caption"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:caption"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:equation)"
-            "equation must not occur among the children or descendants of caption"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:caption"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:sidebar)"
-            "sidebar must not occur among the children or descendants of caption"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:caption"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:task)"
-            "task must not occur among the children or descendants of caption"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:caption"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:caution)"
-            "caution must not occur among the children or descendants of caption"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:caption"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:important)"
-            "important must not occur among the children or descendants of caption"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:caption"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:note)"
-            "note must not occur among the children or descendants of caption"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:caption"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:tip)"
-            "tip must not occur among the children or descendants of caption"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:caption"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:warning)"
-            "warning must not occur among the children or descendants of caption"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element caption { db.html.caption.attlist, db.all.inlines* }
-}
-div {
-  db.html.col.attlist =
-    db.html.attrs
-    & 
-      ## This attribute, whose value must be an integer > 0, specifies the number of columns spanned
-      ##  by the col
-      ##  element; the col
-      ##  element shares its attributes with all the columns it spans. The default value for this attribute is 1 (i.e., a single column). If the span attribute is set to N > 1, the current col
-      ##  element shares its attributes with the next N-1 columns.
-      attribute span { xsd:nonNegativeInteger }?
-    & 
-      ## Specifies a default width for each column spanned by the current col
-      ##  element. It has the same meaning as the width
-      ##  attribute for the colgroup
-      ##  element and overrides it.
-      attribute width { text }?
-    & db.html.cellhalign
-    & db.html.cellvalign
-  db.html.col =
-    
-    ## Specifications for a column in an HTML table
-    element col { db.html.col.attlist, empty }
-}
-div {
-  db.html.colgroup.attlist =
-    db.html.attrs
-    & 
-      ## This attribute, which must be an integer > 0, specifies the number of columns in a column group. In the absence of a span attribute, each colgroup
-      ##  defines a column group containing one column. If the span attribute is set to N > 0, the current colgroup
-      ##  element defines a column group containing N columns. User agents must ignore this attribute if the colgroup
-      ##  element contains one or more col
-      ##  elements.
-      attribute span { xsd:nonNegativeInteger }?
-    & 
-      ## This attribute specifies a default width for each column in the current column group. In addition to the standard pixel, percentage, and relative values, this attribute allows the special form 0*
-      ##  (zero asterisk) which means that the width of the each column in the group should be the minimum width necessary to hold the column's contents. This implies that a column's entire contents must be known before its width may be correctly computed. Authors should be aware that specifying 0*
-      ##  will prevent visual user agents from rendering a table incrementally. This attribute is overridden for any column in the column group whose width is specified via a col
-      ##  element.
-      attribute width { text }?
-    & db.html.cellhalign
-    & db.html.cellvalign
-  db.html.colgroup =
-    
-    ## A group of columns in an HTML table
-    element colgroup { db.html.colgroup.attlist, db.html.col* }
-}
-div {
-  db.html.thead.attlist =
-    db.html.attrs & db.html.cellhalign & db.html.cellvalign
-  db.html.thead =
-    
-    ## A table header consisting of one or more rows in an HTML table
-    element thead { db.html.thead.attlist, db.html.tr+ }
-}
-div {
-  db.html.tfoot.attlist =
-    db.html.attrs & db.html.cellhalign & db.html.cellvalign
-  db.html.tfoot =
-    
-    ## A table footer consisting of one or more rows in an HTML table
-    element tfoot { db.html.tfoot.attlist, db.html.tr+ }
-}
-div {
-  db.html.tbody.attlist =
-    db.html.attrs & db.html.cellhalign & db.html.cellvalign
-  db.html.tbody =
-    
-    ## A wrapper for the rows of an HTML table or informal HTML table
-    element tbody { db.html.tbody.attlist, db.html.tr+ }
-}
-div {
-  db.html.tr.attlist =
-    db.html.attrs & db.html.cellhalign & db.html.cellvalign
-  db.html.tr =
-    
-    ## A row in an HTML table
-    element tr { db.html.tr.attlist, (db.html.th | db.html.td)+ }
-}
-div {
-  db.html.th.attlist =
-    db.html.attrs
-    & db.html.tablecell.attributes
-    & db.html.cellhalign
-    & db.html.cellvalign
-  db.html.th =
-    
-    ## A table header entry in an HTML table
-    element th {
-      db.html.th.attlist, (db.all.inlines* | db.all.blocks*)
-    }
-}
-div {
-  db.html.td.attlist =
-    db.html.attrs
-    & db.html.tablecell.attributes
-    & db.html.cellhalign
-    & db.html.cellvalign
-  db.html.td =
-    
-    ## A table entry in an HTML table
-    element td {
-      db.html.td.attlist, (db.all.inlines* | db.all.blocks*)
-    }
-}
-div {
-  db.msgset.role.attribute = attribute role { text }
-  db.msgset.attlist =
-    db.msgset.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.msgset.info = db._info.title.only
-  db.msgset =
-    
-    ## A detailed set of messages, usually error messages
-    element msgset {
-      db.msgset.attlist,
-      db.msgset.info,
-      (db.msgentry+ | db.simplemsgentry+)
-    }
-}
-div {
-  db.msgentry.role.attribute = attribute role { text }
-  db.msgentry.attlist =
-    db.msgentry.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.msgentry =
-    
-    ## A wrapper for an entry in a message set
-    element msgentry {
-      db.msgentry.attlist, db.msg+, db.msginfo?, db.msgexplan*
-    }
-}
-div {
-  db.simplemsgentry.role.attribute = attribute role { text }
-  db.simplemsgentry.msgaud.attribute =
-    
-    ## The audience to which the message relevant
-    attribute msgaud { text }
-  db.simplemsgentry.msgorig.attribute =
-    
-    ## The origin of the message
-    attribute msgorig { text }
-  db.simplemsgentry.msglevel.attribute =
-    
-    ## The level of importance or severity of a message
-    attribute msglevel { text }
-  db.simplemsgentry.attlist =
-    db.simplemsgentry.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.simplemsgentry.msgaud.attribute?
-    & db.simplemsgentry.msgorig.attribute?
-    & db.simplemsgentry.msglevel.attribute?
-  db.simplemsgentry =
-    
-    ## A wrapper for a simpler entry in a message set
-    element simplemsgentry {
-      db.simplemsgentry.attlist, db.msgtext, db.msgexplan+
-    }
-}
-div {
-  db.msg.role.attribute = attribute role { text }
-  db.msg.attlist =
-    db.msg.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.msg.info = db._info.title.only
-  db.msg =
-    
-    ## A message in a message set
-    element msg {
-      db.msg.attlist, db.msg.info, db.msgmain, (db.msgsub | db.msgrel)*
-    }
-}
-div {
-  db.msgmain.role.attribute = attribute role { text }
-  db.msgmain.attlist =
-    db.msgmain.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.msgmain.info = db._info.title.only
-  db.msgmain =
-    
-    ## The primary component of a message in a message set 
-    element msgmain { db.msgmain.attlist, db.msgmain.info, db.msgtext }
-}
-div {
-  db.msgsub.role.attribute = attribute role { text }
-  db.msgsub.attlist =
-    db.msgsub.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.msgsub.info = db._info.title.only
-  db.msgsub =
-    
-    ## A subcomponent of a message in a message set
-    element msgsub { db.msgsub.attlist, db.msgsub.info, db.msgtext }
-}
-div {
-  db.msgrel.role.attribute = attribute role { text }
-  db.msgrel.attlist =
-    db.msgrel.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.msgrel.info = db._info.title.only
-  db.msgrel =
-    
-    ## A related component of a message in a message set
-    element msgrel { db.msgrel.attlist, db.msgrel.info, db.msgtext }
-}
-div {
-  db.msgtext.role.attribute = attribute role { text }
-  db.msgtext.attlist =
-    db.msgtext.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.msgtext =
-    
-    ## The actual text of a message component in a message set
-    element msgtext { db.msgtext.attlist, db.all.blocks+ }
-}
-div {
-  db.msginfo.role.attribute = attribute role { text }
-  db.msginfo.attlist =
-    db.msginfo.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.msginfo =
-    
-    ## Information about a message in a message set
-    element msginfo {
-      db.msginfo.attlist, (db.msglevel | db.msgorig | db.msgaud)*
-    }
-}
-div {
-  db.msglevel.role.attribute = attribute role { text }
-  db.msglevel.attlist =
-    db.msglevel.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.msglevel =
-    
-    ## The level of importance or severity of a message in a message set
-    element msglevel { db.msglevel.attlist, db._text }
-}
-div {
-  db.msgorig.role.attribute = attribute role { text }
-  db.msgorig.attlist =
-    db.msgorig.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.msgorig =
-    
-    ## The origin of a message in a message set
-    element msgorig { db.msgorig.attlist, db._text }
-}
-div {
-  db.msgaud.role.attribute = attribute role { text }
-  db.msgaud.attlist =
-    db.msgaud.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.msgaud =
-    
-    ## The audience to which a message in a message set is relevant
-    element msgaud { db.msgaud.attlist, db._text }
-}
-div {
-  db.msgexplan.role.attribute = attribute role { text }
-  db.msgexplan.attlist =
-    db.msgexplan.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.msgexplan.info = db._info.title.only
-  db.msgexplan =
-    
-    ## Explanatory material relating to a message in a message set
-    element msgexplan {
-      db.msgexplan.attlist, db.msgexplan.info, db.all.blocks+
-    }
-}
-div {
-  db.qandaset.role.attribute = attribute role { text }
-  db.qandaset.defaultlabel.enumeration =
-    
-    ## No labels
-    "none"
-    | 
-      ## Numeric labels
-      "number"
-    | 
-      ## "Q:" and "A:" labels
-      "qanda"
-  db.qandaset.defaultlabel.attribute =
-    
-    ## Specifies the default labelling
-    attribute defaultlabel { db.qandaset.defaultlabel.enumeration }
-  db.qandaset.attlist =
-    db.qandaset.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.qandaset.defaultlabel.attribute?
-  db.qandaset.info = db._info.title.only
-  db.qandaset =
-    
-    ## A question-and-answer set
-    element qandaset {
-      db.qandaset.attlist,
-      db.qandaset.info,
-      db.all.blocks*,
-      (db.qandadiv+ | db.qandaentry+)
-    }
-}
-div {
-  db.qandadiv.role.attribute = attribute role { text }
-  db.qandadiv.attlist =
-    db.qandadiv.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.qandadiv.info = db._info.title.only
-  db.qandadiv =
-    
-    ## A titled division in a qandaset
-    element qandadiv {
-      db.qandadiv.attlist,
-      db.qandadiv.info,
-      db.all.blocks*,
-      (db.qandadiv+ | db.qandaentry+)
-    }
-}
-div {
-  db.qandaentry.role.attribute = attribute role { text }
-  db.qandaentry.attlist =
-    db.qandaentry.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.qandaentry.info = db._info.title.only
-  db.qandaentry =
-    
-    ## A question/answer set within a qandaset
-    element qandaentry {
-      db.qandaentry.attlist, db.qandaentry.info, db.question, db.answer*
-    }
-}
-div {
-  db.question.role.attribute = attribute role { text }
-  db.question.attlist =
-    db.question.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.question =
-    
-    ## A question in a qandaset
-    element question { db.question.attlist, db.label?, db.all.blocks+ }
-}
-div {
-  db.answer.role.attribute = attribute role { text }
-  db.answer.attlist =
-    db.answer.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.answer =
-    
-    ## An answer to a question posed in a qandaset
-    element answer { db.answer.attlist, db.label?, db.all.blocks+ }
-}
-div {
-  db.label.role.attribute = attribute role { text }
-  db.label.attlist =
-    db.label.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.label =
-    
-    ## A label on a question or answer
-    element label { db.label.attlist, db._text }
-}
-db.math.inlines = db.inlineequation
-db.equation.content = (db.mediaobject+ | db.mathphrase+) | db._any.mml+
-db.inlineequation.content =
-  (db.inlinemediaobject+ | db.mathphrase+) | db._any.mml+
-div {
-  db.equation.role.attribute = attribute role { text }
-  db.equation.label.attribute = db.label.attribute
-  db.equation.attlist =
-    db.equation.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.equation.label.attribute?
-    & db.pgwide.attribute?
-    & db.floatstyle.attribute?
-  db.equation.info = db._info.title.only
-  db.equation =
-    
-    ## A displayed mathematical equation
-    [
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:equation"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:example)"
-            "example must not occur among the children or descendants of equation"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:equation"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:figure)"
-            "figure must not occur among the children or descendants of equation"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:equation"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:table)"
-            "table must not occur among the children or descendants of equation"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:equation"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:equation)"
-            "equation must not occur among the children or descendants of equation"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:equation"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:caution)"
-            "caution must not occur among the children or descendants of equation"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:equation"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:important)"
-            "important must not occur among the children or descendants of equation"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:equation"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:note)"
-            "note must not occur among the children or descendants of equation"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:equation"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:tip)"
-            "tip must not occur among the children or descendants of equation"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:equation"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:warning)"
-            "warning must not occur among the children or descendants of equation"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element equation {
-      db.equation.attlist,
-      db.equation.info,
-      db.alt?,
-      db.equation.content,
-      db.caption?
-    }
-}
-div {
-  db.informalequation.role.attribute = attribute role { text }
-  db.informalequation.attlist =
-    db.informalequation.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.pgwide.attribute?
-    & db.floatstyle.attribute?
-  db.informalequation.info = db._info.title.forbidden
-  db.informalequation =
-    
-    ## A displayed mathematical equation without a title
-    element informalequation {
-      db.informalequation.attlist,
-      db.informalequation.info,
-      db.alt?,
-      db.equation.content,
-      db.caption?
-    }
-}
-div {
-  db.inlineequation.role.attribute = attribute role { text }
-  db.inlineequation.attlist =
-    db.inlineequation.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.inlineequation =
-    
-    ## A mathematical equation or expression occurring inline
-    element inlineequation {
-      db.inlineequation.attlist, db.alt?, db.inlineequation.content
-    }
-}
-div {
-  db.mathphrase.role.attribute = attribute role { text }
-  db.mathphrase.attlist =
-    db.mathphrase.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.mathphrase =
-    
-    ## A mathematical phrase that can be represented with ordinary text and a small amount of markup
-    element mathphrase {
-      db.mathphrase.attlist,
-      (db._text | db.ubiq.inlines | db._emphasis)*
-    }
-}
-db.imagedata.mathml.content = db._any.mml
-div {
-  db.imagedata.mathml.role.attribute = attribute role { text }
-  db.imagedata.mathml.attlist =
-    db.imagedata.mathml.role.attribute?
-    & db.common.attributes
-    & 
-      ## Specifies that the format of the data is MathML
-      attribute format {
-        
-        ## Specifies MathML.
-        "mathml"
-      }?
-    & db.imagedata.align.attribute?
-    & db.imagedata.valign.attribute?
-    & db.imagedata.width.attribute?
-    & db.imagedata.contentwidth.attribute?
-    & db.imagedata.scalefit.attribute?
-    & db.imagedata.scale.attribute?
-    & db.imagedata.depth.attribute?
-    & db.imagedata.contentdepth.attribute?
-  db.imagedata.mathml.info = db._info.title.forbidden
-  db.imagedata.mathml =
-    
-    ## A MathML expression in a media object
-    element imagedata {
-      db.imagedata.mathml.attlist,
-      db.imagedata.mathml.info,
-      db.imagedata.mathml.content+
-    }
-}
-div {
-  db._any.mml =
-    
-    ## Any element from the MathML namespace
-    element mml:* { (db._any.attribute | text | db._any)* }
-}
-db.imagedata.svg.content = db._any.svg
-div {
-  db.imagedata.svg.role.attribute = attribute role { text }
-  db.imagedata.svg.attlist =
-    db.imagedata.svg.role.attribute?
-    & db.common.attributes
-    & 
-      ## Specifies that the format of the data is SVG
-      attribute format {
-        
-        ## Specifies SVG.
-        "svg"
-      }?
-    & db.imagedata.align.attribute?
-    & db.imagedata.valign.attribute?
-    & db.imagedata.width.attribute?
-    & db.imagedata.contentwidth.attribute?
-    & db.imagedata.scalefit.attribute?
-    & db.imagedata.scale.attribute?
-    & db.imagedata.depth.attribute?
-    & db.imagedata.contentdepth.attribute?
-  db.imagedata.svg.info = db._info.title.forbidden
-  db.imagedata.svg =
-    
-    ## An SVG drawing in a media object
-    element imagedata {
-      db.imagedata.svg.attlist,
-      db.imagedata.svg.info,
-      db.imagedata.svg.content+
-    }
-}
-div {
-  db._any.svg =
-    
-    ## Any element from the SVG namespace
-    element svg:* { (db._any.attribute | text | db._any)* }
-}
-db.markup.inlines =
-  db.tag
-  | db.markup
-  | db.token
-  | db.symbol
-  | db.literal
-  | db.code
-  | db.constant
-  | db.email
-  | db.uri
-div {
-  db.markup.role.attribute = attribute role { text }
-  db.markup.attlist =
-    db.markup.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.markup =
-    
-    ## A string of formatting markup in text that is to be represented literally
-    element markup { db.markup.attlist, db._text }
-}
-div {
-  db.tag.role.attribute = attribute role { text }
-  db.tag.class.enumeration =
-    
-    ## An attribute
-    "attribute"
-    | 
-      ## An attribute value
-      "attvalue"
-    | 
-      ## An element
-      "element"
-    | 
-      ## An empty element tag
-      "emptytag"
-    | 
-      ## An end tag
-      "endtag"
-    | 
-      ## A general entity
-      "genentity"
-    | 
-      ## The local name part of a qualified name
-      "localname"
-    | 
-      ## A namespace
-      "namespace"
-    | 
-      ## A numeric character reference
-      "numcharref"
-    | 
-      ## A parameter entity
-      "paramentity"
-    | 
-      ## A processing instruction
-      "pi"
-    | 
-      ## The prefix part of a qualified name
-      "prefix"
-    | 
-      ## An SGML comment
-      "comment"
-    | 
-      ## A start tag
-      "starttag"
-    | 
-      ## An XML processing instruction
-      "xmlpi"
-  db.tag.class.attribute =
-    
-    ## Identifies the nature of the tag content
-    attribute class { db.tag.class.enumeration }
-  db.tag.namespace.attribute =
-    
-    ## Identifies the namespace of the tag content
-    attribute namespace { xsd:anyURI }
-  db.tag.attlist =
-    db.tag.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.tag.class.attribute?
-    & db.tag.namespace.attribute?
-  db.tag =
-    
-    ## A component of XML (or SGML) markup
-    element tag { db.tag.attlist, (db._text | db.tag)* }
-}
-div {
-  db.symbol.class.attribute =
-    
-    ## Identifies the class of symbol
-    attribute class {
-      
-      ## The value is a limit of some kind
-      "limit"
-    }
-  db.symbol.role.attribute = attribute role { text }
-  db.symbol.attlist =
-    db.symbol.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.symbol.class.attribute?
-  db.symbol =
-    
-    ## A name that is replaced by a value before processing
-    element symbol { db.symbol.attlist, db._text }
-}
-div {
-  db.token.role.attribute = attribute role { text }
-  db.token.attlist =
-    db.token.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.token =
-    
-    ## A unit of information
-    element token { db.token.attlist, db._text }
-}
-div {
-  db.literal.role.attribute = attribute role { text }
-  db.literal.attlist =
-    db.literal.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.literal =
-    
-    ## Inline text that is some literal value
-    element literal { db.literal.attlist, db._text }
-}
-div {
-  code.language.attribute =
-    
-    ## Identifies the (computer) language of the code fragment
-    attribute language { text }
-  db.code.role.attribute = attribute role { text }
-  db.code.attlist =
-    db.code.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & code.language.attribute?
-  db.code =
-    
-    ## An inline code fragment
-    element code {
-      db.code.attlist, (db.programming.inlines | db._text)*
-    }
-}
-div {
-  db.constant.class.attribute =
-    
-    ## Identifies the class of constant
-    attribute class {
-      
-      ## The value is a limit of some kind
-      "limit"
-    }
-  db.constant.role.attribute = attribute role { text }
-  db.constant.attlist =
-    db.constant.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.constant.class.attribute?
-  db.constant =
-    
-    ## A programming or system constant
-    element constant { db.constant.attlist, db._text }
-}
-div {
-  db.productname.role.attribute = attribute role { text }
-  db.productname.class.enumeration =
-    
-    ## A name with a copyright
-    "copyright"
-    | 
-      ## A name with a registered copyright
-      "registered"
-    | 
-      ## A name of a service
-      "service"
-    | 
-      ## A name which is trademarked
-      "trade"
-  db.productname.class.attribute =
-    
-    ## Specifies the class of product name
-    attribute class { db.productname.class.enumeration }
-  db.productname.attlist =
-    db.productname.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.productname.class.attribute?
-  db.productname =
-    
-    ## The formal name of a product
-    element productname { db.productname.attlist, db._text }
-}
-div {
-  db.productnumber.role.attribute = attribute role { text }
-  db.productnumber.attlist =
-    db.productnumber.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.productnumber =
-    
-    ## A number assigned to a product
-    element productnumber { db.productnumber.attlist, db._text }
-}
-div {
-  db.database.class.enumeration =
-    
-    ## An alternate or secondary key
-    "altkey"
-    | 
-      ## A constraint
-      "constraint"
-    | 
-      ## A data type
-      "datatype"
-    | 
-      ## A field
-      "field"
-    | 
-      ## A foreign key
-      "foreignkey"
-    | 
-      ## A group
-      "group"
-    | 
-      ## An index
-      "index"
-    | 
-      ## The first or primary key
-      "key1"
-    | 
-      ## An alternate or secondary key
-      "key2"
-    | 
-      ## A name
-      "name"
-    | 
-      ## The primary key
-      "primarykey"
-    | 
-      ## A (stored) procedure
-      "procedure"
-    | 
-      ## A record
-      "record"
-    | 
-      ## A rule
-      "rule"
-    | 
-      ## The secondary key
-      "secondarykey"
-    | 
-      ## A table
-      "table"
-    | 
-      ## A user
-      "user"
-    | 
-      ## A view
-      "view"
-  db.database.class.attribute =
-    
-    ## Identifies the class of database artifact
-    attribute class { db.database.class.enumeration }
-  db.database.role.attribute = attribute role { text }
-  db.database.attlist =
-    db.database.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.database.class.attribute?
-  db.database =
-    
-    ## The name of a database, or part of a database
-    element database { db.database.attlist, db._text }
-}
-div {
-  db.application.class.enumeration =
-    
-    ## A hardware application
-    "hardware"
-    | 
-      ## A software application
-      "software"
-  db.application.class.attribute =
-    
-    ## Identifies the class of application
-    attribute class { db.application.class.enumeration }
-  db.application.role.attribute = attribute role { text }
-  db.application.attlist =
-    db.application.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.application.class.attribute?
-  db.application =
-    
-    ## The name of a software program
-    element application { db.application.attlist, db._text }
-}
-div {
-  db.hardware.role.attribute = attribute role { text }
-  db.hardware.attlist =
-    db.hardware.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.hardware =
-    
-    ## A physical part of a computer system
-    element hardware { db.hardware.attlist, db._text }
-}
-db.gui.inlines =
-  db.guiicon
-  | db.guibutton
-  | db.guimenuitem
-  | db.guimenu
-  | db.guisubmenu
-  | db.guilabel
-  | db.menuchoice
-  | db.mousebutton
-div {
-  db.guibutton.role.attribute = attribute role { text }
-  db.guibutton.attlist =
-    db.guibutton.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.guibutton =
-    
-    ## The text on a button in a GUI
-    element guibutton {
-      db.guibutton.attlist,
-      (db._text | db.accel | db.superscript | db.subscript)*
-    }
-}
-div {
-  db.guiicon.role.attribute = attribute role { text }
-  db.guiicon.attlist =
-    db.guiicon.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.guiicon =
-    
-    ## Graphic and/or text appearing as a icon in a GUI
-    element guiicon {
-      db.guiicon.attlist,
-      (db._text | db.accel | db.superscript | db.subscript)*
-    }
-}
-div {
-  db.guilabel.role.attribute = attribute role { text }
-  db.guilabel.attlist =
-    db.guilabel.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.guilabel =
-    
-    ## The text of a label in a GUI
-    element guilabel {
-      db.guilabel.attlist,
-      (db._text | db.accel | db.superscript | db.subscript)*
-    }
-}
-div {
-  db.guimenu.role.attribute = attribute role { text }
-  db.guimenu.attlist =
-    db.guimenu.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.guimenu =
-    
-    ## The name of a menu in a GUI
-    element guimenu {
-      db.guimenu.attlist,
-      (db._text | db.accel | db.superscript | db.subscript)*
-    }
-}
-div {
-  db.guimenuitem.role.attribute = attribute role { text }
-  db.guimenuitem.attlist =
-    db.guimenuitem.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.guimenuitem =
-    
-    ## The name of a terminal menu item in a GUI
-    element guimenuitem {
-      db.guimenuitem.attlist,
-      (db._text | db.accel | db.superscript | db.subscript)*
-    }
-}
-div {
-  db.guisubmenu.role.attribute = attribute role { text }
-  db.guisubmenu.attlist =
-    db.guisubmenu.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.guisubmenu =
-    
-    ## The name of a submenu in a GUI
-    element guisubmenu {
-      db.guisubmenu.attlist,
-      (db._text | db.accel | db.superscript | db.subscript)*
-    }
-}
-div {
-  db.menuchoice.role.attribute = attribute role { text }
-  db.menuchoice.attlist =
-    db.menuchoice.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.menuchoice =
-    
-    ## A selection or series of selections from a menu
-    element menuchoice {
-      db.menuchoice.attlist,
-      db.shortcut?,
-      (db.guibutton
-       | db.guiicon
-       | db.guilabel
-       | db.guimenu
-       | db.guimenuitem
-       | db.guisubmenu)+
-    }
-}
-div {
-  db.mousebutton.role.attribute = attribute role { text }
-  db.mousebutton.attlist =
-    db.mousebutton.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.mousebutton =
-    
-    ## The conventional name of a mouse button
-    element mousebutton { db.mousebutton.attlist, db._text }
-}
-db.keyboard.inlines =
-  db.keycombo
-  | db.keycap
-  | db.keycode
-  | db.keysym
-  | db.shortcut
-  | db.accel
-div {
-  db.keycap.function.enumeration =
-    
-    ## The "Alt" key
-    "alt"
-    | 
-      ## The "Backspace" key
-      "backspace"
-    | 
-      ## The "Command" key
-      "command"
-    | 
-      ## The "Control" key
-      "control"
-    | 
-      ## The "Delete" key
-      "delete"
-    | 
-      ## The down arrow
-      "down"
-    | 
-      ## The "End" key
-      "end"
-    | 
-      ## The "Enter" or "Return" key
-      "enter"
-    | 
-      ## The "Escape" key
-      "escape"
-    | 
-      ## The "Home" key
-      "home"
-    | 
-      ## The "Insert" key
-      "insert"
-    | 
-      ## The left arrow
-      "left"
-    | 
-      ## The "Meta" key
-      "meta"
-    | 
-      ## The "Option" key
-      "option"
-    | 
-      ## The page down key
-      "pagedown"
-    | 
-      ## The page up key
-      "pageup"
-    | 
-      ## The right arrow
-      "right"
-    | 
-      ## The "Shift" key
-      "shift"
-    | 
-      ## The spacebar
-      "space"
-    | 
-      ## The "Tab" key
-      "tab"
-    | 
-      ## The up arrow
-      "up"
-  db.keycap.function-enum.attribute =
-    
-    ## Identifies the function key
-    attribute function { db.keycap.function.enumeration }?
-  db.keycap.function-other.attributes =
-    
-    ## Identifies the function key
-    attribute function {
-      
-      ## Indicates a non-standard function key
-      "other"
-    }?,
-    
-    ## Specifies a keyword that identifies the non-standard key
-    attribute otherfunction { text }
-  db.keycap.function.attrib =
-    db.keycap.function-enum.attribute
-    | db.keycap.function-other.attributes
-  db.keycap.role.attribute = attribute role { text }
-  db.keycap.attlist =
-    db.keycap.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.keycap.function.attrib
-  db.keycap =
-    
-    ## The text printed on a key on a keyboard
-    element keycap { db.keycap.attlist, db._text }
-}
-div {
-  db.keycode.role.attribute = attribute role { text }
-  db.keycode.attlist =
-    db.keycode.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.keycode =
-    
-    ## The internal, frequently numeric, identifier for a key on a keyboard
-    element keycode { db.keycode.attlist, db._text }
-}
-db.keycombination.contentmodel =
-  (db.keycap | db.keycombo | db.keysym) | db.mousebutton
-div {
-  db.keycombo.action.enumeration =
-    
-    ## A (single) mouse click.
-    "click"
-    | 
-      ## A double mouse click.
-      "double-click"
-    | 
-      ## A mouse or key press.
-      "press"
-    | 
-      ## Sequential clicks or presses.
-      "seq"
-    | 
-      ## Simultaneous clicks or presses.
-      "simul"
-  db.keycombo.action-enum.attribute =
-    
-    ## Identifies the nature of the action taken. If keycombo
-    ##  contains more than one element, simul
-    ##  is the default, otherwise there is no default.
-    attribute action { db.keycombo.action.enumeration }?
-  db.keycombo.action-other.attributes =
-    
-    ## Identifies the nature of the action taken
-    attribute action {
-      
-      ## Indicates a non-standard action
-      "other"
-    }?,
-    
-    ## Identifies the non-standard action in some unspecified way.
-    attribute otheraction { text }
-  db.keycombo.action.attrib =
-    db.keycombo.action-enum.attribute
-    | db.keycombo.action-other.attributes
-  db.keycombo.role.attribute = attribute role { text }
-  db.keycombo.attlist =
-    db.keycombo.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.keycombo.action.attrib
-  db.keycombo =
-    
-    ## A combination of input actions
-    element keycombo {
-      db.keycombo.attlist, db.keycombination.contentmodel+
-    }
-}
-div {
-  db.keysym.role.attribute = attribute role { text }
-  db.keysym.attlist =
-    db.keysym.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.keysym =
-    
-    ## The symbolic name of a key on a keyboard
-    element keysym { db.keysym.attlist, db._text }
-}
-div {
-  db.accel.role.attribute = attribute role { text }
-  db.accel.attlist =
-    db.accel.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.accel =
-    
-    ## A graphical user interface (GUI) keyboard shortcut
-    element accel { db.accel.attlist, db._text }
-}
-div {
-  db.shortcut.action.attrib = db.keycombo.action.attrib
-  db.shortcut.role.attribute = attribute role { text }
-  db.shortcut.attlist =
-    db.shortcut.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.shortcut.action.attrib
-  db.shortcut =
-    
-    ## A key combination for an action that is also accessible through a menu
-    element shortcut {
-      db.shortcut.attlist, db.keycombination.contentmodel+
-    }
-}
-db.os.inlines =
-  db.prompt
-  | db.envar
-  | db.filename
-  | db.command
-  | db.computeroutput
-  | db.userinput
-db.computeroutput.inlines =
-  (text | db.ubiq.inlines | db.os.inlines | db.technical.inlines)
-  | db.co
-  | db.markup.inlines
-db.userinput.inlines =
-  (text | db.ubiq.inlines | db.os.inlines | db.technical.inlines)
-  | db.co
-  | db.markup.inlines
-  | db.gui.inlines
-  | db.keyboard.inlines
-db.prompt.inlines = db._text | db.co
-div {
-  db.prompt.role.attribute = attribute role { text }
-  db.prompt.attlist =
-    db.prompt.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.prompt =
-    
-    ## A character or string indicating the start of an input field in a  computer display
-    element prompt { db.prompt.attlist, db.prompt.inlines* }
-}
-div {
-  db.envar.role.attribute = attribute role { text }
-  db.envar.attlist =
-    db.envar.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.envar =
-    
-    ## A software environment variable
-    element envar { db.envar.attlist, db._text }
-}
-div {
-  db.filename.class.enumeration =
-    
-    ## A device
-    "devicefile"
-    | 
-      ## A directory
-      "directory"
-    | 
-      ## A filename extension
-      "extension"
-    | 
-      ## A header file (as for a programming language)
-      "headerfile"
-    | 
-      ## A library file
-      "libraryfile"
-    | 
-      ## A partition (as of a hard disk)
-      "partition"
-    | 
-      ## A symbolic link
-      "symlink"
-  db.filename.class.attribute =
-    
-    ## Identifies the class of filename
-    attribute class { db.filename.class.enumeration }
-  db.filename.path.attribute =
-    
-    ## Specifies the path of the filename
-    attribute path { text }
-  db.filename.role.attribute = attribute role { text }
-  db.filename.attlist =
-    db.filename.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.filename.path.attribute?
-    & db.filename.class.attribute?
-  db.filename =
-    
-    ## The name of a file
-    element filename { db.filename.attlist, db._text }
-}
-div {
-  db.command.role.attribute = attribute role { text }
-  db.command.attlist =
-    db.command.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.command =
-    
-    ## The name of an executable program or other software command
-    element command { db.command.attlist, db._text }
-}
-div {
-  db.computeroutput.role.attribute = attribute role { text }
-  db.computeroutput.attlist =
-    db.computeroutput.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.computeroutput =
-    
-    ## Data, generally text, displayed or presented by a computer
-    element computeroutput {
-      db.computeroutput.attlist, db.computeroutput.inlines*
-    }
-}
-div {
-  db.userinput.role.attribute = attribute role { text }
-  db.userinput.attlist =
-    db.userinput.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.userinput =
-    
-    ## Data entered by the user
-    element userinput { db.userinput.attlist, db.userinput.inlines* }
-}
-div {
-  db.cmdsynopsis.role.attribute = attribute role { text }
-  db.cmdsynopsis.sepchar.attribute =
-    
-    ## Specifies the character that should separate the command and its top-level arguments
-    attribute sepchar { text }
-  db.cmdsynopsis.cmdlength.attribute =
-    
-    ## Indicates the displayed length of the command; this information may be used to intelligently indent command synopses which extend beyond one line
-    attribute cmdlength { text }
-  db.cmdsynopsis.label.attribute = db.label.attribute
-  db.cmdsynopsis.attlist =
-    db.cmdsynopsis.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.cmdsynopsis.sepchar.attribute?
-    & db.cmdsynopsis.cmdlength.attribute?
-    & db.cmdsynopsis.label.attribute?
-  db.cmdsynopsis.info = db._info.title.forbidden
-  db.cmdsynopsis =
-    
-    ## A syntax summary for a software command
-    element cmdsynopsis {
-      db.cmdsynopsis.attlist,
-      db.cmdsynopsis.info,
-      (db.command | db.arg | db.group | db.sbr)+,
-      db.synopfragment*
-    }
-}
-db.rep.enumeration =
-  
-  ## Can not be repeated.
-  "norepeat"
-  | 
-    ## Can be repeated.
-    "repeat"
-db.rep.attribute =
-  
-  ## Indicates whether or not repetition is possible.
-  [ a:defaultValue = "norepeat" ] attribute rep { db.rep.enumeration }
-db.choice.enumeration =
-  
-  ## Formatted to indicate that it is optional.
-  "opt"
-  | 
-    ## Formatted without indication.
-    "plain"
-  | 
-    ## Formatted to indicate that it is required.
-    "req"
-db.choice.opt.attribute =
-  
-  ## Indicates optionality.
-  [ a:defaultValue = "opt" ] attribute choice { db.choice.enumeration }
-db.choice.req.attribute =
-  
-  ## Indicates optionality.
-  [ a:defaultValue = "req" ] attribute choice { db.choice.enumeration }
-div {
-  db.arg.role.attribute = attribute role { text }
-  db.arg.rep.attribute = db.rep.attribute
-  db.arg.choice.attribute = db.choice.opt.attribute
-  db.arg.attlist =
-    db.arg.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.arg.rep.attribute?
-    & db.arg.choice.attribute?
-  db.arg =
-    
-    ## An argument in a cmdsynopsis
-    element arg {
-      db.arg.attlist,
-      (db._text
-       | db.arg
-       | db.group
-       | db.option
-       | db.synopfragmentref
-       | db.sbr)*
-    }
-}
-div {
-  db.group.role.attribute = attribute role { text }
-  db.group.rep.attribute = db.rep.attribute
-  db.group.choice.attribute = db.choice.opt.attribute
-  db.group.attlist =
-    db.group.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.group.rep.attribute?
-    & db.group.choice.attribute?
-  db.group =
-    
-    ## A group of elements in a cmdsynopsis
-    element group {
-      db.group.attlist,
-      (db.arg
-       | db.group
-       | db.option
-       | db.synopfragmentref
-       | db.replaceable
-       | db.sbr)+
-    }
-}
-div {
-  db.sbr.role.attribute = attribute role { text }
-  db.sbr.attlist = db.sbr.role.attribute? & db.common.attributes
-  db.sbr =
-    
-    ## An explicit line break in a command synopsis
-    element sbr { db.sbr.attlist, empty }
-}
-div {
-  db.synopfragment.role.attribute = attribute role { text }
-  db.synopfragment.attlist =
-    db.synopfragment.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.synopfragment =
-    
-    ## A portion of a cmdsynopsis broken out from the main body of the synopsis
-    element synopfragment {
-      db.synopfragment.attlist, (db.arg | db.group)+
-    }
-}
-div {
-  db.synopfragmentref.role.attribute = attribute role { text }
-  db.synopfragmentref.attlist =
-    db.synopfragmentref.role.attribute?
-    & db.common.attributes
-    & db.linkend.attribute
-  db.synopfragmentref =
-    
-    ## A reference to a fragment of a command synopsis
-    [
-      s:pattern [
-        name = "Synopsis fragment type constraint"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:synopfragmentref"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test =
-              "local-name(//*[@xml:id=current()/@linkend]) = 'synopfragment' and namespace-uri(//*[@xml:id=current()/@linkend]) = 'http://docbook.org/ns/docbook'"
-            "@linkend on synopfragmentref must point to a synopfragment."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element synopfragmentref { db.synopfragmentref.attlist, text }
-}
-db.programming.inlines =
-  db.function
-  | db.parameter
-  | db.varname
-  | db.returnvalue
-  | db.type
-  | db.classname
-  | db.exceptionname
-  | db.interfacename
-  | db.methodname
-  | db.modifier
-  | db.initializer
-  | db.oo.inlines
-db.oo.inlines = db.ooclass | db.ooexception | db.oointerface
-db.synopsis.blocks =
-  (db.funcsynopsis
-   | db.classsynopsis
-   | db.methodsynopsis
-   | db.constructorsynopsis
-   | db.destructorsynopsis
-   | db.fieldsynopsis)
-  | db.cmdsynopsis
-div {
-  db.synopsis.role.attribute = attribute role { text }
-  db.synopsis.label.attribute = db.label.attribute
-  db.synopsis.attlist =
-    db.synopsis.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.verbatim.attributes
-    & db.synopsis.label.attribute?
-  db.synopsis =
-    
-    ## A general-purpose element for representing the syntax of commands or functions
-    element synopsis { db.synopsis.attlist, db.verbatim.contentmodel }
-}
-div {
-  db.funcsynopsis.role.attribute = attribute role { text }
-  db.funcsynopsis.attlist =
-    db.funcsynopsis.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.language.attribute?
-  db.funcsynopsis.info = db._info.title.forbidden
-  db.funcsynopsis =
-    
-    ## The syntax summary for a function definition
-    element funcsynopsis {
-      db.funcsynopsis.attlist,
-      db.funcsynopsis.info,
-      (db.funcsynopsisinfo | db.funcprototype)+
-    }
-}
-div {
-  db.funcsynopsisinfo.role.attribute = attribute role { text }
-  db.funcsynopsisinfo.attlist =
-    db.funcsynopsisinfo.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.verbatim.attributes
-  db.funcsynopsisinfo =
-    
-    ## Information supplementing the funcdefs of a funcsynopsis
-    element funcsynopsisinfo {
-      db.funcsynopsisinfo.attlist, db.verbatim.contentmodel
-    }
-}
-div {
-  db.funcprototype.role.attribute = attribute role { text }
-  db.funcprototype.attlist =
-    db.funcprototype.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.funcprototype =
-    
-    ## The prototype of a function
-    element funcprototype {
-      db.funcprototype.attlist,
-      db.modifier*,
-      db.funcdef,
-      (db.void
-       | db.varargs
-       | ((db.paramdef | db.group.paramdef)+, db.varargs?)),
-      db.modifier*
-    }
-}
-div {
-  db.funcdef.role.attribute = attribute role { text }
-  db.funcdef.attlist =
-    db.funcdef.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.funcdef =
-    
-    ## A function (subroutine) name and its return type
-    element funcdef {
-      db.funcdef.attlist, (db._text | db.type | db.function)*
-    }
-}
-div {
-  db.function.role.attribute = attribute role { text }
-  db.function.attlist =
-    db.function.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.function =
-    
-    ## The name of a function or subroutine, as in a programming language
-    element function { db.function.attlist, db._text }
-}
-div {
-  db.void.role.attribute = attribute role { text }
-  db.void.attlist =
-    db.void.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.void =
-    
-    ## An empty element in a function synopsis indicating that the function in question takes no arguments
-    element void { db.void.attlist, empty }
-}
-div {
-  db.varargs.role.attribute = attribute role { text }
-  db.varargs.attlist =
-    db.varargs.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.varargs =
-    
-    ## An empty element in a function synopsis indicating a variable number of arguments
-    element varargs { db.varargs.attlist, empty }
-}
-div {
-  db.group.paramdef.role.attribute = attribute role { text }
-  db.group.paramdef.choice.attribute = db.choice.opt.attribute
-  db.group.paramdef.attlist =
-    db.group.paramdef.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.group.paramdef.choice.attribute?
-  db.group.paramdef =
-    
-    ## A group of parameters
-    element group {
-      db.group.paramdef.attlist, (db.paramdef | db.group.paramdef)+
-    }
-}
-div {
-  db.paramdef.role.attribute = attribute role { text }
-  db.paramdef.choice.enumeration =
-    
-    ## Formatted to indicate that it is optional.
-    "opt"
-    | 
-      ## Formatted to indicate that it is required.
-      "req"
-  db.paramdef.choice.attribute =
-    
-    ## Indicates optionality.
-    [ a:defaultValue = "opt" ]
-    attribute choice { db.paramdef.choice.enumeration }
-  db.paramdef.attlist =
-    db.paramdef.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.paramdef.choice.attribute?
-  db.paramdef =
-    
-    ## Information about a function parameter in a programming language
-    element paramdef {
-      db.paramdef.attlist,
-      (db._text
-       | db.initializer
-       | db.type
-       | db.parameter
-       | db.funcparams)*
-    }
-}
-div {
-  db.funcparams.role.attribute = attribute role { text }
-  db.funcparams.attlist =
-    db.funcparams.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.funcparams =
-    
-    ## Parameters for a function referenced through a function pointer in a synopsis
-    element funcparams { db.funcparams.attlist, db._text }
-}
-div {
-  db.classsynopsis.role.attribute = attribute role { text }
-  db.classsynopsis.class.enumeration =
-    
-    ## This is the synopsis of a class
-    "class"
-    | 
-      ## This is the synopsis of an interface
-      "interface"
-  db.classsynopsis.class.attribute =
-    
-    ## Specifies the nature of the synopsis
-    attribute class { db.classsynopsis.class.enumeration }
-  db.classsynopsis.attlist =
-    db.classsynopsis.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.language.attribute?
-    & db.classsynopsis.class.attribute?
-  db.classsynopsis =
-    
-    ## The syntax summary for a class definition
-    element classsynopsis {
-      db.classsynopsis.attlist,
-      db.oo.inlines+,
-      (db.classsynopsisinfo
-       | db.methodsynopsis
-       | db.constructorsynopsis
-       | db.destructorsynopsis
-       | db.fieldsynopsis)*
-    }
-}
-div {
-  db.classsynopsisinfo.role.attribute = attribute role { text }
-  db.classsynopsisinfo.attlist =
-    db.classsynopsisinfo.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.verbatim.attributes
-  db.classsynopsisinfo =
-    
-    ## Information supplementing the contents of a classsynopsis
-    element classsynopsisinfo {
-      db.classsynopsisinfo.attlist, db.verbatim.contentmodel
-    }
-}
-div {
-  db.ooclass.role.attribute = attribute role { text }
-  db.ooclass.attlist =
-    db.ooclass.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.ooclass =
-    
-    ## A class in an object-oriented programming language
-    element ooclass {
-      db.ooclass.attlist, (db.package | db.modifier)*, db.classname
-    }
-}
-div {
-  db.oointerface.role.attribute = attribute role { text }
-  db.oointerface.attlist =
-    db.oointerface.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.oointerface =
-    
-    ## An interface in an object-oriented programming language
-    element oointerface {
-      db.oointerface.attlist,
-      (db.package | db.modifier)*,
-      db.interfacename
-    }
-}
-div {
-  db.ooexception.role.attribute = attribute role { text }
-  db.ooexception.attlist =
-    db.ooexception.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.ooexception =
-    
-    ## An exception in an object-oriented programming language
-    element ooexception {
-      db.ooexception.attlist,
-      (db.package | db.modifier)*,
-      db.exceptionname
-    }
-}
-db.modifier.xml.space.attribute =
-  
-  ## Can be used to indicate that whitespace in the modifier should be preserved (for multi-line annotations, for example).
-  attribute xml:space {
-    
-    ## Extra whitespace and line breaks must be preserved.
-    [
-      # Ideally the definition of xml:space used on modifier would be
-      # different from the definition used on the verbatim elements. The
-      # verbatim elements forbid the use of xml:space="default" which
-      # wouldn't be a problem on modifier. But doing that causes the
-      # generated XSD schemas to be broken so I'm just reusing the existing
-      # definition for now. It won't be backwards incompatible to fix this
-      # problem in the future.
-      #    | ## Extra whitespace and line breaks are not preserved.
-      #      "default"
-      
-    ]
-    "preserve"
-  }
-div {
-  db.modifier.role.attribute = attribute role { text }
-  db.modifier.attlist =
-    db.modifier.xml.space.attribute?
-    & db.modifier.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.modifier =
-    
-    ## Modifiers in a synopsis
-    element modifier { db.modifier.attlist, db._text }
-}
-div {
-  db.interfacename.role.attribute = attribute role { text }
-  db.interfacename.attlist =
-    db.interfacename.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.interfacename =
-    
-    ## The name of an interface
-    element interfacename { db.interfacename.attlist, db._text }
-}
-div {
-  db.exceptionname.role.attribute = attribute role { text }
-  db.exceptionname.attlist =
-    db.exceptionname.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.exceptionname =
-    
-    ## The name of an exception
-    element exceptionname { db.exceptionname.attlist, db._text }
-}
-div {
-  db.fieldsynopsis.role.attribute = attribute role { text }
-  db.fieldsynopsis.attlist =
-    db.fieldsynopsis.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.language.attribute?
-  db.fieldsynopsis =
-    
-    ## The name of a field in a class definition
-    element fieldsynopsis {
-      db.fieldsynopsis.attlist,
-      db.modifier*,
-      db.type?,
-      db.varname,
-      db.initializer?
-    }
-}
-div {
-  db.initializer.role.attribute = attribute role { text }
-  db.initializer.attlist =
-    db.initializer.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.initializer.inlines = db._text | db.mathphrase | db.markup.inlines
-  db.initializer =
-    
-    ## The initializer for a fieldsynopsis
-    element initializer {
-      db.initializer.attlist, db.initializer.inlines*
-    }
-}
-div {
-  db.constructorsynopsis.role.attribute = attribute role { text }
-  db.constructorsynopsis.attlist =
-    db.constructorsynopsis.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.language.attribute?
-  db.constructorsynopsis =
-    
-    ## A syntax summary for a constructor
-    element constructorsynopsis {
-      db.constructorsynopsis.attlist,
-      db.modifier*,
-      db.methodname?,
-      ((db.methodparam | db.group.methodparam)+ | db.void?),
-      db.exceptionname*
-    }
-}
-div {
-  db.destructorsynopsis.role.attribute = attribute role { text }
-  db.destructorsynopsis.attlist =
-    db.destructorsynopsis.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.language.attribute?
-  db.destructorsynopsis =
-    
-    ## A syntax summary for a destructor
-    element destructorsynopsis {
-      db.destructorsynopsis.attlist,
-      db.modifier*,
-      db.methodname?,
-      ((db.methodparam | db.group.methodparam)+ | db.void?),
-      db.exceptionname*
-    }
-}
-div {
-  db.methodsynopsis.role.attribute = attribute role { text }
-  db.methodsynopsis.attlist =
-    db.methodsynopsis.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.language.attribute?
-  db.methodsynopsis =
-    
-    ## A syntax summary for a method
-    element methodsynopsis {
-      db.methodsynopsis.attlist,
-      db.modifier*,
-      (db.type | db.void)?,
-      db.methodname,
-      ((db.methodparam | db.group.methodparam)+ | db.void),
-      db.exceptionname*,
-      db.modifier*
-    }
-}
-div {
-  db.methodname.role.attribute = attribute role { text }
-  db.methodname.attlist =
-    db.methodname.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.methodname =
-    
-    ## The name of a method
-    element methodname { db.methodname.attlist, db._text }
-}
-div {
-  db.methodparam.role.attribute = attribute role { text }
-  db.methodparam.rep.attribute = db.rep.attribute
-  db.methodparam.choice.attribute = db.choice.req.attribute
-  db.methodparam.attlist =
-    db.methodparam.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.methodparam.rep.attribute?
-    & db.methodparam.choice.attribute?
-  db.methodparam =
-    
-    ## Parameters to a method
-    element methodparam {
-      db.methodparam.attlist,
-      db.modifier*,
-      db.type?,
-      ((db.modifier*, db.parameter, db.initializer?) | db.funcparams),
-      db.modifier*
-    }
-}
-div {
-  db.group.methodparam.role.attribute = attribute role { text }
-  db.group.methodparam.choice.attribute = db.choice.opt.attribute
-  db.group.methodparam.attlist =
-    db.group.methodparam.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.group.methodparam.choice.attribute?
-  db.group.methodparam =
-    
-    ## A group of method parameters
-    element group {
-      db.group.methodparam.attlist,
-      (db.methodparam | db.group.methodparam)+
-    }
-}
-div {
-  db.varname.role.attribute = attribute role { text }
-  db.varname.attlist =
-    db.varname.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.varname =
-    
-    ## The name of a variable
-    element varname { db.varname.attlist, db._text }
-}
-div {
-  db.returnvalue.role.attribute = attribute role { text }
-  db.returnvalue.attlist =
-    db.returnvalue.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.returnvalue =
-    
-    ## The value returned by a function
-    element returnvalue { db.returnvalue.attlist, db._text }
-}
-div {
-  db.type.role.attribute = attribute role { text }
-  db.type.attlist =
-    db.type.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.type =
-    
-    ## The classification of a value
-    element type { db.type.attlist, db._text }
-}
-div {
-  db.classname.role.attribute = attribute role { text }
-  db.classname.attlist =
-    db.classname.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.classname =
-    
-    ## The name of a class, in the object-oriented programming sense
-    element classname { db.classname.attlist, db._text }
-}
-div {
-  db.programlisting.role.attribute = attribute role { text }
-  db.programlisting.width.attribute = db.width.characters.attribute
-  db.programlisting.attlist =
-    db.programlisting.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.verbatim.attributes
-    & db.programlisting.width.attribute?
-  db.programlisting =
-    
-    ## A literal listing of all or part of a program
-    element programlisting {
-      db.programlisting.attlist, db.verbatim.contentmodel
-    }
-}
-db.admonition.blocks =
-  db.caution | db.important | db.note | db.tip | db.warning
-db.admonition.contentmodel = db._info.title.only, db.all.blocks+
-div {
-  db.caution.role.attribute = attribute role { text }
-  db.caution.attlist =
-    db.caution.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.caution =
-    
-    ## A note of caution
-    [
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:caution"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:caution)"
-            "caution must not occur among the children or descendants of caution"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:caution"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:important)"
-            "important must not occur among the children or descendants of caution"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:caution"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:note)"
-            "note must not occur among the children or descendants of caution"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:caution"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:tip)"
-            "tip must not occur among the children or descendants of caution"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:caution"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:warning)"
-            "warning must not occur among the children or descendants of caution"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element caution { db.caution.attlist, db.admonition.contentmodel }
-}
-div {
-  db.important.role.attribute = attribute role { text }
-  db.important.attlist =
-    db.important.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.important =
-    
-    ## An admonition set off from the text
-    [
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:important"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:caution)"
-            "caution must not occur among the children or descendants of important"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:important"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:important)"
-            "important must not occur among the children or descendants of important"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:important"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:note)"
-            "note must not occur among the children or descendants of important"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:important"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:tip)"
-            "tip must not occur among the children or descendants of important"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:important"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:warning)"
-            "warning must not occur among the children or descendants of important"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element important {
-      db.important.attlist, db.admonition.contentmodel
-    }
-}
-div {
-  db.note.role.attribute = attribute role { text }
-  db.note.attlist =
-    db.note.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.note =
-    
-    ## A message set off from the text
-    [
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:note"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:caution)"
-            "caution must not occur among the children or descendants of note"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:note"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:important)"
-            "important must not occur among the children or descendants of note"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:note"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:note)"
-            "note must not occur among the children or descendants of note"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:note"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:tip)"
-            "tip must not occur among the children or descendants of note"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:note"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:warning)"
-            "warning must not occur among the children or descendants of note"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element note { db.note.attlist, db.admonition.contentmodel }
-}
-div {
-  db.tip.role.attribute = attribute role { text }
-  db.tip.attlist =
-    db.tip.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.tip =
-    
-    ## A suggestion to the user, set off from the text
-    [
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:tip"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:caution)"
-            "caution must not occur among the children or descendants of tip"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:tip"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:important)"
-            "important must not occur among the children or descendants of tip"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:tip"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:note)"
-            "note must not occur among the children or descendants of tip"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:tip"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:tip)"
-            "tip must not occur among the children or descendants of tip"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:tip"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:warning)"
-            "warning must not occur among the children or descendants of tip"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element tip { db.tip.attlist, db.admonition.contentmodel }
-}
-div {
-  db.warning.role.attribute = attribute role { text }
-  db.warning.attlist =
-    db.warning.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.warning =
-    
-    ## An admonition set off from the text
-    [
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:warning"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:caution)"
-            "caution must not occur among the children or descendants of warning"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:warning"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:important)"
-            "important must not occur among the children or descendants of warning"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:warning"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:note)"
-            "note must not occur among the children or descendants of warning"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:warning"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:tip)"
-            "tip must not occur among the children or descendants of warning"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:warning"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:warning)"
-            "warning must not occur among the children or descendants of warning"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element warning { db.warning.attlist, db.admonition.contentmodel }
-}
-db.error.inlines =
-  db.errorcode | db.errortext | db.errorname | db.errortype
-div {
-  db.errorcode.role.attribute = attribute role { text }
-  db.errorcode.attlist =
-    db.errorcode.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.errorcode =
-    
-    ## An error code
-    element errorcode { db.errorcode.attlist, db._text }
-}
-div {
-  db.errorname.role.attribute = attribute role { text }
-  db.errorname.attlist =
-    db.errorname.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.errorname =
-    
-    ## An error name
-    element errorname { db.errorname.attlist, db._text }
-}
-div {
-  db.errortext.role.attribute = attribute role { text }
-  db.errortext.attlist =
-    db.errortext.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.errortext =
-    
-    ## An error message.
-    element errortext { db.errortext.attlist, db._text }
-}
-div {
-  db.errortype.role.attribute = attribute role { text }
-  db.errortype.attlist =
-    db.errortype.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.errortype =
-    
-    ## The classification of an error message
-    element errortype { db.errortype.attlist, db._text }
-}
-db.systemitem.inlines = db._text | db.co
-div {
-  db.systemitem.class.enumeration =
-    
-    ## A daemon or other system process (syslogd)
-    "daemon"
-    | 
-      ## A domain name (example.com)
-      "domainname"
-    | 
-      ## An ethernet address (00:05:4E:49:FD:8E)
-      "etheraddress"
-    | 
-      ## An event of some sort (SIGHUP)
-      "event"
-    | 
-      ## An event handler of some sort (hangup)
-      "eventhandler"
-    | 
-      ## A filesystem (ext3)
-      "filesystem"
-    | 
-      ## A fully qualified domain name (my.example.com)
-      "fqdomainname"
-    | 
-      ## A group name (wheel)
-      "groupname"
-    | 
-      ## An IP address (127.0.0.1)
-      "ipaddress"
-    | 
-      ## A library (libncurses)
-      "library"
-    | 
-      ## A macro
-      "macro"
-    | 
-      ## A netmask (255.255.255.192)
-      "netmask"
-    | 
-      ## A newsgroup (comp.text.xml)
-      "newsgroup"
-    | 
-      ## An operating system name (Hurd)
-      "osname"
-    | 
-      ## A process (gnome-cups-icon)
-      "process"
-    | 
-      ## A protocol (ftp)
-      "protocol"
-    | 
-      ## A resource
-      "resource"
-    | 
-      ## A security context (a role, permission, or security token, for example)
-      "securitycontext"
-    | 
-      ## A server (mail.example.com)
-      "server"
-    | 
-      ## A service (ppp)
-      "service"
-    | 
-      ## A system name (hephaistos)
-      "systemname"
-    | 
-      ## A user name (ndw)
-      "username"
-  db.systemitem.class-enum.attribute =
-    
-    ## Identifies the nature of the system item
-    attribute class { db.systemitem.class.enumeration }?
-  db.systemitem.class-other.attribute =
-    
-    ## Identifies the nature of the non-standard system item
-    attribute otherclass { xsd:NMTOKEN }
-  db.systemitem.class-other.attributes =
-    
-    ## Identifies the kind of systemitemgraphic identifier
-    attribute class {
-      
-      ## Indicates that the system item is some 'other' kind.
-      "other"
-    }
-    & db.systemitem.class-other.attribute
-  db.systemitem.class.attribute =
-    db.systemitem.class-enum.attribute
-    | db.systemitem.class-other.attributes
-  db.systemitem.role.attribute = attribute role { text }
-  db.systemitem.attlist =
-    db.systemitem.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.systemitem.class.attribute?
-  db.systemitem =
-    
-    ## A system-related item or term
-    element systemitem { db.systemitem.attlist, db.systemitem.inlines* }
-}
-div {
-  db.option.role.attribute = attribute role { text }
-  db.option.attlist =
-    db.option.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.option =
-    
-    ## An option for a software command
-    element option { db.option.attlist, db._text }
-}
-div {
-  db.optional.role.attribute = attribute role { text }
-  db.optional.attlist =
-    db.optional.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.optional =
-    
-    ## Optional information
-    element optional { db.optional.attlist, db._text }
-}
-div {
-  db.property.role.attribute = attribute role { text }
-  db.property.attlist =
-    db.property.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.property =
-    
-    ## A unit of data associated with some part of a computer system
-    element property { db.property.attlist, db._text }
-}
-div {
-  db.topic.status.attribute = db.status.attribute
-  db.topic.role.attribute = attribute role { text }
-  db.topic.type.attribute =
-    
-    ## Identifies the topic type
-    attribute type { text }
-  db.topic.attlist =
-    db.topic.role.attribute?
-    & db.topic.type.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.label.attribute?
-    & db.topic.status.attribute?
-  db.topic.info = db._info.title.req
-  db.topic =
-    
-    ## A modular unit of documentation not part of any particular narrative flow
-    element topic {
-      db.topic.attlist,
-      db.topic.info,
-      db.navigation.components*,
-      db.toplevel.blocks.or.sections,
-      db.navigation.components*
-    }
-}
-start =
-  db.assembly
-  | db.resources
-  | db.relationships
-  | db.transforms
-  | db.module
-db.grammar.attribute =
-  
-  ## Identifies the markup grammar of a resource
-  attribute grammar { text }
-div {
-  db.assembly.role.attribute = attribute role { text }
-  db.assembly.attlist =
-    db.assembly.role.attribute? & db.common.attributes
-  db.assembly.info = db._info
-  db.assembly =
-    
-    ## Defines the hierarchy and relationships for a collection of resources
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:assembly"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element assembly {
-      db.assembly.attlist,
-      db.assembly.info,
-      db.resources+,
-      db.structure*,
-      db.relationships*,
-      db.transforms?
-    }
-}
-div {
-  db.resources.role.attribute = attribute role { text }
-  db.resources.grammar.attribute = db.grammar.attribute
-  db.resources.attlist =
-    db.resources.role.attribute?
-    & db.resources.grammar.attribute?
-    & db.common.attributes
-  db.resources.info = db._info.title.forbidden
-  db.resources =
-    
-    ## Contains one or more resource objects that are managed by the assembly
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:resources"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element resources {
-      db.resources.attlist,
-      db.resources.info?,
-      (db.description*, db.resource+)
-    }
-}
-div {
-  db.resource.role.attribute = attribute role { text }
-  db.resource.fileref.attribute =
-    
-    ## Indentifies the location of the data by URI
-    attribute fileref { xsd:anyURI }
-  db.resource.grammar.attribute = db.grammar.attribute
-  db.resource.attlist =
-    db.resource.role.attribute?
-    & db.resource.grammar.attribute?
-    & db.common.attributes
-  db.resource =
-    
-    ## Identifies an object managed within the assembly
-    element resource {
-      db.resource.attlist,
-      db.resource.fileref.attribute,
-      db.description*
-    }
-}
-div {
-  db.structure.role.attribute = attribute role { text }
-  db.structure.type.attribute =
-    
-    ## Identifies the structure type of the structure
-    attribute type { xsd:NMTOKEN }
-  db.structure.resourceref.attribute =
-    
-    ## Indicates a single resource from which to construct this structure
-    attribute resourceref { xsd:IDREF }
-  db.structure.defaultformat.attribute =
-    
-    ## Identifies the default format of the structure
-    attribute defaultformat { xsd:NMTOKEN }
-  db.structure.renderas.attribute =
-    
-    ## Specifies the DocBook element to which this unit should be renamed
-    attribute renderas { xsd:QName }
-  db.structure.attlist =
-    db.structure.role.attribute?
-    & db.structure.type.attribute?
-    & db.structure.resourceref.attribute?
-    & db.structure.renderas.attribute?
-    & db.structure.defaultformat.attribute?
-    & db.common.attributes
-  db.structure.info = db.info?
-  db.structure =
-    
-    ## Describes the structure of a document
-    [
-      s:pattern [
-        name = "Specification of renderas"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:structure"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@renderas and db:output/@renderas"
-            "The renderas attribute can be specified on either the structure or output, but not both."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element structure {
-      db.structure.attlist,
-      (db.output* & db.filterin? & db.filterout? & db.structure.info),
-      db.merge?,
-      db.revhistory?,
-      db.module+
-    }
-}
-div {
-  db.output.role.attribute = attribute role { text }
-  db.output.chunk.attribute =
-    
-    ## Specifies chunking for this module
-    [ a:defaultValue = "auto" ]
-    attribute chunk { db.module.chunk.enumeration }
-  db.output.format.attribute =
-    
-    ## Identifies the format of the module or structure
-    attribute format { xsd:NMTOKENS }
-  db.output.file.attribute =
-    
-    ## Specifies the output file for this module or structure
-    attribute file { xsd:anyURI }
-  db.output.renderas.attribute =
-    
-    ## Specifies the DocBook element to which this unit should be renamed
-    attribute renderas { xsd:QName }
-  db.output.grammar.attribute = db.grammar.attribute
-  db.output.transform.attribute =
-    
-    ## Specifies the transformation that should be applied to this unit
-    attribute transform { xsd:NMTOKEN }
-  db.output.suppress.attribute =
-    
-    ## Indicates whether or not this unit should be suppressed
-    attribute suppress { xsd:boolean }
-  db.output.attlist =
-    db.output.role.attribute?
-    & db.common.attributes
-    & db.output.chunk.attribute?
-    & db.output.format.attribute?
-    & db.output.file.attribute?
-    & db.output.renderas.attribute?
-    & db.output.grammar.attribute?
-    & db.output.transform.attribute?
-    & db.output.suppress.attribute?
-  db.output =
-    
-    ## Specify an output format and/or file name and/or renderas
-    element output { db.output.attlist, empty }
-}
-div {
-  db.merge.role.attribute = attribute role { text }
-  db.merge.resourceref.attribute =
-    
-    ## Indicates a single resource from which to read merged info
-    attribute resourceref { xsd:IDREF }
-  db.merge.attlist =
-    db.merge.role.attribute?
-    & db.merge.resourceref.attribute?
-    & db.common.attributes
-  db.merge =
-    
-    ## A wrapper for information that a module overrides in the resource it includes
-    element merge { db.merge.attlist, (db._title & db.info.elements*) }
-}
-div {
-  db.module.role.attribute = attribute role { text }
-  db.module.chunk.enumeration =
-    
-    ## This module will be in a chunk
-    "true"
-    | 
-      ## This module will not be in a chunk
-      "false"
-    | 
-      ## Chunking of this module depends on the overall chunking algorithm
-      "auto"
-  db.module.chunk.attribute =
-    
-    ## Specifies chunking for this module
-    [ a:defaultValue = "auto" ]
-    attribute chunk { db.module.chunk.enumeration }
-  db.module.resourceref.attribute =
-    
-    ## Indicates a single resource from which to construct this module
-    attribute resourceref { xsd:IDREF }
-  db.module.omittitles.attribute =
-    
-    ## Indicates if titles should be omitted when including a resource
-    attribute omittitles { xsd:boolean }?
-  db.module.contentonly.attribute =
-    
-    ## Indicates if only the content should be copied when including a resource
-    attribute contentonly { xsd:boolean }?
-  db.module.renderas.attribute =
-    
-    ## Specifies the DocBook element to which this unit should be renamed
-    attribute renderas { xsd:QName }
-  db.module.attlist =
-    db.module.role.attribute?
-    & db.module.chunk.attribute?
-    & db.module.resourceref.attribute?
-    & db.module.omittitles.attribute?
-    & db.module.contentonly.attribute?
-    & db.module.renderas.attribute?
-    & db.common.attributes
-  db.module.info = db.info?
-  db.module =
-    
-    ## A modular component within a structure
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:module"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Specification of renderas"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:module"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@renderas and db:output/@renderas"
-            "The renderas attribute can be specified on either the structure or output, but not both."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element module {
-      db.module.attlist,
-      ((db.output | db.filterin | db.filterout)*,
-       db.module.info,
-       db.merge?,
-       db.module*)
-    }
-}
-div {
-  db.filterout.role.attribute = attribute role { text }
-  db.filterout.attlist =
-    db.filterout.role.attribute? & db.common.attributes
-  db.filterout =
-    
-    ## Elements with effectivity attributes matching this element are suppressed
-    element filterout { db.filterout.attlist, empty }
-}
-div {
-  db.filterin.role.attribute = attribute role { text }
-  db.filterin.attlist =
-    db.filterin.role.attribute? & db.common.attributes
-  db.filterin =
-    
-    ## Elements with effectivity attributes matching this element are allowed
-    element filterin { db.filterin.attlist, empty }
-}
-div {
-  db.relationships.role.attribute = attribute role { text }
-  db.relationships.type.attribute =
-    
-    ## Identifies the type of the contained relationships
-    attribute type { xsd:NMTOKENS }
-  db.relationships.attlist =
-    db.relationships.role.attribute?
-    & db.relationships.type.attribute?
-    & db.common.attributes
-  db.relationships.info = db._info
-  db.relationships =
-    
-    ## Groups relationship elements to define associations between resources
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:relationships"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element relationships {
-      db.relationships.attlist,
-      db.relationships.info,
-      (db.relationship | db.instance)+
-    }
-}
-div {
-  db.relationship.role.attribute = attribute role { text }
-  db.relationship.type.attribute =
-    
-    ## Identifies the type of the relationship
-    attribute type { xsd:NMTOKEN }
-  db.relationship.attlist =
-    db.relationship.role.attribute?
-    & db.relationship.type.attribute?
-    & db.linkend.attribute?
-    & db.common.attributes
-  db.relationship =
-    
-    ## A relationship associates one or more resources
-    element relationship {
-      db.relationship.attlist, db.association, db.instance+
-    }
-}
-div {
-  db.association.role.attribute = attribute role { text }
-  db.association.attlist =
-    db.association.role.attribute?
-    & db.linkend.attribute?
-    & db.common.attributes
-  db.association =
-    
-    ## Identifies the type of relationship between one or more resources
-    element association { db.association.attlist, text? }
-}
-div {
-  db.instance.role.attribute = attribute role { text }
-  db.instance.linking.attribute =
-    
-    ## Specifies the type of link for this instance
-    attribute linking { xsd:NMTOKENS }
-  db.instance.attlist =
-    db.instance.role.attribute?
-    & db.instance.linking.attribute?
-    & db.common.attributes
-  db.instance =
-    
-    ## Identifies a resource that is part of a relationship
-    element instance {
-      db.instance.attlist, db.linkend.attribute, empty
-    }
-}
-div {
-  db.transforms.role.attribute = attribute role { text }
-  db.transforms.attlist =
-    db.transforms.role.attribute? & db.common.attributes
-  db.transforms.info = db._info
-  db.transforms =
-    
-    ## List of transforms for converting from non-DocBook schemas
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:transforms"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element transforms {
-      db.transforms.attlist, db.transforms.info, db.transform+
-    }
-}
-div {
-  db.transform.role.attribute = attribute role { text }
-  db.transform.grammar.attribute = db.grammar.attribute
-  db.transform.fileref.attribute =
-    
-    ## Indentifies the location of the data by URI
-    attribute fileref { xsd:anyURI }
-  db.transform.name.attribute =
-    
-    ## Identifies the location of the data by reference
-    attribute name { xsd:NMTOKEN }
-  db.transform.attlist =
-    db.transform.role.attribute?
-    & (db.transform.grammar.attribute | db.transform.name.attribute)
-    & db.transform.fileref.attribute
-    & db.common.attributes
-  db.transform =
-    
-    ## Identifies a transform for converting from a non-DocBook schema
-    element transform { db.transform.attlist, empty }
-}
-div {
-  db.description.role.attribute = attribute role { text }
-  db.description.attlist =
-    db.description.role.attribute? & db.common.attributes
-  db.description =
-    
-    ## A description of a resource or resources
-    element description { db.description.attlist, db._text }
-}

+ 0 - 12976
stylesheets/lfs-xsl/docbook-xsl-1.78.1/assembly/schema/docbook51b7.rnc

@@ -1,12976 +0,0 @@
-namespace a = "http://relaxng.org/ns/compatibility/annotations/1.0"
-namespace ctrl = "http://nwalsh.com/xmlns/schema-control/"
-default namespace db = "http://docbook.org/ns/docbook"
-namespace html = "http://www.w3.org/1999/xhtml"
-namespace mml = "http://www.w3.org/1998/Math/MathML"
-namespace rng = "http://relaxng.org/ns/structure/1.0"
-namespace s = "http://purl.oclc.org/dsdl/schematron"
-namespace svg = "http://www.w3.org/2000/svg"
-namespace xlink = "http://www.w3.org/1999/xlink"
-
-# This file is part of DocBook V5.1b7
-# 
-# Copyright 1992-2011 HaL Computer Systems, Inc.,
-# O'Reilly & Associates, Inc., ArborText, Inc., Fujitsu Software
-# Corporation, Norman Walsh, Sun Microsystems, Inc., and the
-# Organization for the Advancement of Structured Information
-# Standards (OASIS).
-# 
-# Permission to use, copy, modify and distribute the DocBook schema
-# and its accompanying documentation for any purpose and without fee
-# is hereby granted in perpetuity, provided that the above copyright
-# notice and this paragraph appear in all copies. The copyright
-# holders make no representation about the suitability of the schema
-# for any purpose. It is provided "as is" without expressed or implied
-# warranty.
-# 
-# If you modify the DocBook schema in any way, label your schema as a
-# variant of DocBook. See the reference documentation
-# (http://docbook.org/tdg5/en/html/ch05.html#s-notdocbook)
-# for more information.
-# 
-# Please direct all questions, bug reports, or suggestions for changes
-# to the docbook@lists.oasis-open.org mailing list. For more
-# information, see http://www.oasis-open.org/docbook/.
-# 
-# ======================================================================
-start =
-  (db.set
-   | db.book
-   | db.divisions
-   | db.components
-   | db.navigation.components
-   | db.section
-   | db.para)
-  | (db.abstract
-     | db.mediaobject.content
-     | db.audiodata
-     | db.imagedata
-     | db.textdata
-     | db.videodata
-     | db.caption
-     | db.publishing.blocks
-     | db.formal.blocks
-     | db.informal.blocks
-     | db.formalpara
-     | db.inlinemediaobject
-     | db.list.blocks
-     | db.legalnotice
-     | db.verbatim.blocks
-     | db.graphic.blocks
-     | db.personblurb
-     | db.revhistory
-     | db.simpara
-     | db.step
-     | db.stepalternatives)
-  | (db.partintro | db.simplesect)
-  | db.annotation
-  | (db.sect1 | db.sect2 | db.sect3 | db.sect4 | db.sect5)
-  | (db.refentry | db.refsection | db.refsynopsisdiv)
-  | (db.refsect1 | db.refsect2 | db.refsect3)
-  | (db.glossary | db.glossdiv | db.glosslist)
-  | (db.bibliodiv | db.bibliolist)
-  | (db.setindex | db.index | db.indexdiv)
-  | (db.toc | db.tocdiv)
-  | (db.task | db.taskprerequisites | db.taskrelated | db.tasksummary)
-  | (db.calloutlist
-     | db.programlistingco
-     | db.screenco
-     | db.imageobjectco)
-  | (db.productionset | db.constraintdef)
-  | (db.msg
-     | db.msgexplan
-     | db.msgmain
-     | db.msgrel
-     | db.msgset
-     | db.msgsub)
-  | (db.qandadiv | db.qandaentry | db.qandaset)
-  | (db.equation | db.informalequation)
-  | db.cmdsynopsis
-  | (db.synopsis.blocks | db.funcsynopsisinfo | db.classsynopsisinfo)
-  | db.admonition.blocks
-  | db.topic
-div {
-  db._any.attribute =
-    
-    ## Any attribute, including any attribute in any namespace.
-    attribute * { text }
-  db._any =
-    
-    ## Any element from almost any namespace
-    element * - (db:* | html:*) {
-      (db._any.attribute | text | db._any)*
-    }
-}
-db.arch.attribute =
-  
-  ## Designates the computer or chip architecture to which the element applies
-  attribute arch { text }
-db.audience.attribute =
-  
-  ## Designates the intended audience to which the element applies, for example, system administrators, programmers, or new users.
-  attribute audience { text }
-db.condition.attribute =
-  
-  ## provides a standard place for application-specific effectivity
-  attribute condition { text }
-db.conformance.attribute =
-  
-  ## Indicates standards conformance characteristics of the element
-  attribute conformance { text }
-db.os.attribute =
-  
-  ## Indicates the operating system to which the element is applicable
-  attribute os { text }
-db.revision.attribute =
-  
-  ## Indicates the editorial revision to which the element belongs
-  attribute revision { text }
-db.security.attribute =
-  
-  ## Indicates something about the security level associated with the element to which it applies
-  attribute security { text }
-db.userlevel.attribute =
-  
-  ## Indicates the level of user experience for which the element applies
-  attribute userlevel { text }
-db.vendor.attribute =
-  
-  ## Indicates the computer vendor to which the element applies.
-  attribute vendor { text }
-db.wordsize.attribute =
-  
-  ## Indicates the word size (width in bits) of the computer architecture to which the element applies
-  attribute wordsize { text }
-db.effectivity.attributes =
-  db.arch.attribute?
-  & db.audience.attribute?
-  & db.condition.attribute?
-  & db.conformance.attribute?
-  & db.os.attribute?
-  & db.revision.attribute?
-  & db.security.attribute?
-  & db.userlevel.attribute?
-  & db.vendor.attribute?
-  & db.wordsize.attribute?
-db.endterm.attribute =
-  
-  ## Points to the element whose content is to be used as the text of the link
-  attribute endterm { xsd:IDREF }
-db.linkend.attribute =
-  
-  ## Points to an internal link target by identifying the value of its xml:id attribute
-  attribute linkend { xsd:IDREF }
-db.linkends.attribute =
-  
-  ## Points to one or more internal link targets by identifying the value of their xml:id attributes
-  attribute linkends { xsd:IDREFS }
-db.xlink.href.attribute =
-  
-  ## Identifies a link target with a URI
-  attribute xlink:href { xsd:anyURI }
-db.xlink.simple.type.attribute =
-  
-  ## Identifies the XLink link type
-  attribute xlink:type {
-    
-    ## An XLink simple link type
-    "simple"
-  }
-db.xlink.role.attribute =
-  
-  ## Identifies the XLink role of the link
-  attribute xlink:role { xsd:anyURI }
-db.xlink.arcrole.attribute =
-  
-  ## Identifies the XLink arcrole of the link
-  attribute xlink:arcrole { xsd:anyURI }
-db.xlink.title.attribute =
-  
-  ## Identifies the XLink title of the link
-  attribute xlink:title { text }
-db.xlink.show.enumeration =
-  
-  ## An application traversing to the ending resource should load it in a new window, frame, pane, or other relevant presentation context.
-  "new"
-  | 
-    ## An application traversing to the ending resource should load the resource in the same window, frame, pane, or other relevant presentation context in which the starting resource was loaded.
-    "replace"
-  | 
-    ## An application traversing to the ending resource should load its presentation in place of the presentation of the starting resource.
-    "embed"
-  | 
-    ## The behavior of an application traversing to the ending resource is unconstrained by XLink. The application should look for other markup present in the link to determine the appropriate behavior.
-    "other"
-  | 
-    ## The behavior of an application traversing to the ending resource is unconstrained by this specification. No other markup is present to help the application determine the appropriate behavior.
-    "none"
-db.xlink.show.attribute =
-  
-  ## Identifies the XLink show behavior of the link
-  attribute xlink:show { db.xlink.show.enumeration }
-db.xlink.actuate.enumeration =
-  
-  ## An application should traverse to the ending resource immediately on loading the starting resource.
-  "onLoad"
-  | 
-    ## An application should traverse from the starting resource to the ending resource only on a post-loading event triggered for the purpose of traversal.
-    "onRequest"
-  | 
-    ## The behavior of an application traversing to the ending resource is unconstrained by this specification. The application should look for other markup present in the link to determine the appropriate behavior.
-    "other"
-  | 
-    ## The behavior of an application traversing to the ending resource is unconstrained by this specification. No other markup is present to help the application determine the appropriate behavior.
-    "none"
-db.xlink.actuate.attribute =
-  
-  ## Identifies the XLink actuate behavior of the link
-  attribute xlink:actuate { db.xlink.actuate.enumeration }
-db.xlink.simple.link.attributes =
-  db.xlink.simple.type.attribute?
-  & db.xlink.href.attribute?
-  & db.xlink.role.attribute?
-  & db.xlink.arcrole.attribute?
-  & db.xlink.title.attribute?
-  & db.xlink.show.attribute?
-  & db.xlink.actuate.attribute?
-db.xlink.attributes =
-  db.xlink.simple.link.attributes
-  | (db.xlink.extended.link.attributes
-     | db.xlink.locator.link.attributes
-     | db.xlink.arc.link.attributes
-     | db.xlink.resource.link.attributes
-     | db.xlink.title.link.attributes)
-db.xml.id.attribute =
-  
-  ## Identifies the unique ID value of the element
-  attribute xml:id { xsd:ID }
-db.version.attribute =
-  
-  ## Specifies the DocBook version of the element and its descendants
-  attribute version { text }
-db.xml.lang.attribute =
-  
-  ## Specifies the natural language of the element and its descendants
-  attribute xml:lang { text }
-db.xml.base.attribute =
-  
-  ## Specifies the base URI of the element and its descendants
-  attribute xml:base { xsd:anyURI }
-db.remap.attribute =
-  
-  ## Provides the name or similar semantic identifier assigned to the content in some previous markup scheme
-  attribute remap { text }
-db.xreflabel.attribute =
-  
-  ## Provides the text that is to be generated for a cross reference to the element
-  attribute xreflabel { text }
-db.xrefstyle.attribute =
-  
-  ## Specifies a keyword or keywords identifying additional style information
-  attribute xrefstyle { text }
-db.revisionflag.enumeration =
-  
-  ## The element has been changed.
-  "changed"
-  | 
-    ## The element is new (has been added to the document).
-    "added"
-  | 
-    ## The element has been deleted.
-    "deleted"
-  | 
-    ## Explicitly turns off revision markup for this element.
-    "off"
-db.revisionflag.attribute =
-  
-  ## Identifies the revision status of the element
-  attribute revisionflag { db.revisionflag.enumeration }
-db.dir.enumeration =
-  
-  ## Left-to-right text
-  "ltr"
-  | 
-    ## Right-to-left text
-    "rtl"
-  | 
-    ## Left-to-right override
-    "lro"
-  | 
-    ## Right-to-left override
-    "rlo"
-db.dir.attribute =
-  
-  ## Identifies the direction of text in an element
-  attribute dir { db.dir.enumeration }
-db.common.base.attributes =
-  db.version.attribute?
-  & db.xml.lang.attribute?
-  & db.xml.base.attribute?
-  & db.remap.attribute?
-  & db.xreflabel.attribute?
-  & db.revisionflag.attribute?
-  & db.dir.attribute?
-  & db.effectivity.attributes
-db.common.attributes =
-  db.xml.id.attribute?
-  & db.common.base.attributes
-  & db.annotations.attribute?
-db.common.idreq.attributes =
-  db.xml.id.attribute
-  & db.common.base.attributes
-  & db.annotations.attribute?
-db.common.linking.attributes =
-  (db.linkend.attribute | db.xlink.attributes)?
-db.common.req.linking.attributes =
-  db.linkend.attribute | db.xlink.attributes
-db.common.data.attributes =
-  
-  ## Specifies the format of the data
-  attribute format { text }?,
-  (
-   ## Indentifies the location of the data by URI
-   attribute fileref { xsd:anyURI }
-   | 
-     ## Identifies the location of the data by external identifier (entity name)
-     attribute entityref { xsd:ENTITY })
-db.verbatim.continuation.enumeration =
-  
-  ## Line numbering continues from the immediately preceding element with the same name.
-  "continues"
-  | 
-    ## Line numbering restarts (begins at 1, usually).
-    "restarts"
-db.verbatim.continuation.attribute =
-  
-  ## Determines whether line numbering continues from the previous element or restarts.
-  attribute continuation { db.verbatim.continuation.enumeration }
-db.verbatim.linenumbering.enumeration =
-  
-  ## Lines are numbered.
-  "numbered"
-  | 
-    ## Lines are not numbered.
-    "unnumbered"
-db.verbatim.linenumbering.attribute =
-  
-  ## Determines whether lines are numbered.
-  attribute linenumbering { db.verbatim.linenumbering.enumeration }
-db.verbatim.startinglinenumber.attribute =
-  
-  ## Specifies the initial line number.
-  attribute startinglinenumber { xsd:integer }
-db.verbatim.language.attribute =
-  
-  ## Identifies the language (i.e. programming language) of the verbatim content.
-  attribute language { text }
-db.verbatim.xml.space.attribute =
-  
-  ## Can be used to indicate explicitly that whitespace in the verbatim environment is preserved. Whitespace must always be preserved in verbatim environments whether this attribute is specified or not.
-  attribute xml:space {
-    
-    ## Whitespace must be preserved.
-    "preserve"
-  }
-db.verbatim.common.attributes =
-  db.verbatim.continuation.attribute?
-  & db.verbatim.linenumbering.attribute?
-  & db.verbatim.startinglinenumber.attribute?
-  & db.verbatim.xml.space.attribute?
-db.verbatim.attributes =
-  db.verbatim.common.attributes & db.verbatim.language.attribute?
-db.label.attribute =
-  
-  ## Specifies an identifying string for presentation purposes
-  attribute label { text }
-db.width.characters.attribute =
-  
-  ## Specifies the width (in characters) of the element
-  attribute width { xsd:nonNegativeInteger }
-db.spacing.enumeration =
-  
-  ## The spacing should be "compact".
-  "compact"
-  | 
-    ## The spacing should be "normal".
-    "normal"
-db.spacing.attribute =
-  
-  ## Specifies (a hint about) the spacing of the content
-  attribute spacing { db.spacing.enumeration }
-db.pgwide.enumeration =
-  
-  ## The element should be rendered in the current text flow (with the flow column width).
-  "0"
-  | 
-    ## The element should be rendered across the full text page.
-    "1"
-db.pgwide.attribute =
-  
-  ## Indicates if the element is rendered across the column or the page
-  attribute pgwide { db.pgwide.enumeration }
-db.language.attribute =
-  
-  ## Identifies the language (i.e. programming language) of the content.
-  attribute language { text }
-db.performance.enumeration =
-  
-  ## The content describes an optional step or steps.
-  "optional"
-  | 
-    ## The content describes a required step or steps.
-    "required"
-db.performance.attribute =
-  
-  ## Specifies if the content is required or optional.
-  attribute performance { db.performance.enumeration }
-db.floatstyle.attribute =
-  
-  ## Specifies style information to be used when rendering the float
-  attribute floatstyle { text }
-db.width.attribute =
-  
-  ## Specifies the width of the element
-  attribute width { text }
-db.depth.attribute =
-  
-  ## Specifies the depth of the element
-  attribute depth { text }
-db.contentwidth.attribute =
-  
-  ## Specifies the width of the content rectangle
-  attribute contentwidth { text }
-db.contentdepth.attribute =
-  
-  ## Specifies the depth of the content rectangle
-  attribute contentdepth { text }
-db.scalefit.enumeration =
-  
-  ## False (do not scale-to-fit; anamorphic scaling may occur)
-  "0"
-  | 
-    ## True (scale-to-fit; anamorphic scaling is forbidden)
-    "1"
-db.scale.attribute =
-  
-  ## Specifies the scaling factor
-  attribute scale { xsd:positiveInteger }
-db.classid.attribute =
-  
-  ## Specifies a classid for a media object player
-  attribute classid { text }
-db.autoplay.attribute =
-  
-  ## Specifies the autoplay setting for a media object player
-  attribute autoplay { text }
-db.halign.enumeration =
-  
-  ## Centered horizontally
-  "center"
-  | 
-    ## Aligned horizontally on the specified character
-    "char"
-  | 
-    ## Fully justified (left and right margins or edges)
-    "justify"
-  | 
-    ## Left aligned
-    "left"
-  | 
-    ## Right aligned
-    "right"
-db.valign.enumeration =
-  
-  ## Aligned on the bottom of the region
-  "bottom"
-  | 
-    ## Centered vertically
-    "middle"
-  | 
-    ## Aligned on the top of the region
-    "top"
-db.biblio.class.enumeration =
-  
-  ## A digital object identifier.
-  "doi"
-  | 
-    ## An international standard book number.
-    "isbn"
-  | 
-    ## An international standard technical report number (ISO 10444).
-    "isrn"
-  | 
-    ## An international standard serial number.
-    "issn"
-  | 
-    ## An international standard text code.
-    "istc"
-  | 
-    ## A Library of Congress reference number.
-    "libraryofcongress"
-  | 
-    ## A publication number (an internal number or possibly organizational standard).
-    "pubsnumber"
-  | 
-    ## A Uniform Resource Identifier
-    "uri"
-db.biblio.class-enum.attribute =
-  
-  ## Identifies the kind of bibliographic identifier
-  attribute class { db.biblio.class.enumeration }?
-db.biblio.class-other.attribute =
-  
-  ## Identifies the nature of the non-standard bibliographic identifier
-  attribute otherclass { xsd:NMTOKEN }
-db.biblio.class-other.attributes =
-  
-  ## Identifies the kind of bibliographic identifier
-  attribute class {
-    
-    ## Indicates that the identifier is some 'other' kind.
-    "other"
-  }
-  & db.biblio.class-other.attribute
-db.biblio.class.attribute =
-  db.biblio.class-enum.attribute | db.biblio.class-other.attributes
-db.ubiq.inlines =
-  (db.inlinemediaobject
-   | db.remark
-   | db.link.inlines
-   | db.alt
-   | db.trademark
-   | # below, effectively the publishing inlines (as of 5.0)
-     db.abbrev
-   | db.acronym
-   | db.date
-   | db._emphasis
-   | db.footnote
-   | db.footnoteref
-   | db._foreignphrase
-   | db._phrase
-   | db._quote
-   | db.subscript
-   | db.superscript
-   | db.wordasword)
-  | db.annotation
-  | (db._firstterm | db._glossterm)
-  | db.indexterm
-  | db.coref
-db._text = (text | db.ubiq.inlines | db._phrase | db.replaceable)*
-db._title = db.title? & db.titleabbrev? & db.subtitle?
-db._title.req = db.title & db.titleabbrev? & db.subtitle?
-db._title.only = db.title? & db.titleabbrev?
-db._title.onlyreq = db.title & db.titleabbrev?
-db._info = (db._title, db.titleforbidden.info?) | db.info?
-db._info.title.req =
-  (db._title.req, db.titleforbidden.info?) | db.titlereq.info
-db._info.title.only =
-  (db._title.only, db.titleforbidden.info?) | db.titleonly.info
-db._info.title.onlyreq =
-  (db._title.onlyreq, db.titleforbidden.info?) | db.titleonlyreq.info
-db._info.title.forbidden = db.titleforbidden.info?
-db.all.inlines =
-  text
-  | db.ubiq.inlines
-  | db.general.inlines
-  | db.domain.inlines
-  | db.extension.inlines
-db.general.inlines =
-  db.publishing.inlines
-  | db.product.inlines
-  | db.bibliography.inlines
-  | db.graphic.inlines
-  | db.indexing.inlines
-  | db.link.inlines
-db.domain.inlines =
-  db.technical.inlines
-  | db.math.inlines
-  | db.markup.inlines
-  | db.gui.inlines
-  | db.keyboard.inlines
-  | db.os.inlines
-  | db.programming.inlines
-  | db.error.inlines
-db.technical.inlines =
-  (db.replaceable | db.package | db.parameter)
-  | db.termdef
-  | db.nonterminal
-  | (db.systemitem | db.option | db.optional | db.property)
-db.product.inlines =
-  db.trademark
-  | (db.productnumber
-     | db.productname
-     | db.database
-     | db.application
-     | db.hardware)
-db.bibliography.inlines =
-  db.citation
-  | db.citerefentry
-  | db.citetitle
-  | db.citebiblioid
-  | db.author
-  | db.person
-  | db.personname
-  | db.org
-  | db.orgname
-  | db.editor
-  | db.jobtitle
-db.publishing.inlines =
-  (db.abbrev
-   | db.acronym
-   | db.date
-   | db.emphasis
-   | db.footnote
-   | db.footnoteref
-   | db.foreignphrase
-   | db.phrase
-   | db.quote
-   | db.subscript
-   | db.superscript
-   | db.wordasword)
-  | db.glossary.inlines
-  | db.coref
-db.graphic.inlines = db.inlinemediaobject
-db.indexing.inlines = notAllowed | db.indexterm
-db.link.inlines =
-  (db.xref | db.link | db.olink | db.anchor) | db.biblioref
-db.extension.inlines = notAllowed
-db.nopara.blocks =
-  (db.list.blocks
-   | db.formal.blocks
-   | db.informal.blocks
-   | db.publishing.blocks
-   | db.graphic.blocks
-   | db.technical.blocks
-   | db.verbatim.blocks
-   | db.bridgehead
-   | db.remark
-   | db.revhistory)
-  | db.indexterm
-  | db.synopsis.blocks
-  | db.admonition.blocks
-db.para.blocks = db.anchor | db.para | db.formalpara | db.simpara
-db.all.blocks =
-  (db.nopara.blocks | db.para.blocks | db.extension.blocks)
-  | db.annotation
-db.formal.blocks = (db.example | db.figure | db.table) | db.equation
-db.informal.blocks =
-  (db.informalexample | db.informalfigure | db.informaltable)
-  | db.informalequation
-db.publishing.blocks =
-  db.sidebar | db.blockquote | db.address | db.epigraph
-db.graphic.blocks = db.mediaobject | db.screenshot
-db.technical.blocks =
-  db.procedure
-  | db.task
-  | (db.productionset | db.constraintdef)
-  | db.msgset
-db.list.blocks =
-  (db.itemizedlist
-   | db.orderedlist
-   | db.procedure
-   | db.simplelist
-   | db.variablelist
-   | db.segmentedlist)
-  | db.glosslist
-  | db.bibliolist
-  | db.calloutlist
-  | db.qandaset
-db.verbatim.blocks =
-  (db.screen | db.literallayout)
-  | (db.programlistingco | db.screenco)
-  | (db.programlisting | db.synopsis)
-db.extension.blocks = notAllowed
-db.info.extension = db._any
-db.info.elements =
-  (db.abstract
-   | db.address
-   | db.artpagenums
-   | db.author
-   | db.authorgroup
-   | db.authorinitials
-   | db.bibliocoverage
-   | db.biblioid
-   | db.bibliosource
-   | db.collab
-   | db.confgroup
-   | db.contractsponsor
-   | db.contractnum
-   | db.copyright
-   | db.cover
-   | db.date
-   | db.edition
-   | db.editor
-   | db.issuenum
-   | db.keywordset
-   | db.legalnotice
-   | db.mediaobject
-   | db.org
-   | db.orgname
-   | db.othercredit
-   | db.pagenums
-   | db.printhistory
-   | db.pubdate
-   | db.publisher
-   | db.publishername
-   | db.releaseinfo
-   | db.revhistory
-   | db.seriesvolnums
-   | db.subjectset
-   | db.volumenum
-   | db.info.extension)
-  | db.annotation
-  | db.extendedlink
-  | (db.bibliomisc | db.bibliomset | db.bibliorelation | db.biblioset)
-  | db.itermset
-  | (db.productname | db.productnumber)
-db.bibliographic.elements =
-  db.info.elements
-  | db.publishing.inlines
-  | db.citerefentry
-  | db.citetitle
-  | db.citebiblioid
-  | db.person
-  | db.personblurb
-  | db.personname
-  | db.subtitle
-  | db.title
-  | db.titleabbrev
-div {
-  db.title.role.attribute = attribute role { text }
-  db.title.attlist =
-    db.title.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.title =
-    
-    ## The text of the title of a section of a document or of a formal block-level element
-    element title { db.title.attlist, db.all.inlines* }
-}
-div {
-  db.titleabbrev.role.attribute = attribute role { text }
-  db.titleabbrev.attlist =
-    db.titleabbrev.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.titleabbrev =
-    
-    ## The abbreviation of a title
-    element titleabbrev { db.titleabbrev.attlist, db.all.inlines* }
-}
-div {
-  db.subtitle.role.attribute = attribute role { text }
-  db.subtitle.attlist =
-    db.subtitle.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.subtitle =
-    
-    ## The subtitle of a document
-    element subtitle { db.subtitle.attlist, db.all.inlines* }
-}
-div {
-  db.info.role.attribute = attribute role { text }
-  db.info.attlist = db.info.role.attribute? & db.common.attributes
-  db.info =
-    
-    ## A wrapper for information about a component or other block
-    element info { db.info.attlist, (db._title & db.info.elements*) }
-}
-div {
-  db.titlereq.info.role.attribute = attribute role { text }
-  db.titlereq.info.attlist =
-    db.titlereq.info.role.attribute? & db.common.attributes
-  db.titlereq.info =
-    
-    ## A wrapper for information about a component or other block with a required title
-    element info {
-      db.titlereq.info.attlist, (db._title.req & db.info.elements*)
-    }
-}
-div {
-  db.titleonly.info.role.attribute = attribute role { text }
-  db.titleonly.info.attlist =
-    db.titleonly.info.role.attribute? & db.common.attributes
-  db.titleonly.info =
-    
-    ## A wrapper for information about a component or other block with only a title
-    element info {
-      db.titleonly.info.attlist, (db._title.only & db.info.elements*)
-    }
-}
-div {
-  db.titleonlyreq.info.role.attribute = attribute role { text }
-  db.titleonlyreq.info.attlist =
-    db.titleonlyreq.info.role.attribute? & db.common.attributes
-  db.titleonlyreq.info =
-    
-    ## A wrapper for information about a component or other block with only a required title
-    element info {
-      db.titleonlyreq.info.attlist,
-      (db._title.onlyreq & db.info.elements*)
-    }
-}
-div {
-  db.titleforbidden.info.role.attribute = attribute role { text }
-  db.titleforbidden.info.attlist =
-    db.titleforbidden.info.role.attribute? & db.common.attributes
-  db.titleforbidden.info =
-    
-    ## A wrapper for information about a component or other block without a title
-    element info { db.titleforbidden.info.attlist, db.info.elements* }
-}
-div {
-  db.subjectset.role.attribute = attribute role { text }
-  db.subjectset.scheme.attribute =
-    
-    ## Identifies the controlled vocabulary used by this set's terms
-    attribute scheme { xsd:NMTOKEN }
-  db.subjectset.attlist =
-    db.subjectset.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.subjectset.scheme.attribute?
-  db.subjectset =
-    
-    ## A set of terms describing the subject matter of a document
-    element subjectset { db.subjectset.attlist, db.subject+ }
-}
-div {
-  db.subject.role.attribute = attribute role { text }
-  db.subject.weight.attribute =
-    
-    ## Specifies a ranking for this subject relative to other subjects in the same set
-    attribute weight { text }
-  db.subject.attlist =
-    db.subject.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.subject.weight.attribute?
-  db.subject =
-    
-    ## One of a group of terms describing the subject matter of a document
-    element subject { db.subject.attlist, db.subjectterm+ }
-}
-div {
-  db.subjectterm.role.attribute = attribute role { text }
-  db.subjectterm.attlist =
-    db.subjectterm.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.subjectterm =
-    
-    ## A term in a group of terms describing the subject matter of a document
-    element subjectterm { db.subjectterm.attlist, text }
-}
-div {
-  db.keywordset.role.attribute = attribute role { text }
-  db.keywordset.attlist =
-    db.keywordset.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.keywordset =
-    
-    ## A set of keywords describing the content of a document
-    element keywordset { db.keywordset.attlist, db.keyword+ }
-}
-div {
-  db.keyword.role.attribute = attribute role { text }
-  db.keyword.attlist =
-    db.keyword.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.keyword =
-    
-    ## One of a set of keywords describing the content of a document
-    element keyword { db.keyword.attlist, text }
-}
-db.table.choice = notAllowed | db.cals.table | db.html.table
-db.informaltable.choice =
-  notAllowed | db.cals.informaltable | db.html.informaltable
-db.table = db.table.choice
-db.informaltable = db.informaltable.choice
-div {
-  db.procedure.role.attribute = attribute role { text }
-  db.procedure.attlist =
-    db.procedure.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.procedure.info = db._info.title.only
-  db.procedure =
-    
-    ## A list of operations to be performed in a well-defined sequence
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:procedure"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element procedure {
-      db.procedure.attlist, db.procedure.info, db.all.blocks*, db.step+
-    }
-}
-div {
-  db.step.role.attribute = attribute role { text }
-  db.step.attlist =
-    db.step.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.performance.attribute?
-  db.step.info = db._info.title.only
-  # This content model is blocks*, step|stepalternatives, blocks* but
-  # expressed this way it avoids UPA issues in XSD and DTD versions
-  db.step =
-    
-    ## A unit of action in a procedure
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:step"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element step {
-      db.step.attlist,
-      db.step.info,
-      ((db.all.blocks+,
-        ((db.substeps | db.stepalternatives), db.all.blocks*)?)
-       | ((db.substeps | db.stepalternatives), db.all.blocks*))
-    }
-}
-div {
-  db.stepalternatives.role.attribute = attribute role { text }
-  db.stepalternatives.attlist =
-    db.stepalternatives.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.performance.attribute?
-  db.stepalternatives.info = db._info.title.forbidden
-  db.stepalternatives =
-    
-    ## Alternative steps in a procedure
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:stepalternatives"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element stepalternatives {
-      db.stepalternatives.attlist, db.stepalternatives.info, db.step+
-    }
-}
-div {
-  db.substeps.role.attribute = attribute role { text }
-  db.substeps.attlist =
-    db.substeps.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.performance.attribute?
-  db.substeps =
-    
-    ## A wrapper for steps that occur within steps in a procedure
-    element substeps { db.substeps.attlist, db.step+ }
-}
-div {
-  db.sidebar.floatstyle.attribute = db.floatstyle.attribute
-  db.sidebar.role.attribute = attribute role { text }
-  db.sidebar.attlist =
-    db.sidebar.role.attribute?
-    & db.sidebar.floatstyle.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.sidebar.info = db._info
-  db.sidebar =
-    
-    ## A portion of a document that is isolated from the main narrative flow
-    [
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:sidebar"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:sidebar)"
-            "sidebar must not occur among the children or descendants of sidebar"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:sidebar"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element sidebar {
-      db.sidebar.attlist, db.sidebar.info, db.all.blocks+
-    }
-}
-div {
-  db.abstract.role.attribute = attribute role { text }
-  db.abstract.attlist =
-    db.abstract.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.abstract.info = db._info.title.only
-  db.abstract =
-    
-    ## A summary
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:abstract"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element abstract {
-      db.abstract.attlist, db.abstract.info, db.para.blocks+
-    }
-}
-div {
-  db.personblurb.role.attribute = attribute role { text }
-  db.personblurb.attlist =
-    db.personblurb.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.personblurb.info = db._info.title.only
-  db.personblurb =
-    
-    ## A short description or note about a person
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:personblurb"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element personblurb {
-      db.personblurb.attlist, db.personblurb.info, db.para.blocks+
-    }
-}
-div {
-  db.blockquote.role.attribute = attribute role { text }
-  db.blockquote.attlist =
-    db.blockquote.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.blockquote.info = db._info.title.only
-  db.blockquote =
-    
-    ## A quotation set off from the main text
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:blockquote"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element blockquote {
-      db.blockquote.attlist,
-      db.blockquote.info,
-      db.attribution?,
-      db.all.blocks+
-    }
-}
-div {
-  db.attribution.role.attribute = attribute role { text }
-  db.attribution.attlist =
-    db.attribution.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.attribution =
-    
-    ## The source of a block quote or epigraph
-    element attribution {
-      db.attribution.attlist,
-      (db._text
-       | db.person
-       | db.personname
-       | db.citetitle
-       | db.citation)*
-    }
-}
-div {
-  db.bridgehead.renderas.enumeration =
-    
-    ## Render as a first-level section
-    "sect1"
-    | 
-      ## Render as a second-level section
-      "sect2"
-    | 
-      ## Render as a third-level section
-      "sect3"
-    | 
-      ## Render as a fourth-level section
-      "sect4"
-    | 
-      ## Render as a fifth-level section
-      "sect5"
-  db.bridgehead.renderas-enum.attribute =
-    
-    ## Indicates how the bridge head should be rendered
-    attribute renderas { db.bridgehead.renderas.enumeration }?
-  db.bridgehead.renderas-other.attribute =
-    
-    ## Identifies the nature of the non-standard rendering
-    attribute otherrenderas { xsd:NMTOKEN }
-  db.bridgehead.renderas-other.attributes =
-    
-    ## Indicates how the bridge head should be rendered
-    attribute renderas {
-      
-      ## Identifies a non-standard rendering
-      "other"
-    }
-    & db.bridgehead.renderas-other.attribute
-  db.bridgehead.renderas.attribute =
-    db.bridgehead.renderas-enum.attribute
-    | db.bridgehead.renderas-other.attributes
-  db.bridgehead.role.attribute = attribute role { text }
-  db.bridgehead.attlist =
-    db.bridgehead.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.bridgehead.renderas.attribute?
-  db.bridgehead =
-    
-    ## A free-floating heading
-    element bridgehead { db.bridgehead.attlist, db.all.inlines* }
-}
-div {
-  db.remark.role.attribute = attribute role { text }
-  db.remark.attlist =
-    db.remark.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.remark =
-    
-    ## A remark (or comment) intended for presentation in a draft manuscript
-    element remark { db.remark.attlist, db.all.inlines* }
-}
-div {
-  db.epigraph.role.attribute = attribute role { text }
-  db.epigraph.attlist =
-    db.epigraph.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.epigraph.info = db._info.title.forbidden
-  db.epigraph =
-    
-    ## A short inscription at the beginning of a document or component
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:epigraph"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element epigraph {
-      db.epigraph.attlist,
-      db.epigraph.info,
-      db.attribution?,
-      (db.para.blocks | db.literallayout)+
-    }
-}
-div {
-  db.footnote.role.attribute = attribute role { text }
-  db.footnote.label.attribute =
-    
-    ## Identifies the desired footnote mark
-    attribute label { xsd:NMTOKEN }
-  db.footnote.attlist =
-    db.footnote.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.footnote.label.attribute?
-  db.footnote =
-    
-    ## A footnote
-    [
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:footnote"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:footnote)"
-            "footnote must not occur among the children or descendants of footnote"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:footnote"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:example)"
-            "example must not occur among the children or descendants of footnote"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:footnote"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:figure)"
-            "figure must not occur among the children or descendants of footnote"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:footnote"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:table)"
-            "table must not occur among the children or descendants of footnote"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:footnote"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:equation)"
-            "equation must not occur among the children or descendants of footnote"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:footnote"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:sidebar)"
-            "sidebar must not occur among the children or descendants of footnote"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:footnote"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:task)"
-            "task must not occur among the children or descendants of footnote"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:footnote"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:epigraph)"
-            "epigraph must not occur among the children or descendants of footnote"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:footnote"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:caution)"
-            "caution must not occur among the children or descendants of footnote"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:footnote"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:important)"
-            "important must not occur among the children or descendants of footnote"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:footnote"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:note)"
-            "note must not occur among the children or descendants of footnote"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:footnote"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:tip)"
-            "tip must not occur among the children or descendants of footnote"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:footnote"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:warning)"
-            "warning must not occur among the children or descendants of footnote"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element footnote { db.footnote.attlist, db.all.blocks+ }
-}
-div {
-  db.formalpara.role.attribute = attribute role { text }
-  db.formalpara.attlist =
-    db.formalpara.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.formalpara.info = db._info.title.onlyreq
-  db.formalpara =
-    
-    ## A paragraph with a title
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:formalpara"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element formalpara {
-      db.formalpara.attlist,
-      db.formalpara.info,
-      db.indexing.inlines*,
-      db.para
-    }
-}
-div {
-  db.para.role.attribute = attribute role { text }
-  db.para.attlist =
-    db.para.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.para.info = db._info.title.forbidden
-  db.para =
-    
-    ## A paragraph
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:para"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element para {
-      db.para.attlist,
-      db.para.info,
-      (db.all.inlines | db.nopara.blocks)*
-    }
-}
-div {
-  db.simpara.role.attribute = attribute role { text }
-  db.simpara.attlist =
-    db.simpara.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.simpara.info = db._info.title.forbidden
-  db.simpara =
-    
-    ## A paragraph that contains only text and inline markup, no block elements
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:simpara"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element simpara {
-      db.simpara.attlist, db.simpara.info, db.all.inlines*
-    }
-}
-div {
-  db.itemizedlist.role.attribute = attribute role { text }
-  db.itemizedlist.mark.attribute =
-    
-    ## Identifies the type of mark to be used on items in this list
-    attribute mark { xsd:NMTOKEN }
-  db.itemizedlist.attlist =
-    db.itemizedlist.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.spacing.attribute?
-    & db.itemizedlist.mark.attribute?
-  db.itemizedlist.info = db._info.title.only
-  db.itemizedlist =
-    
-    ## A list in which each entry is marked with a bullet or other dingbat
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:itemizedlist"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element itemizedlist {
-      db.itemizedlist.attlist,
-      db.itemizedlist.info,
-      db.all.blocks*,
-      db.listitem+
-    }
-}
-div {
-  db.orderedlist.role.attribute = attribute role { text }
-  db.orderedlist.continuation.enumeration =
-    
-    ## Specifies that numbering should begin where the preceding list left off
-    "continues"
-    | 
-      ## Specifies that numbering should begin again at 1
-      "restarts"
-  db.orderedlist.continuation.attribute =
-    
-    ## Indicates how list numbering should begin relative to the immediately preceding list
-    attribute continuation { db.orderedlist.continuation.enumeration }
-  db.orderedlist.startingnumber.attribute =
-    
-    ## Specifies the initial line number.
-    attribute startingnumber { xsd:integer }
-  db.orderedlist.inheritnum.enumeration =
-    
-    ## Specifies that numbering should ignore list nesting
-    "ignore"
-    | 
-      ## Specifies that numbering should inherit from outer-level lists
-      "inherit"
-  db.orderedlist.inheritnum.attribute =
-    
-    ## Indicates whether or not item numbering should be influenced by list nesting
-    attribute inheritnum { db.orderedlist.inheritnum.enumeration }
-  db.orderedlist.numeration.enumeration =
-    
-    ## Specifies Arabic numeration (1, 2, 3, …)
-    "arabic"
-    | 
-      ## Specifies upper-case alphabetic numeration (A, B, C, …)
-      "upperalpha"
-    | 
-      ## Specifies lower-case alphabetic numeration (a, b, c, …)
-      "loweralpha"
-    | 
-      ## Specifies upper-case Roman numeration (I, II, III, …)
-      "upperroman"
-    | 
-      ## Specifies lower-case Roman numeration (i, ii, iii …)
-      "lowerroman"
-  db.orderedlist.numeration.attribute =
-    
-    ## Indicates the desired numeration
-    attribute numeration { db.orderedlist.numeration.enumeration }
-  db.orderedlist.attlist =
-    db.orderedlist.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.spacing.attribute?
-    & (db.orderedlist.continuation.attribute
-       | db.orderedlist.startingnumber.attribute)?
-    & db.orderedlist.inheritnum.attribute?
-    & db.orderedlist.numeration.attribute?
-  db.orderedlist.info = db._info.title.only
-  db.orderedlist =
-    
-    ## A list in which each entry is marked with a sequentially incremented label
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:orderedlist"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element orderedlist {
-      db.orderedlist.attlist,
-      db.orderedlist.info,
-      db.all.blocks*,
-      db.listitem+
-    }
-}
-div {
-  db.listitem.role.attribute = attribute role { text }
-  db.listitem.override.attribute =
-    
-    ## Specifies the keyword for the type of mark that should be used on this
-    ##  item, instead of the mark that would be used by default
-    attribute override { xsd:NMTOKEN }
-  db.listitem.attlist =
-    db.listitem.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.listitem.override.attribute?
-  db.listitem =
-    
-    ## A wrapper for the elements of a list item
-    element listitem { db.listitem.attlist, db.all.blocks+ }
-}
-div {
-  db.segmentedlist.role.attribute = attribute role { text }
-  db.segmentedlist.attlist =
-    db.segmentedlist.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.segmentedlist.info = db._info.title.only
-  db.segmentedlist =
-    
-    ## A segmented list, a list of sets of elements
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:segmentedlist"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element segmentedlist {
-      db.segmentedlist.attlist,
-      db.segmentedlist.info,
-      db.segtitle+,
-      db.seglistitem+
-    }
-}
-div {
-  db.segtitle.role.attribute = attribute role { text }
-  db.segtitle.attlist =
-    db.segtitle.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.segtitle =
-    
-    ## The title of an element of a list item in a segmented list
-    element segtitle { db.segtitle.attlist, db.all.inlines* }
-}
-div {
-  db.seglistitem.role.attribute = attribute role { text }
-  db.seglistitem.attlist =
-    db.seglistitem.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.seglistitem =
-    
-    ## A list item in a segmented list
-    [
-      s:pattern [
-        name = "Cardinality of segments and titles"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:seglistitem"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "count(db:seg) = count(../db:segtitle)"
-            "The number of seg elements must be the same as the number of segtitle elements in the parent segmentedlist"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element seglistitem { db.seglistitem.attlist, db.seg+ }
-}
-div {
-  db.seg.role.attribute = attribute role { text }
-  db.seg.attlist =
-    db.seg.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.seg =
-    
-    ## An element of a list item in a segmented list
-    element seg { db.seg.attlist, db.all.inlines* }
-}
-div {
-  db.simplelist.role.attribute = attribute role { text }
-  db.simplelist.type.enumeration =
-    
-    ## A tabular presentation in row-major order.
-    "horiz"
-    | 
-      ## A tabular presentation in column-major order.
-      "vert"
-    | 
-      ## An inline presentation, usually a comma-delimited list.
-      "inline"
-  db.simplelist.type.attribute =
-    
-    ## Specifies the type of list presentation.
-    [ a:defaultValue = "vert" ]
-    attribute type { db.simplelist.type.enumeration }
-  db.simplelist.columns.attribute =
-    
-    ## Specifies the number of columns for horizontal or vertical presentation
-    attribute columns { xsd:integer }
-  db.simplelist.attlist =
-    db.simplelist.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.simplelist.type.attribute?
-    & db.simplelist.columns.attribute?
-  db.simplelist =
-    
-    ## An undecorated list of single words or short phrases
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:simplelist"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element simplelist { db.simplelist.attlist, db.member+ }
-}
-div {
-  db.member.role.attribute = attribute role { text }
-  db.member.attlist =
-    db.member.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.member =
-    
-    ## An element of a simple list
-    element member { db.member.attlist, db.all.inlines* }
-}
-div {
-  db.variablelist.role.attribute = attribute role { text }
-  db.variablelist.termlength.attribute =
-    
-    ## Indicates a length beyond which the presentation system may consider a term too long and select an alternate presentation for that term, item, or list
-    attribute termlength { text }
-  db.variablelist.attlist =
-    db.variablelist.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.spacing.attribute?
-    & db.variablelist.termlength.attribute?
-  db.variablelist.info = db._info.title.only
-  db.variablelist =
-    
-    ## A list in which each entry is composed of a set of one or more terms and an associated description
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:variablelist"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element variablelist {
-      db.variablelist.attlist,
-      db.variablelist.info,
-      db.all.blocks*,
-      db.varlistentry+
-    }
-}
-div {
-  db.varlistentry.role.attribute = attribute role { text }
-  db.varlistentry.attlist =
-    db.varlistentry.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.varlistentry =
-    
-    ## A wrapper for a set of terms and the associated description in a variable list
-    element varlistentry {
-      db.varlistentry.attlist, db.term+, db.listitem
-    }
-}
-div {
-  db.term.role.attribute = attribute role { text }
-  db.term.attlist =
-    db.term.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.term =
-    
-    ## The word or phrase being defined or described in a variable list
-    element term { db.term.attlist, db.all.inlines* }
-}
-div {
-  db.example.role.attribute = attribute role { text }
-  db.example.label.attribute = db.label.attribute
-  db.example.width.attribute = db.width.characters.attribute
-  db.example.pgwide.attribute = db.pgwide.attribute
-  db.example.floatstyle.attribute = db.floatstyle.attribute
-  db.example.attlist =
-    db.example.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.example.label.attribute?
-    & db.example.floatstyle.attribute?
-    & (db.example.width.attribute | db.example.pgwide.attribute)?
-  db.example.info = db._info.title.onlyreq
-  db.example =
-    
-    ## A formal example, with a title
-    [
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:example"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:example)"
-            "example must not occur among the children or descendants of example"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:example"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:figure)"
-            "figure must not occur among the children or descendants of example"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:example"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:table)"
-            "table must not occur among the children or descendants of example"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:example"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:equation)"
-            "equation must not occur among the children or descendants of example"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:example"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:caution)"
-            "caution must not occur among the children or descendants of example"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:example"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:important)"
-            "important must not occur among the children or descendants of example"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:example"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:note)"
-            "note must not occur among the children or descendants of example"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:example"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:tip)"
-            "tip must not occur among the children or descendants of example"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:example"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:warning)"
-            "warning must not occur among the children or descendants of example"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:example"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element example {
-      db.example.attlist, db.example.info, db.all.blocks+, db.caption?
-    }
-}
-div {
-  db.informalexample.role.attribute = attribute role { text }
-  db.informalexample.width.attribute = db.width.characters.attribute
-  db.informalexample.pgwide.attribute = db.pgwide.attribute
-  db.informalexample.floatstyle.attribute = db.floatstyle.attribute
-  db.informalexample.attlist =
-    db.informalexample.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.informalexample.floatstyle.attribute?
-    & (db.informalexample.width.attribute
-       | db.informalexample.pgwide.attribute)?
-  db.informalexample.info = db._info.title.forbidden
-  db.informalexample =
-    
-    ## A displayed example without a title
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:informalexample"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element informalexample {
-      db.informalexample.attlist,
-      db.informalexample.info,
-      db.all.blocks+,
-      db.caption?
-    }
-}
-db.verbatim.inlines = (db.all.inlines | db.lineannotation) | db.co
-db.verbatim.contentmodel =
-  db._info.title.forbidden, (db.textobject | db.verbatim.inlines*)
-div {
-  db.literallayout.role.attribute = attribute role { text }
-  db.literallayout.class.enumeration =
-    
-    ## The literal layout should be formatted with a monospaced font
-    "monospaced"
-    | 
-      ## The literal layout should be formatted with the current font
-      "normal"
-  db.literallayout.class.attribute =
-    
-    ## Specifies the class of literal layout
-    attribute class { db.literallayout.class.enumeration }
-  db.literallayout.attlist =
-    db.literallayout.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.verbatim.attributes
-    & db.literallayout.class.attribute?
-  db.literallayout =
-    
-    ## A block of text in which line breaks and white space are to be reproduced faithfully
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:literallayout"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element literallayout {
-      db.literallayout.attlist, db.verbatim.contentmodel
-    }
-}
-div {
-  db.screen.role.attribute = attribute role { text }
-  db.screen.width.attribute = db.width.characters.attribute
-  db.screen.attlist =
-    db.screen.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.verbatim.attributes
-    & db.screen.width.attribute?
-  db.screen =
-    
-    ## Text that a user sees or might see on a computer screen
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:screen"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element screen { db.screen.attlist, db.verbatim.contentmodel }
-}
-div {
-  db.screenshot.role.attribute = attribute role { text }
-  db.screenshot.attlist =
-    db.screenshot.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.screenshot.info = db._info
-  db.screenshot =
-    
-    ## A representation of what the user sees or might see on a computer screen
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:screenshot"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element screenshot {
-      db.screenshot.attlist, db.screenshot.info, db.mediaobject
-    }
-}
-div {
-  db.figure.role.attribute = attribute role { text }
-  db.figure.label.attribute = db.label.attribute
-  db.figure.pgwide.attribute = db.pgwide.attribute
-  db.figure.floatstyle.attribute = db.floatstyle.attribute
-  db.figure.attlist =
-    db.figure.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.figure.label.attribute?
-    & db.figure.pgwide.attribute?
-    & db.figure.floatstyle.attribute?
-  db.figure.info = db._info.title.onlyreq
-  db.figure =
-    
-    ## A formal figure, generally an illustration, with a title
-    [
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:figure"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:example)"
-            "example must not occur among the children or descendants of figure"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:figure"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:figure)"
-            "figure must not occur among the children or descendants of figure"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:figure"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:table)"
-            "table must not occur among the children or descendants of figure"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:figure"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:equation)"
-            "equation must not occur among the children or descendants of figure"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:figure"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:caution)"
-            "caution must not occur among the children or descendants of figure"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:figure"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:important)"
-            "important must not occur among the children or descendants of figure"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:figure"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:note)"
-            "note must not occur among the children or descendants of figure"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:figure"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:tip)"
-            "tip must not occur among the children or descendants of figure"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:figure"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:warning)"
-            "warning must not occur among the children or descendants of figure"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:figure"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element figure {
-      db.figure.attlist, db.figure.info, db.all.blocks+, db.caption?
-    }
-}
-div {
-  db.informalfigure.role.attribute = attribute role { text }
-  db.informalfigure.label.attribute = db.label.attribute
-  db.informalfigure.pgwide.attribute = db.pgwide.attribute
-  db.informalfigure.floatstyle.attribute = db.floatstyle.attribute
-  db.informalfigure.attlist =
-    db.informalfigure.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.informalfigure.label.attribute?
-    & db.informalfigure.pgwide.attribute?
-    & db.informalfigure.floatstyle.attribute?
-  db.informalfigure.info = db._info.title.forbidden
-  db.informalfigure =
-    
-    ## A untitled figure
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:informalfigure"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element informalfigure {
-      db.informalfigure.attlist,
-      db.informalfigure.info,
-      db.all.blocks+,
-      db.caption?
-    }
-}
-db.mediaobject.content =
-  (db.videoobject | db.audioobject | db.imageobject | db.textobject)
-  | db.imageobjectco
-div {
-  db.mediaobject.role.attribute = attribute role { text }
-  db.mediaobject.attlist =
-    db.mediaobject.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.mediaobject.info = db._info.title.forbidden
-  db.mediaobject =
-    
-    ## A displayed media object (video, audio, image, etc.)
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:mediaobject"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element mediaobject {
-      db.mediaobject.attlist,
-      db.mediaobject.info,
-      db.alt?,
-      db.mediaobject.content+,
-      db.caption?
-    }
-}
-div {
-  db.inlinemediaobject.role.attribute = attribute role { text }
-  db.inlinemediaobject.attlist =
-    db.inlinemediaobject.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.inlinemediaobject.info = db._info.title.forbidden
-  db.inlinemediaobject =
-    
-    ## An inline media object (video, audio, image, and so on)
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:inlinemediaobject"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element inlinemediaobject {
-      db.inlinemediaobject.attlist,
-      db.inlinemediaobject.info,
-      db.alt?,
-      db.mediaobject.content+
-    }
-}
-div {
-  db.videoobject.role.attribute = attribute role { text }
-  db.videoobject.attlist =
-    db.videoobject.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.videoobject.info = db._info.title.forbidden
-  db.videoobject =
-    
-    ## A wrapper for video data and its associated meta-information
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:videoobject"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element videoobject {
-      db.videoobject.attlist,
-      db.videoobject.info,
-      db.videodata,
-      db.multimediaparam*
-    }
-}
-div {
-  db.audioobject.role.attribute = attribute role { text }
-  db.audioobject.attlist =
-    db.audioobject.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.audioobject.info = db._info.title.forbidden
-  db.audioobject =
-    
-    ## A wrapper for audio data and its associated meta-information
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:audioobject"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element audioobject {
-      db.audioobject.attlist,
-      db.audioobject.info,
-      db.audiodata,
-      db.multimediaparam*
-    }
-}
-db.imageobject.content =
-  db.imagedata | db.imagedata.mathml | db.imagedata.svg
-div {
-  db.imageobject.role.attribute = attribute role { text }
-  db.imageobject.attlist =
-    db.imageobject.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.imageobject.info = db._info.title.forbidden
-  db.imageobject =
-    
-    ## A wrapper for image data and its associated meta-information
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:imageobject"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element imageobject {
-      db.imageobject.attlist,
-      db.imageobject.info,
-      db.imageobject.content
-    }
-}
-div {
-  db.textobject.role.attribute = attribute role { text }
-  db.textobject.attlist =
-    db.textobject.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.textobject.info = db._info.title.forbidden
-  db.textobject =
-    
-    ## A wrapper for a text description of an object and its associated meta-information
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:textobject"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element textobject {
-      db.textobject.attlist,
-      db.textobject.info,
-      (db.phrase | db.textdata | db.all.blocks+)
-    }
-}
-div {
-  db.videodata.role.attribute = attribute role { text }
-  db.videodata.align.enumeration = db.halign.enumeration
-  db.videodata.align.attribute =
-    
-    ## Specifies the (horizontal) alignment of the video data
-    attribute align { db.videodata.align.enumeration }
-  db.videodata.autoplay.attribute = db.autoplay.attribute
-  db.videodata.classid.attribute = db.classid.attribute
-  db.videodata.valign.enumeration = db.valign.enumeration
-  db.videodata.valign.attribute =
-    
-    ## Specifies the vertical alignment of the video data
-    attribute valign { db.videodata.valign.enumeration }
-  db.videodata.width.attribute = db.width.attribute
-  db.videodata.depth.attribute = db.depth.attribute
-  db.videodata.contentwidth.attribute = db.contentwidth.attribute
-  db.videodata.contentdepth.attribute = db.contentdepth.attribute
-  db.videodata.scalefit.enumeration = db.scalefit.enumeration
-  db.videodata.scalefit.attribute =
-    
-    ## Determines if anamorphic scaling is forbidden
-    attribute scalefit { db.videodata.scalefit.enumeration }
-  db.videodata.scale.attribute = db.scale.attribute
-  db.videodata.attlist =
-    db.videodata.role.attribute?
-    & db.common.attributes
-    & db.common.data.attributes
-    & db.videodata.align.attribute?
-    & db.videodata.valign.attribute?
-    & db.videodata.width.attribute?
-    & db.videodata.contentwidth.attribute?
-    & db.videodata.scalefit.attribute?
-    & db.videodata.scale.attribute?
-    & db.videodata.depth.attribute?
-    & db.videodata.contentdepth.attribute?
-    & db.videodata.autoplay.attribute?
-    & db.videodata.classid.attribute?
-  db.videodata.info = db._info.title.forbidden
-  db.videodata =
-    
-    ## Pointer to external video data
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:videodata"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element videodata { db.videodata.attlist, db.videodata.info }
-}
-div {
-  db.audiodata.role.attribute = attribute role { text }
-  db.audiodata.align.enumeration = db.halign.enumeration
-  db.audiodata.align.attribute =
-    
-    ## Specifies the (horizontal) alignment of the video data
-    attribute align { db.audiodata.align.enumeration }
-  db.audiodata.autoplay.attribute = db.autoplay.attribute
-  db.audiodata.classid.attribute = db.classid.attribute
-  db.audiodata.contentwidth.attribute = db.contentwidth.attribute
-  db.audiodata.contentdepth.attribute = db.contentdepth.attribute
-  db.audiodata.depth.attribute = db.depth.attribute
-  db.audiodata.scale.attribute = db.scale.attribute
-  db.audiodata.scalefit.enumeration = db.scalefit.enumeration
-  db.audiodata.scalefit.attribute =
-    
-    ## Determines if anamorphic scaling is forbidden
-    attribute scalefit { db.audiodata.scalefit.enumeration }
-  db.audiodata.valign.enumeration = db.valign.enumeration
-  db.audiodata.valign.attribute =
-    
-    ## Specifies the vertical alignment of the video data
-    attribute valign { db.audiodata.valign.enumeration }
-  db.audiodata.width.attribute = db.width.attribute
-  db.audiodata.attlist =
-    db.audiodata.role.attribute?
-    & db.common.attributes
-    & db.common.data.attributes
-    & db.audiodata.align.attribute?
-    & db.audiodata.autoplay.attribute?
-    & db.audiodata.classid.attribute?
-    & db.audiodata.contentdepth.attribute?
-    & db.audiodata.contentwidth.attribute?
-    & db.audiodata.depth.attribute?
-    & db.audiodata.scale.attribute?
-    & db.audiodata.scalefit.attribute?
-    & db.audiodata.valign.attribute?
-    & db.audiodata.width.attribute?
-  db.audiodata.info = db._info.title.forbidden
-  db.audiodata =
-    
-    ## Pointer to external audio data
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:audiodata"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element audiodata { db.audiodata.attlist, db.audiodata.info }
-}
-div {
-  db.imagedata.role.attribute = attribute role { text }
-  db.imagedata.align.enumeration = db.halign.enumeration
-  db.imagedata.align.attribute =
-    
-    ## Specifies the (horizontal) alignment of the image data
-    attribute align { db.imagedata.align.enumeration }
-  db.imagedata.valign.enumeration = db.valign.enumeration
-  db.imagedata.valign.attribute =
-    
-    ## Specifies the vertical alignment of the image data
-    attribute valign { db.imagedata.valign.enumeration }
-  db.imagedata.width.attribute = db.width.attribute
-  db.imagedata.depth.attribute = db.depth.attribute
-  db.imagedata.contentwidth.attribute = db.contentwidth.attribute
-  db.imagedata.contentdepth.attribute = db.contentdepth.attribute
-  db.imagedata.scalefit.enumeration = db.scalefit.enumeration
-  db.imagedata.scalefit.attribute =
-    
-    ## Determines if anamorphic scaling is forbidden
-    attribute scalefit { db.imagedata.scalefit.enumeration }
-  db.imagedata.scale.attribute = db.scale.attribute
-  db.imagedata.attlist =
-    db.imagedata.role.attribute?
-    & db.common.attributes
-    & db.common.data.attributes
-    & db.imagedata.align.attribute?
-    & db.imagedata.valign.attribute?
-    & db.imagedata.width.attribute?
-    & db.imagedata.contentwidth.attribute?
-    & db.imagedata.scalefit.attribute?
-    & db.imagedata.scale.attribute?
-    & db.imagedata.depth.attribute?
-    & db.imagedata.contentdepth.attribute?
-  db.imagedata.info = db._info.title.forbidden
-  db.imagedata =
-    
-    ## Pointer to external image data
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:imagedata"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element imagedata { db.imagedata.attlist, db.imagedata.info }
-}
-div {
-  db.textdata.role.attribute = attribute role { text }
-  db.textdata.encoding.attribute =
-    
-    ## Identifies the encoding of the text in the external file
-    attribute encoding { text }
-  db.textdata.attlist =
-    db.textdata.role.attribute?
-    & db.common.attributes
-    & db.common.data.attributes
-    & db.textdata.encoding.attribute?
-  db.textdata.info = db._info.title.forbidden
-  db.textdata =
-    
-    ## Pointer to external text data
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:textdata"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element textdata { db.textdata.attlist, db.textdata.info }
-}
-div {
-  db.multimediaparam.role.attribute = attribute role { text }
-  db.multimediaparam.name.attribute =
-    
-    ## Specifies the name of the parameter
-    attribute name { text }
-  db.multimediaparam.value.attribute =
-    
-    ## Specifies the value of the parameter
-    attribute value { text }
-  db.multimediaparam.valuetype.attribute =
-    
-    ## Specifies the type of the value of the parameter
-    attribute valuetype { text }
-  db.multimediaparam.attlist =
-    db.multimediaparam.role.attribute?
-    & db.common.attributes
-    & db.multimediaparam.name.attribute
-    & db.multimediaparam.value.attribute
-    & db.multimediaparam.valuetype.attribute?
-  db.multimediaparam =
-    
-    ## Application specific parameters for a media player
-    element multimediaparam { db.multimediaparam.attlist, empty }
-}
-div {
-  db.caption.role.attribute = attribute role { text }
-  db.caption.attlist =
-    db.caption.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.caption.info = db._info.title.forbidden
-  db.caption =
-    
-    ## A caption
-    [
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:caption"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:example)"
-            "example must not occur among the children or descendants of caption"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:caption"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:figure)"
-            "figure must not occur among the children or descendants of caption"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:caption"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:table)"
-            "table must not occur among the children or descendants of caption"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:caption"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:equation)"
-            "equation must not occur among the children or descendants of caption"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:caption"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:sidebar)"
-            "sidebar must not occur among the children or descendants of caption"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:caption"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:task)"
-            "task must not occur among the children or descendants of caption"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:caption"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:caution)"
-            "caution must not occur among the children or descendants of caption"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:caption"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:important)"
-            "important must not occur among the children or descendants of caption"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:caption"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:note)"
-            "note must not occur among the children or descendants of caption"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:caption"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:tip)"
-            "tip must not occur among the children or descendants of caption"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:caption"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:warning)"
-            "warning must not occur among the children or descendants of caption"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:caption"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element caption {
-      db.caption.attlist, db.caption.info, db.all.blocks+
-    }
-}
-div {
-  db.address.role.attribute = attribute role { text }
-  db.address.attlist =
-    db.address.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.verbatim.attributes
-  db.address =
-    
-    ## A real-world address, generally a postal address
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:address"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element address {
-      db.address.attlist,
-      (db._text
-       | db.personname
-       | db.orgname
-       | db.pob
-       | db.street
-       | db.city
-       | db.state
-       | db.postcode
-       | db.country
-       | db.phone
-       | db.fax
-       | db.email
-       | db.uri
-       | db.otheraddr)*
-    }
-}
-div {
-  db.street.role.attribute = attribute role { text }
-  db.street.attlist =
-    db.street.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.street =
-    
-    ## A street address in an address
-    element street { db.street.attlist, db._text }
-}
-div {
-  db.pob.role.attribute = attribute role { text }
-  db.pob.attlist =
-    db.pob.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.pob =
-    
-    ## A post office box in an address
-    element pob { db.pob.attlist, db._text }
-}
-div {
-  db.postcode.role.attribute = attribute role { text }
-  db.postcode.attlist =
-    db.postcode.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.postcode =
-    
-    ## A postal code in an address
-    element postcode { db.postcode.attlist, db._text }
-}
-div {
-  db.city.role.attribute = attribute role { text }
-  db.city.attlist =
-    db.city.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.city =
-    
-    ## The name of a city in an address
-    element city { db.city.attlist, db._text }
-}
-div {
-  db.state.role.attribute = attribute role { text }
-  db.state.attlist =
-    db.state.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.state =
-    
-    ## A state or province in an address
-    element state { db.state.attlist, db._text }
-}
-div {
-  db.country.role.attribute = attribute role { text }
-  db.country.attlist =
-    db.country.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.country =
-    
-    ## The name of a country
-    element country { db.country.attlist, db._text }
-}
-div {
-  db.phone.role.attribute = attribute role { text }
-  db.phone.attlist =
-    db.phone.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.phone =
-    
-    ## A telephone number
-    element phone { db.phone.attlist, db._text }
-}
-div {
-  db.fax.role.attribute = attribute role { text }
-  db.fax.attlist =
-    db.fax.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.fax =
-    
-    ## A fax number
-    element fax { db.fax.attlist, db._text }
-}
-div {
-  db.otheraddr.role.attribute = attribute role { text }
-  db.otheraddr.attlist =
-    db.otheraddr.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.otheraddr =
-    
-    ## Uncategorized information in address
-    element otheraddr { db.otheraddr.attlist, db._text }
-}
-div {
-  db.affiliation.role.attribute = attribute role { text }
-  db.affiliation.attlist =
-    db.affiliation.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.affiliation =
-    
-    ## The institutional affiliation of an individual
-    element affiliation {
-      db.affiliation.attlist,
-      db.shortaffil?,
-      db.jobtitle*,
-      (db.org? | (db.orgname?, db.orgdiv*, db.address*))
-    }
-}
-div {
-  db.shortaffil.role.attribute = attribute role { text }
-  db.shortaffil.attlist =
-    db.shortaffil.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.shortaffil =
-    
-    ## A brief description of an affiliation
-    element shortaffil { db.shortaffil.attlist, db._text }
-}
-div {
-  db.jobtitle.role.attribute = attribute role { text }
-  db.jobtitle.attlist =
-    db.jobtitle.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.jobtitle =
-    
-    ## The title of an individual in an organization
-    element jobtitle { db.jobtitle.attlist, db._text }
-}
-div {
-  db.orgname.class.enumeration =
-    
-    ## A consortium
-    "consortium"
-    | 
-      ## A corporation
-      "corporation"
-    | 
-      ## An informal organization
-      "informal"
-    | 
-      ## A non-profit organization
-      "nonprofit"
-  db.orgname.class-enum.attribute =
-    
-    ## Specifies the nature of the organization
-    attribute class { db.orgname.class.enumeration }
-  db.orgname.class-other.attributes =
-    
-    ## Specifies the nature of the organization
-    attribute class {
-      
-      ## Indicates a non-standard organization class
-      "other"
-    },
-    
-    ## Identifies the non-standard nature of the organization
-    attribute otherclass { text }
-  db.orgname.class.attribute =
-    db.orgname.class-enum.attribute | db.orgname.class-other.attributes
-  db.orgname.role.attribute = attribute role { text }
-  db.orgname.attlist =
-    db.orgname.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.orgname.class.attribute?
-  db.orgname =
-    
-    ## The name of an organization
-    element orgname { db.orgname.attlist, db._text }
-}
-div {
-  db.orgdiv.role.attribute = attribute role { text }
-  db.orgdiv.attlist =
-    db.orgdiv.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.orgdiv =
-    
-    ## A division of an organization
-    element orgdiv { db.orgdiv.attlist, db.all.inlines* }
-}
-div {
-  db.artpagenums.role.attribute = attribute role { text }
-  db.artpagenums.attlist =
-    db.artpagenums.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.artpagenums =
-    
-    ## The page numbers of an article as published
-    element artpagenums { db.artpagenums.attlist, db._text }
-}
-div {
-  db.personname.role.attribute = attribute role { text }
-  db.personname.attlist =
-    db.personname.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.personname =
-    
-    ## The personal name of an individual
-    element personname {
-      db.personname.attlist,
-      (db._text
-       | (db.honorific
-          | db.firstname
-          | db.surname
-          | db.lineage
-          | db.othername)+
-       | (db.honorific
-          | db.givenname
-          | db.surname
-          | db.lineage
-          | db.othername)+)
-    }
-}
-db.person.author.contentmodel =
-  db.personname,
-  (db.personblurb
-   | db.affiliation
-   | db.email
-   | db.uri
-   | db.address
-   | db.contrib)*
-db.org.author.contentmodel =
-  db.orgname,
-  (db.orgdiv
-   | db.affiliation
-   | db.email
-   | db.uri
-   | db.address
-   | db.contrib)*
-db.credit.contentmodel =
-  db.person.author.contentmodel | db.org.author.contentmodel
-div {
-  db.author.role.attribute = attribute role { text }
-  db.author.attlist =
-    db.author.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.author =
-    
-    ## The name of an individual author
-    element author { db.author.attlist, db.credit.contentmodel }
-}
-div {
-  db.authorgroup.role.attribute = attribute role { text }
-  db.authorgroup.attlist =
-    db.authorgroup.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.authorgroup =
-    
-    ## Wrapper for author information when a document has multiple authors or collaborators
-    element authorgroup {
-      db.authorgroup.attlist, (db.author | db.editor | db.othercredit)+
-    }
-}
-div {
-  db.collab.role.attribute = attribute role { text }
-  db.collab.attlist =
-    db.collab.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.collab =
-    
-    ## Identifies a collaborator
-    element collab {
-      db.collab.attlist,
-      (db.person | db.personname | db.org | db.orgname)+,
-      db.affiliation*
-    }
-}
-div {
-  db.authorinitials.role.attribute = attribute role { text }
-  db.authorinitials.attlist =
-    db.authorinitials.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.authorinitials =
-    
-    ## The initials or other short identifier for an author
-    element authorinitials { db.authorinitials.attlist, db._text }
-}
-div {
-  db.person.role.attribute = attribute role { text }
-  db.person.attlist =
-    db.person.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.person =
-    
-    ## A person and associated metadata
-    element person {
-      db.person.attlist,
-      db.personname,
-      (db.address
-       | db.affiliation
-       | db.email
-       | db.uri
-       | db.personblurb)*
-    }
-}
-div {
-  db.org.role.attribute = attribute role { text }
-  db.org.attlist =
-    db.org.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.org =
-    
-    ## An organization and associated metadata
-    element org {
-      db.org.attlist,
-      db.orgname,
-      (db.address | db.affiliation | db.email | db.uri | db.orgdiv)*
-    }
-}
-div {
-  db.confgroup.role.attribute = attribute role { text }
-  db.confgroup.attlist =
-    db.confgroup.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.confgroup =
-    
-    ## A wrapper for document meta-information about a conference
-    element confgroup {
-      db.confgroup.attlist,
-      (db.confdates
-       | db.conftitle
-       | db.confnum
-       | db.confsponsor
-       | db.address)*
-    }
-}
-div {
-  db.confdates.role.attribute = attribute role { text }
-  db.confdates.attlist =
-    db.confdates.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.confdates =
-    
-    ## The dates of a conference for which a document was written
-    element confdates { db.confdates.attlist, db._text }
-}
-div {
-  db.conftitle.role.attribute = attribute role { text }
-  db.conftitle.attlist =
-    db.conftitle.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.conftitle =
-    
-    ## The title of a conference for which a document was written
-    element conftitle { db.conftitle.attlist, db._text }
-}
-div {
-  db.confnum.role.attribute = attribute role { text }
-  db.confnum.attlist =
-    db.confnum.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.confnum =
-    
-    ## An identifier, frequently numerical, associated with a conference for which a document was written
-    element confnum { db.confnum.attlist, db._text }
-}
-div {
-  db.confsponsor.role.attribute = attribute role { text }
-  db.confsponsor.attlist =
-    db.confsponsor.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.confsponsor =
-    
-    ## The sponsor of a conference for which a document was written
-    element confsponsor { db.confsponsor.attlist, db._text }
-}
-div {
-  db.contractnum.role.attribute = attribute role { text }
-  db.contractnum.attlist =
-    db.contractnum.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.contractnum =
-    
-    ## The contract number of a document
-    element contractnum { db.contractnum.attlist, db._text }
-}
-div {
-  db.contractsponsor.role.attribute = attribute role { text }
-  db.contractsponsor.attlist =
-    db.contractsponsor.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.contractsponsor =
-    
-    ## The sponsor of a contract
-    element contractsponsor { db.contractsponsor.attlist, db._text }
-}
-div {
-  db.copyright.role.attribute = attribute role { text }
-  db.copyright.attlist =
-    db.copyright.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.copyright =
-    
-    ## Copyright information about a document
-    element copyright { db.copyright.attlist, db.year+, db.holder* }
-}
-div {
-  db.year.role.attribute = attribute role { text }
-  db.year.attlist =
-    db.year.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.year =
-    
-    ## The year of publication of a document
-    element year { db.year.attlist, db._text }
-}
-div {
-  db.holder.role.attribute = attribute role { text }
-  db.holder.attlist =
-    db.holder.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.holder =
-    
-    ## The name of the individual or organization that holds a copyright
-    element holder { db.holder.attlist, db._text }
-}
-db.cover.contentmodel =
-  (db.para.blocks
-   | db.extension.blocks
-   | db.list.blocks
-   | db.informal.blocks
-   | db.publishing.blocks
-   | db.graphic.blocks
-   | db.technical.blocks
-   | db.verbatim.blocks
-   | db.bridgehead
-   | db.remark
-   | db.revhistory)
-  | db.synopsis.blocks
-div {
-  db.cover.role.attribute = attribute role { text }
-  db.cover.attlist =
-    db.cover.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.cover =
-    
-    ## Additional content for the cover of a publication
-    element cover { db.cover.attlist, db.cover.contentmodel+ }
-}
-db.date.contentmodel =
-  xsd:date | xsd:dateTime | xsd:gYearMonth | xsd:gYear | text
-div {
-  db.date.role.attribute = attribute role { text }
-  db.date.attlist =
-    db.date.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.date =
-    
-    ## The date of publication or revision of a document
-    element date { db.date.attlist, db.date.contentmodel }
-}
-div {
-  db.edition.role.attribute = attribute role { text }
-  db.edition.attlist =
-    db.edition.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.edition =
-    
-    ## The name or number of an edition of a document
-    element edition { db.edition.attlist, db._text }
-}
-div {
-  db.editor.role.attribute = attribute role { text }
-  db.editor.attlist =
-    db.editor.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.editor =
-    
-    ## The name of the editor of a document
-    element editor { db.editor.attlist, db.credit.contentmodel }
-}
-div {
-  db.biblioid.role.attribute = attribute role { text }
-  db.biblioid.attlist =
-    db.biblioid.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.biblio.class.attribute
-  db.biblioid =
-    
-    ## An identifier for a document
-    element biblioid { db.biblioid.attlist, db._text }
-}
-div {
-  db.citebiblioid.role.attribute = attribute role { text }
-  db.citebiblioid.attlist =
-    db.citebiblioid.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.biblio.class.attribute
-  db.citebiblioid =
-    
-    ## A citation of a bibliographic identifier
-    element citebiblioid { db.citebiblioid.attlist, db._text }
-}
-div {
-  db.bibliosource.role.attribute = attribute role { text }
-  db.bibliosource.attlist =
-    db.bibliosource.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.biblio.class.attribute
-  db.bibliosource =
-    
-    ## The source of a document
-    element bibliosource { db.bibliosource.attlist, db._text }
-}
-div {
-  db.bibliorelation.type.enumeration =
-    
-    ## The described resource pre-existed the referenced resource, which is essentially the same intellectual content presented in another format
-    "hasformat"
-    | 
-      ## The described resource includes the referenced resource either physically or logically
-      "haspart"
-    | 
-      ## The described resource has a version, edition, or adaptation, namely, the referenced resource
-      "hasversion"
-    | 
-      ## The described resource is the same intellectual content of the referenced resource, but presented in another format
-      "isformatof"
-    | 
-      ## The described resource is a physical or logical part of the referenced resource
-      "ispartof"
-    | 
-      ## The described resource is referenced, cited, or otherwise pointed to by the referenced resource
-      "isreferencedby"
-    | 
-      ## The described resource is supplanted, displaced, or superceded by the referenced resource
-      "isreplacedby"
-    | 
-      ## The described resource is required by the referenced resource, either physically or logically
-      "isrequiredby"
-    | 
-      ## The described resource is a version, edition, or adaptation of the referenced resource; changes in version imply substantive changes in content rather than differences in format
-      "isversionof"
-    | 
-      ## The described resource references, cites, or otherwise points to the referenced resource
-      "references"
-    | 
-      ## The described resource supplants, displaces, or supersedes the referenced resource
-      "replaces"
-    | 
-      ## The described resource requires the referenced resource to support its function, delivery, or coherence of content
-      "requires"
-  db.bibliorelation.type-enum.attribute =
-    
-    ## Identifies the type of relationship
-    attribute type { db.bibliorelation.type.enumeration }?
-  db.bibliorelation.type-other.attributes =
-    
-    ## Identifies the type of relationship
-    attribute type {
-      
-      ## The described resource has a non-standard relationship with the referenced resource
-      "othertype"
-    }?,
-    
-    ## A keyword that identififes the type of the non-standard relationship
-    attribute othertype { xsd:NMTOKEN }
-  db.bibliorelation.type.attribute =
-    db.bibliorelation.type-enum.attribute
-    | db.bibliorelation.type-other.attributes
-  db.bibliorelation.role.attribute = attribute role { text }
-  db.bibliorelation.attlist =
-    db.bibliorelation.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.biblio.class.attribute
-    & db.bibliorelation.type.attribute
-  db.bibliorelation =
-    
-    ## The relationship of a document to another
-    element bibliorelation { db.bibliorelation.attlist, db._text }
-}
-div {
-  db.bibliocoverage.spacial.enumeration =
-    
-    ## The DCMI Point identifies a point in space using its geographic coordinates
-    "dcmipoint"
-    | 
-      ## ISO 3166 Codes for the representation of names of countries
-      "iso3166"
-    | 
-      ## The DCMI Box identifies a region of space using its geographic limits
-      "dcmibox"
-    | 
-      ## The Getty Thesaurus of Geographic Names
-      "tgn"
-  db.bibliocoverage.spatial-enum.attribute =
-    
-    ## Specifies the type of spatial coverage
-    attribute spatial { db.bibliocoverage.spacial.enumeration }?
-  db.bibliocoverage.spatial-other.attributes =
-    
-    ## Specifies the type of spatial coverage
-    attribute spatial {
-      
-      ## Identifies a non-standard type of coverage
-      "otherspatial"
-    }?,
-    
-    ## A keyword that identifies the type of non-standard coverage
-    attribute otherspatial { xsd:NMTOKEN }
-  db.bibliocoverage.spatial.attribute =
-    db.bibliocoverage.spatial-enum.attribute
-    | db.bibliocoverage.spatial-other.attributes
-  db.bibliocoverage.temporal.enumeration =
-    
-    ## A specification of the limits of a time interval
-    "dcmiperiod"
-    | 
-      ## W3C Encoding rules for dates and times—a profile based on ISO 8601
-      "w3c-dtf"
-  db.bibliocoverage.temporal-enum.attribute =
-    
-    ## Specifies the type of temporal coverage
-    attribute temporal { db.bibliocoverage.temporal.enumeration }?
-  db.bibliocoverage.temporal-other.attributes =
-    
-    ## Specifies the type of temporal coverage
-    attribute temporal {
-      
-      ## Specifies a non-standard type of coverage
-      "othertemporal"
-    }?,
-    
-    ## A keyword that identifies the type of non-standard coverage
-    attribute othertemporal { xsd:NMTOKEN }
-  db.bibliocoverage.temporal.attribute =
-    db.bibliocoverage.temporal-enum.attribute
-    | db.bibliocoverage.temporal-other.attributes
-  db.bibliocoverage.coverage.attrib =
-    db.bibliocoverage.spatial.attribute
-    & db.bibliocoverage.temporal.attribute
-  db.bibliocoverage.role.attribute = attribute role { text }
-  db.bibliocoverage.attlist =
-    db.bibliocoverage.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.bibliocoverage.coverage.attrib
-  db.bibliocoverage =
-    
-    ## The spatial or temporal coverage of a document
-    element bibliocoverage { db.bibliocoverage.attlist, db._text }
-}
-div {
-  db.legalnotice.role.attribute = attribute role { text }
-  db.legalnotice.attlist =
-    db.legalnotice.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.legalnotice.info = db._info.title.only
-  db.legalnotice =
-    
-    ## A statement of legal obligations or requirements
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:legalnotice"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element legalnotice {
-      db.legalnotice.attlist, db.legalnotice.info, db.all.blocks+
-    }
-}
-div {
-  db.othercredit.class.enumeration =
-    
-    ## A copy editor
-    "copyeditor"
-    | 
-      ## A graphic designer
-      "graphicdesigner"
-    | 
-      ## Some other contributor
-      "other"
-    | 
-      ## A production editor
-      "productioneditor"
-    | 
-      ## A technical editor
-      "technicaleditor"
-    | 
-      ## A translator
-      "translator"
-    | 
-      ## An indexer
-      "indexer"
-    | 
-      ## A proof-reader
-      "proofreader"
-    | 
-      ## A cover designer
-      "coverdesigner"
-    | 
-      ## An interior designer
-      "interiordesigner"
-    | 
-      ## An illustrator
-      "illustrator"
-    | 
-      ## A reviewer
-      "reviewer"
-    | 
-      ## A typesetter
-      "typesetter"
-    | 
-      ## A converter (a persons responsible for conversion, not an application)
-      "conversion"
-  db.othercredit.class-enum.attribute =
-    
-    ## Identifies the nature of the contributor
-    attribute class { db.othercredit.class.enumeration }?
-  db.othercredit.class-other.attribute =
-    
-    ## Identifies the nature of the non-standard contribution
-    attribute otherclass { xsd:NMTOKEN }
-  db.othercredit.class-other.attributes =
-    
-    ## Identifies the nature of the contributor
-    attribute class {
-      
-      ## Identifies a non-standard contribution
-      "other"
-    }
-    & db.othercredit.class-other.attribute
-  db.othercredit.class.attribute =
-    db.othercredit.class-enum.attribute
-    | db.othercredit.class-other.attributes
-  db.othercredit.role.attribute = attribute role { text }
-  db.othercredit.attlist =
-    db.othercredit.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.othercredit.class.attribute
-  db.othercredit =
-    
-    ## A person or entity, other than an author or editor, credited in a document
-    element othercredit {
-      db.othercredit.attlist, db.credit.contentmodel
-    }
-}
-div {
-  db.pagenums.role.attribute = attribute role { text }
-  db.pagenums.attlist =
-    db.pagenums.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.pagenums =
-    
-    ## The numbers of the pages in a book, for use in a bibliographic entry
-    element pagenums { db.pagenums.attlist, db._text }
-}
-div {
-  db.contrib.role.attribute = attribute role { text }
-  db.contrib.attlist =
-    db.contrib.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.contrib =
-    
-    ## A summary of the contributions made to a document by a credited source
-    element contrib { db.contrib.attlist, db.all.inlines* }
-}
-div {
-  db.honorific.role.attribute = attribute role { text }
-  db.honorific.attlist =
-    db.honorific.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.honorific =
-    
-    ## The title of a person
-    element honorific { db.honorific.attlist, db._text }
-}
-div {
-  db.firstname.role.attribute = attribute role { text }
-  db.firstname.attlist =
-    db.firstname.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.firstname =
-    
-    ## A given name of a person
-    element firstname { db.firstname.attlist, db._text }
-}
-div {
-  db.givenname.role.attribute = attribute role { text }
-  db.givenname.attlist =
-    db.givenname.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.givenname =
-    
-    ## The given name of a person
-    element givenname { db.givenname.attlist, db._text }
-}
-div {
-  db.surname.role.attribute = attribute role { text }
-  db.surname.attlist =
-    db.surname.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.surname =
-    
-    ## An inherited or family name; in western cultures the last name
-    element surname { db.surname.attlist, db._text }
-}
-div {
-  db.lineage.role.attribute = attribute role { text }
-  db.lineage.attlist =
-    db.lineage.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.lineage =
-    
-    ## The portion of a person's name indicating a relationship to ancestors
-    element lineage { db.lineage.attlist, db._text }
-}
-div {
-  db.othername.role.attribute = attribute role { text }
-  db.othername.attlist =
-    db.othername.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.othername =
-    
-    ## A component of a person's name that is not a first name, surname, or lineage
-    element othername { db.othername.attlist, db._text }
-}
-div {
-  db.printhistory.role.attribute = attribute role { text }
-  db.printhistory.attlist =
-    db.printhistory.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.printhistory =
-    
-    ## The printing history of a document
-    element printhistory { db.printhistory.attlist, db.para.blocks+ }
-}
-div {
-  db.pubdate.role.attribute = attribute role { text }
-  db.pubdate.attlist =
-    db.pubdate.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.pubdate =
-    
-    ## The date of publication of a document
-    element pubdate { db.pubdate.attlist, db.date.contentmodel }
-}
-div {
-  db.publisher.role.attribute = attribute role { text }
-  db.publisher.attlist =
-    db.publisher.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.publisher =
-    
-    ## The publisher of a document
-    element publisher {
-      db.publisher.attlist, db.publishername, db.address*
-    }
-}
-div {
-  db.publishername.role.attribute = attribute role { text }
-  db.publishername.attlist =
-    db.publishername.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.publishername =
-    
-    ## The name of the publisher of a document
-    element publishername { db.publishername.attlist, db._text }
-}
-div {
-  db.releaseinfo.role.attribute = attribute role { text }
-  db.releaseinfo.attlist =
-    db.releaseinfo.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.releaseinfo =
-    
-    ## Information about a particular release of a document
-    element releaseinfo { db.releaseinfo.attlist, db._text }
-}
-div {
-  db.revhistory.role.attribute = attribute role { text }
-  db.revhistory.attlist =
-    db.revhistory.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.revhistory.info = db._info.title.only
-  db.revhistory =
-    
-    ## A history of the revisions to a document
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:revhistory"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element revhistory {
-      db.revhistory.attlist, db.revhistory.info, db.revision+
-    }
-}
-div {
-  db.revision.role.attribute = attribute role { text }
-  db.revision.attlist =
-    db.revision.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.revision =
-    
-    ## An entry describing a single revision in the history of the revisions to a document
-    element revision {
-      db.revision.attlist,
-      db.revnumber?,
-      db.date,
-      (db.authorinitials | db.author)*,
-      (db.revremark | db.revdescription)?
-    }
-}
-div {
-  db.revnumber.role.attribute = attribute role { text }
-  db.revnumber.attlist =
-    db.revnumber.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.revnumber =
-    
-    ## A document revision number
-    element revnumber { db.revnumber.attlist, db._text }
-}
-div {
-  db.revremark.role.attribute = attribute role { text }
-  db.revremark.attlist =
-    db.revremark.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.revremark =
-    
-    ## A description of a revision to a document
-    element revremark { db.revremark.attlist, db._text }
-}
-div {
-  db.revdescription.role.attribute = attribute role { text }
-  db.revdescription.attlist =
-    db.revdescription.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.revdescription =
-    
-    ## A extended description of a revision to a document
-    element revdescription { db.revdescription.attlist, db.all.blocks* }
-}
-div {
-  db.seriesvolnums.role.attribute = attribute role { text }
-  db.seriesvolnums.attlist =
-    db.seriesvolnums.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.seriesvolnums =
-    
-    ## Numbers of the volumes in a series of books
-    element seriesvolnums { db.seriesvolnums.attlist, db._text }
-}
-div {
-  db.volumenum.role.attribute = attribute role { text }
-  db.volumenum.attlist =
-    db.volumenum.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.volumenum =
-    
-    ## The volume number of a document in a set (as of books in a set or articles in a journal)
-    element volumenum { db.volumenum.attlist, db._text }
-}
-div {
-  db.issuenum.role.attribute = attribute role { text }
-  db.issuenum.attlist =
-    db.issuenum.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.issuenum =
-    
-    ## The number of an issue of a journal
-    element issuenum { db.issuenum.attlist, db._text }
-}
-div {
-  db.package.role.attribute = attribute role { text }
-  db.package.attlist =
-    db.package.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.package =
-    
-    ## A software or application package
-    element package { db.package.attlist, db._text }
-}
-div {
-  db.email.role.attribute = attribute role { text }
-  db.email.attlist =
-    db.email.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.email =
-    
-    ## An email address
-    element email { db.email.attlist, db._text }
-}
-div {
-  db.lineannotation.role.attribute = attribute role { text }
-  db.lineannotation.attlist =
-    db.lineannotation.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.lineannotation =
-    
-    ## A comment on a line in a verbatim listing
-    element lineannotation { db.lineannotation.attlist, db._text }
-}
-div {
-  db.parameter.class.enumeration =
-    
-    ## A command
-    "command"
-    | 
-      ## A function
-      "function"
-    | 
-      ## An option
-      "option"
-  db.parameter.class.attribute =
-    
-    ## Identifies the class of parameter
-    attribute class { db.parameter.class.enumeration }
-  db.parameter.role.attribute = attribute role { text }
-  db.parameter.attlist =
-    db.parameter.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.parameter.class.attribute?
-  db.parameter =
-    
-    ## A value or a symbolic reference to a value
-    element parameter { db.parameter.attlist, db._text }
-}
-db.replaceable.inlines = db._text | db.co
-div {
-  db.replaceable.class.enumeration =
-    
-    ## A command
-    "command"
-    | 
-      ## A function
-      "function"
-    | 
-      ## An option
-      "option"
-    | 
-      ## A parameter
-      "parameter"
-  db.replaceable.class.attribute =
-    
-    ## Identifies the nature of the replaceable text
-    attribute class { db.replaceable.class.enumeration }
-  db.replaceable.role.attribute = attribute role { text }
-  db.replaceable.attlist =
-    db.replaceable.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.replaceable.class.attribute?
-  db.replaceable =
-    
-    ## Content that may or must be replaced by the user
-    element replaceable {
-      db.replaceable.attlist, db.replaceable.inlines*
-    }
-}
-div {
-  db.uri.type.attribute =
-    
-    ## Identifies the type of URI specified
-    attribute type { text }?
-  db.uri.role.attribute = attribute role { text }
-  db.uri.attlist =
-    db.uri.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.uri.type.attribute
-  db.uri =
-    
-    ## A Uniform Resource Identifier
-    element uri { db.uri.attlist, db._text }
-}
-div {
-  db.abbrev.role.attribute = attribute role { text }
-  db.abbrev.attlist =
-    db.abbrev.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.abbrev =
-    
-    ## An abbreviation, especially one followed by a period
-    element abbrev {
-      db.abbrev.attlist,
-      (db._text | db.superscript | db.subscript | db.trademark)*
-    }
-}
-div {
-  db.acronym.role.attribute = attribute role { text }
-  db.acronym.attlist =
-    db.acronym.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.acronym =
-    
-    ## An often pronounceable word made from the initial (or selected) letters of a name or phrase
-    element acronym {
-      db.acronym.attlist,
-      (db._text | db.superscript | db.subscript | db.trademark)*
-    }
-}
-div {
-  db.citation.role.attribute = attribute role { text }
-  db.citation.attlist =
-    db.citation.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.citation =
-    
-    ## An inline bibliographic reference to another published work
-    element citation { db.citation.attlist, db.all.inlines* }
-}
-div {
-  db.citerefentry.role.attribute = attribute role { text }
-  db.citerefentry.attlist =
-    db.citerefentry.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.citerefentry =
-    
-    ## A citation to a reference page
-    element citerefentry {
-      db.citerefentry.attlist, db.refentrytitle, db.manvolnum?
-    }
-}
-div {
-  db.refentrytitle.role.attribute = attribute role { text }
-  db.refentrytitle.attlist =
-    db.refentrytitle.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.refentrytitle =
-    
-    ## The title of a reference page
-    element refentrytitle { db.refentrytitle.attlist, db.all.inlines* }
-}
-div {
-  db.manvolnum.role.attribute = attribute role { text }
-  db.manvolnum.attlist =
-    db.manvolnum.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.manvolnum =
-    
-    ## A reference volume number
-    element manvolnum { db.manvolnum.attlist, db._text }
-}
-div {
-  db.citetitle.pubwork.enumeration =
-    
-    ## An article
-    "article"
-    | 
-      ## A bulletin board system
-      "bbs"
-    | 
-      ## A book
-      "book"
-    | 
-      ## A CD-ROM
-      "cdrom"
-    | 
-      ## A chapter (as of a book)
-      "chapter"
-    | 
-      ## A DVD
-      "dvd"
-    | 
-      ## An email message
-      "emailmessage"
-    | 
-      ## A gopher page
-      "gopher"
-    | 
-      ## A journal
-      "journal"
-    | 
-      ## A manuscript
-      "manuscript"
-    | 
-      ## A posting to a newsgroup
-      "newsposting"
-    | 
-      ## A part (as of a book)
-      "part"
-    | 
-      ## A reference entry
-      "refentry"
-    | 
-      ## A section (as of a book or article)
-      "section"
-    | 
-      ## A series
-      "series"
-    | 
-      ## A set (as of books)
-      "set"
-    | 
-      ## A web page
-      "webpage"
-    | 
-      ## A wiki page
-      "wiki"
-  db.citetitle.pubwork.attribute =
-    
-    ## Identifies the nature of the publication being cited
-    attribute pubwork { db.citetitle.pubwork.enumeration }
-  db.citetitle.role.attribute = attribute role { text }
-  db.citetitle.attlist =
-    db.citetitle.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.citetitle.pubwork.attribute?
-  db.citetitle =
-    
-    ## The title of a cited work
-    element citetitle { db.citetitle.attlist, db.all.inlines* }
-}
-div {
-  db.emphasis.role.attribute = attribute role { text }
-  db.emphasis.attlist =
-    db.emphasis.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.emphasis =
-    
-    ## Emphasized text
-    element emphasis { db.emphasis.attlist, db.all.inlines* }
-}
-div {
-  db._emphasis =
-    
-    ## A limited span of emphasized text
-    element emphasis { db.emphasis.attlist, db._text }
-}
-div {
-  db.foreignphrase.role.attribute = attribute role { text }
-  db.foreignphrase.attlist =
-    db.foreignphrase.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.foreignphrase =
-    
-    ## A word or phrase in a language other than the primary language of the document
-    element foreignphrase {
-      db.foreignphrase.attlist, (text | db.general.inlines)*
-    }
-}
-div {
-  db._foreignphrase.role.attribute = attribute role { text }
-  db._foreignphrase.attlist =
-    db._foreignphrase.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db._foreignphrase =
-    
-    ## A limited word or phrase in a language other than the primary language of the document
-    element foreignphrase { db._foreignphrase.attlist, db._text }
-}
-div {
-  db.phrase.role.attribute = attribute role { text }
-  db.phrase.attlist =
-    db.phrase.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.phrase =
-    
-    ## A span of text
-    element phrase { db.phrase.attlist, db.all.inlines* }
-}
-div {
-  db._phrase =
-    
-    ## A limited span of text
-    element phrase { db.phrase.attlist, db._text }
-}
-div {
-  db.quote.role.attribute = attribute role { text }
-  db.quote.attlist =
-    db.quote.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.quote =
-    
-    ## An inline quotation
-    element quote { db.quote.attlist, db.all.inlines* }
-}
-div {
-  db._quote.role.attribute = attribute role { text }
-  db._quote.attlist =
-    db._quote.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db._quote =
-    
-    ## A limited inline quotation
-    element quote { db._quote.attlist, db._text }
-}
-div {
-  db.subscript.role.attribute = attribute role { text }
-  db.subscript.attlist =
-    db.subscript.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.subscript =
-    
-    ## A subscript (as in H2
-    ## O, the molecular formula for water)
-    element subscript { db.subscript.attlist, db._text }
-}
-div {
-  db.superscript.role.attribute = attribute role { text }
-  db.superscript.attlist =
-    db.superscript.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.superscript =
-    
-    ## A superscript (as in x2
-    ## , the mathematical notation for x multiplied by itself)
-    element superscript { db.superscript.attlist, db._text }
-}
-div {
-  db.trademark.class.enumeration =
-    
-    ## A copyright
-    "copyright"
-    | 
-      ## A registered copyright
-      "registered"
-    | 
-      ## A service
-      "service"
-    | 
-      ## A trademark
-      "trade"
-  db.trademark.class.attribute =
-    
-    ## Identifies the class of trade mark
-    attribute class { db.trademark.class.enumeration }
-  db.trademark.role.attribute = attribute role { text }
-  db.trademark.attlist =
-    db.trademark.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.trademark.class.attribute?
-  db.trademark =
-    
-    ## A trademark
-    element trademark { db.trademark.attlist, db._text }
-}
-div {
-  db.wordasword.role.attribute = attribute role { text }
-  db.wordasword.attlist =
-    db.wordasword.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.wordasword =
-    
-    ## A word meant specifically as a word and not representing anything else
-    element wordasword { db.wordasword.attlist, db._text }
-}
-div {
-  db.footnoteref.role.attribute = attribute role { text }
-  db.footnoteref.label.attribute = db.label.attribute
-  db.footnoteref.attlist =
-    db.footnoteref.role.attribute?
-    & db.common.attributes
-    & db.linkend.attribute
-    & db.footnoteref.label.attribute?
-  db.footnoteref =
-    
-    ## A cross reference to a footnote (a footnote mark)
-    [
-      s:pattern [
-        name = "Footnote reference type constraint"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:footnoteref"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test =
-              "local-name(//*[@xml:id=current()/@linkend]) = 'footnote' and namespace-uri(//*[@xml:id=current()/@linkend]) = 'http://docbook.org/ns/docbook'"
-            "@linkend on footnoteref must point to a footnote."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element footnoteref { db.footnoteref.attlist, empty }
-}
-div {
-  db.xref.role.attribute = attribute role { text }
-  db.xref.xrefstyle.attribute = db.xrefstyle.attribute
-  db.xref.endterm.attribute = db.endterm.attribute
-  db.xref.attlist =
-    db.xref.role.attribute?
-    & db.common.attributes
-    & db.common.req.linking.attributes
-    & db.xref.xrefstyle.attribute?
-    & db.xref.endterm.attribute?
-  db.xref =
-    
-    ## A cross reference to another part of the document
-    element xref { db.xref.attlist, empty }
-}
-div {
-  db.link.role.attribute = attribute role { text }
-  db.link.xrefstyle.attribute = db.xrefstyle.attribute
-  db.link.endterm.attribute = db.endterm.attribute
-  db.link.attlist =
-    db.link.role.attribute?
-    & db.common.attributes
-    & db.common.req.linking.attributes
-    & db.link.xrefstyle.attribute?
-    & db.link.endterm.attribute?
-  db.link =
-    
-    ## A hypertext link
-    element link { db.link.attlist, db.all.inlines* }
-}
-div {
-  db.olink.role.attribute = attribute role { text }
-  db.olink.xrefstyle.attribute = db.xrefstyle.attribute
-  db.olink.localinfo.attribute =
-    
-    ## Holds additional information that may be used by the application when resolving the link
-    attribute localinfo { text }
-  db.olink.targetdoc.attribute =
-    
-    ## Specifies the URI of the document in which the link target appears
-    attribute targetdoc { xsd:anyURI }
-  db.olink.targetptr.attribute =
-    
-    ## Specifies the location of the link target in the document
-    attribute targetptr { text }
-  db.olink.type.attribute =
-    
-    ## Identifies application-specific customization of the link behavior
-    attribute type { text }
-  db.olink.attlist =
-    db.common.attributes
-    & db.olink.targetdoc.attribute?
-    & db.olink.role.attribute?
-    & db.olink.xrefstyle.attribute?
-    & db.olink.localinfo.attribute?
-    & db.olink.targetptr.attribute?
-    & db.olink.type.attribute?
-  db.olink =
-    
-    ## A link that addresses its target indirectly
-    element olink { db.olink.attlist, db.all.inlines* }
-}
-div {
-  db.anchor.role.attribute = attribute role { text }
-  db.anchor.attlist =
-    db.anchor.role.attribute? & db.common.idreq.attributes
-  db.anchor =
-    
-    ## A spot in the document
-    element anchor { db.anchor.attlist, empty }
-}
-div {
-  db.alt.role.attribute = attribute role { text }
-  db.alt.attlist = db.alt.role.attribute? & db.common.attributes
-  db.alt =
-    
-    ## A text-only annotation, often used for accessibility
-    element alt { db.alt.attlist, (text | db.inlinemediaobject)* }
-}
-db.status.attribute =
-  
-  ## Identifies the editorial or publication status of the element on which it occurs
-  attribute status { text }
-db.toplevel.sections =
-  ((db.section+, db.simplesect*) | db.simplesect+)
-  | (db.sect1+, db.simplesect*)
-  | db.refentry+
-db.toplevel.blocks.or.sections =
-  (db.all.blocks+, db.toplevel.sections?) | db.toplevel.sections
-db.recursive.sections =
-  ((db.section+, db.simplesect*) | db.simplesect+)
-  | db.refentry+
-db.recursive.blocks.or.sections =
-  (db.all.blocks+, db.recursive.sections?) | db.recursive.sections
-db.divisions = db.part | db.reference
-db.components =
-  db.dedication
-  | db.acknowledgements
-  | db.preface
-  | db.chapter
-  | db.appendix
-  | db.article
-  | db.colophon
-db.navigation.components =
-  notAllowed | db.glossary | db.bibliography | db.index | db.toc
-db.component.contentmodel =
-  db.navigation.components*,
-  db.toplevel.blocks.or.sections,
-  db.navigation.components*
-db.setindex.components = notAllowed | db.setindex
-db.toc.components = notAllowed | db.toc
-db.set.components = db.set | db.book
-div {
-  db.set.status.attribute = db.status.attribute
-  db.set.role.attribute = attribute role { text }
-  db.set.attlist =
-    db.set.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.label.attribute?
-    & db.set.status.attribute?
-  db.set.info = db._info.title.req
-  db.set =
-    
-    ## A collection of books
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:set"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element set {
-      db.set.attlist,
-      db.set.info,
-      db.toc.components?,
-      db.set.components+,
-      db.setindex.components?
-    }
-}
-db.book.components =
-  (db.navigation.components | db.components | db.divisions)* | db.topic*
-div {
-  db.book.status.attribute = db.status.attribute
-  db.book.role.attribute = attribute role { text }
-  db.book.attlist =
-    db.book.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.label.attribute?
-    & db.book.status.attribute?
-  db.book.info = db._info
-  db.book =
-    
-    ## A book
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:book"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element book { db.book.attlist, db.book.info, db.book.components }
-}
-div {
-  db.dedication.status.attribute = db.status.attribute
-  db.dedication.role.attribute = attribute role { text }
-  db.dedication.attlist =
-    db.dedication.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.label.attribute?
-    & db.dedication.status.attribute?
-  db.dedication.info = db._info
-  db.dedication =
-    
-    ## The dedication of a book or other component
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:dedication"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element dedication {
-      db.dedication.attlist, db.dedication.info, db.all.blocks+
-    }
-}
-div {
-  db.acknowledgements.status.attribute = db.status.attribute
-  db.acknowledgements.role.attribute = attribute role { text }
-  db.acknowledgements.attlist =
-    db.acknowledgements.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.label.attribute?
-    & db.acknowledgements.status.attribute?
-  db.acknowledgements.info = db._info
-  db.acknowledgements =
-    
-    ## Acknowledgements of a book or other component
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:acknowledgements"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element acknowledgements {
-      db.acknowledgements.attlist,
-      db.acknowledgements.info,
-      db.all.blocks+
-    }
-}
-div {
-  db.colophon.status.attribute = db.status.attribute
-  db.colophon.role.attribute = attribute role { text }
-  db.colophon.attlist =
-    db.colophon.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.label.attribute?
-    & db.colophon.status.attribute?
-  db.colophon.info = db._info
-  db.colophon =
-    
-    ## Text at the back of a book describing facts about its production
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:colophon"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element colophon {
-      db.colophon.attlist,
-      db.colophon.info,
-      ((db.all.blocks+, db.simplesect*)
-       | (db.all.blocks*, db.simplesect+))
-    }
-}
-db.appendix.contentmodel = db.component.contentmodel | db.topic+
-div {
-  db.appendix.status.attribute = db.status.attribute
-  db.appendix.role.attribute = attribute role { text }
-  db.appendix.attlist =
-    db.appendix.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.label.attribute?
-    & db.appendix.status.attribute?
-  db.appendix.info = db._info.title.req
-  db.appendix =
-    
-    ## An appendix in a book or article
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:appendix"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element appendix {
-      db.appendix.attlist, db.appendix.info, db.appendix.contentmodel?
-    }
-}
-db.chapter.contentmodel = db.component.contentmodel | db.topic+
-div {
-  db.chapter.status.attribute = db.status.attribute
-  db.chapter.role.attribute = attribute role { text }
-  db.chapter.attlist =
-    db.chapter.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.label.attribute?
-    & db.chapter.status.attribute?
-  db.chapter.info = db._info.title.req
-  db.chapter =
-    
-    ## A chapter, as of a book
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:chapter"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element chapter {
-      db.chapter.attlist, db.chapter.info, db.chapter.contentmodel?
-    }
-}
-db.part.components =
-  (db.navigation.components | db.components)
-  | (db.refentry | db.reference)
-db.part.contentmodel = db.part.components+ | db.topic+
-div {
-  db.part.status.attribute = db.status.attribute
-  db.part.role.attribute = attribute role { text }
-  db.part.attlist =
-    db.part.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.label.attribute?
-    & db.part.status.attribute?
-  db.part.info = db._info.title.req
-  db.part =
-    
-    ## A division in a book
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:part"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element part {
-      db.part.attlist,
-      db.part.info,
-      db.partintro?,
-      db.part.contentmodel?
-    }
-}
-div {
-  db.preface.status.attribute = db.status.attribute
-  db.preface.role.attribute = attribute role { text }
-  db.preface.attlist =
-    db.preface.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.label.attribute?
-    & db.preface.status.attribute?
-  db.preface.info = db._info.title.req
-  db.preface =
-    
-    ## Introductory matter preceding the first chapter of a book
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:preface"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element preface {
-      db.preface.attlist, db.preface.info, db.component.contentmodel?
-    }
-}
-div {
-  db.partintro.status.attribute = db.status.attribute
-  db.partintro.role.attribute = attribute role { text }
-  db.partintro.attlist =
-    db.partintro.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.label.attribute?
-    & db.partintro.status.attribute?
-  db.partintro.info = db._info
-  db.partintro =
-    
-    ## An introduction to the contents of a part
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:partintro"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element partintro {
-      db.partintro.attlist,
-      db.partintro.info,
-      db.toplevel.blocks.or.sections?
-    }
-}
-div {
-  db.section.status.attribute = db.status.attribute
-  db.section.role.attribute = attribute role { text }
-  db.section.attlist =
-    db.section.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.label.attribute?
-    & db.section.status.attribute?
-  db.section.info = db._info.title.req
-  db.section =
-    
-    ## A recursive section
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:section"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element section {
-      db.section.attlist,
-      db.section.info,
-      db.recursive.blocks.or.sections?,
-      db.navigation.components*
-    }
-}
-div {
-  db.simplesect.status.attribute = db.status.attribute
-  db.simplesect.role.attribute = attribute role { text }
-  db.simplesect.attlist =
-    db.simplesect.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.label.attribute?
-    & db.simplesect.status.attribute?
-  db.simplesect.info = db._info.title.req
-  db.simplesect =
-    
-    ## A section of a document with no subdivisions
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:simplesect"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element simplesect {
-      db.simplesect.attlist, db.simplesect.info, db.all.blocks*
-    }
-}
-db.article.components = db.toplevel.sections
-db.article.navcomponents =
-  db.navigation.components
-  | db.acknowledgements
-  | db.dedication
-  | db.appendix
-  | db.colophon
-div {
-  db.article.status.attribute = db.status.attribute
-  db.article.class.enumeration =
-    
-    ## A collection of frequently asked questions.
-    "faq"
-    | 
-      ## An article in a journal or other periodical.
-      "journalarticle"
-    | 
-      ## A description of a product.
-      "productsheet"
-    | 
-      ## A specification.
-      "specification"
-    | 
-      ## A technical report.
-      "techreport"
-    | 
-      ## A white paper.
-      "whitepaper"
-  db.article.class.attribute =
-    
-    ## Identifies the nature of the article
-    attribute class { db.article.class.enumeration }
-  db.article.role.attribute = attribute role { text }
-  db.article.attlist =
-    db.article.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.label.attribute?
-    & db.article.status.attribute?
-    & db.article.class.attribute?
-  db.article.info = db._info.title.req
-  db.article =
-    
-    ## An article
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:article"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element article {
-      db.article.attlist,
-      db.article.info,
-      db.article.navcomponents*,
-      ((db.all.blocks+, db.article.components?)
-       | db.article.components),
-      db.article.navcomponents*
-    }
-}
-db.annotations.attribute =
-  
-  ## Identifies one or more annotations that apply to this element
-  attribute annotations { text }
-div {
-  db.annotation.role.attribute = attribute role { text }
-  db.annotation.annotates.attribute =
-    
-    ## Identifies one ore more elements to which this annotation applies
-    attribute annotates { text }
-  db.annotation.attlist =
-    db.annotation.role.attribute?
-    & db.annotation.annotates.attribute?
-    & db.common.attributes
-  db.annotation.info = db._info.title.only
-  db.annotation =
-    
-    ## An annotation
-    [
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:annotation"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:annotation)"
-            "annotation must not occur among the children or descendants of annotation"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:annotation"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element annotation {
-      db.annotation.attlist, db.annotation.info, db.all.blocks+
-    }
-}
-db.xlink.extended.type.attribute =
-  
-  ## Identifies the XLink extended link type
-  [
-    s:pattern [
-      name = "XLink extended placement"
-      "\x{a}" ~
-      "            "
-      s:rule [
-        context = "*[@xlink:type='extended']"
-        "\x{a}" ~
-        "               "
-        s:assert [
-          test = "not(parent::*[@xlink:type='extended'])"
-          "An XLink extended type element may not occur as the direct child of an XLink extended type element."
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      "\x{a}" ~
-      "         "
-    ]
-  ]
-  attribute xlink:type {
-    
-    ## An XLink extended link type
-    "extended"
-  }
-db.xlink.locator.type.attribute =
-  
-  ## Identifies the XLink locator link type
-  [
-    s:pattern [
-      name = "XLink locator placement"
-      "\x{a}" ~
-      "            "
-      s:rule [
-        context = "*[@xlink:type='locator']"
-        "\x{a}" ~
-        "               "
-        s:assert [
-          test = "not(parent::*[@xlink:type='extended'])"
-          "An XLink locator type element must occur as the direct child of an XLink extended type element."
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      "\x{a}" ~
-      "         "
-    ]
-  ]
-  attribute xlink:type {
-    
-    ## An XLink locator link type
-    "locator"
-  }
-db.xlink.arc.type.attribute =
-  
-  ## Identifies the XLink arc link type
-  [
-    s:pattern [
-      name = "XLink arc placement"
-      "\x{a}" ~
-      "            "
-      s:rule [
-        context = "*[@xlink:type='arc']"
-        "\x{a}" ~
-        "               "
-        s:assert [
-          test = "parent::*[@xlink:type='extended']"
-          "An XLink arc type element must occur as the direct child of an XLink extended type element."
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      "\x{a}" ~
-      "         "
-    ]
-  ]
-  attribute xlink:type {
-    
-    ## An XLink arc link type
-    "arc"
-  }
-db.xlink.resource.type.attribute =
-  
-  ## Identifies the XLink resource link type
-  [
-    s:pattern [
-      name = "XLink resource placement"
-      "\x{a}" ~
-      "            "
-      s:rule [
-        context = "*[@xlink:type='resource']"
-        "\x{a}" ~
-        "               "
-        s:assert [
-          test = "not(parent::*[@xlink:type='extended'])"
-          "An XLink resource type element must occur as the direct child of an XLink extended type element."
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      "\x{a}" ~
-      "         "
-    ]
-  ]
-  attribute xlink:type {
-    
-    ## An XLink resource link type
-    "resource"
-  }
-db.xlink.title.type.attribute =
-  
-  ## Identifies the XLink title link type
-  [
-    s:pattern [
-      name = "XLink title placement"
-      "\x{a}" ~
-      "            "
-      s:rule [
-        context = "*[@xlink:type='title']"
-        "\x{a}" ~
-        "               "
-        s:assert [
-          test =
-            "not(parent::*[@xlink:type='extended']) and not(parent::*[@xlink:type='locator']) and not(parent::*[@xlink:type='arc'])"
-          "An XLink title type element must occur as the direct child of an XLink extended, locator, or arc type element."
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      "\x{a}" ~
-      "         "
-    ]
-  ]
-  attribute xlink:type {
-    
-    ## An XLink title link type
-    "title"
-  }
-db.xlink.extended.link.attributes =
-  db.xlink.extended.type.attribute
-  & db.xlink.role.attribute?
-  & db.xlink.title.attribute?
-db.xlink.locator.link.attributes =
-  db.xlink.locator.type.attribute
-  & db.xlink.href.attribute
-  & db.xlink.role.attribute?
-  & db.xlink.title.attribute?
-  & db.xlink.label.attribute?
-db.xlink.arc.link.attributes =
-  db.xlink.arc.type.attribute
-  & db.xlink.arcrole.attribute?
-  & db.xlink.title.attribute?
-  & db.xlink.show.attribute?
-  & db.xlink.actuate.attribute?
-  & db.xlink.from.attribute?
-  & db.xlink.to.attribute?
-db.xlink.resource.link.attributes =
-  db.xlink.resource.type.attribute
-  & db.xlink.role.attribute?
-  & db.xlink.title.attribute?
-  & db.xlink.label.attribute?
-db.xlink.title.link.attributes = db.xlink.title.type.attribute
-db.xlink.from.attribute =
-  
-  ## Specifies the XLink traversal-from
-  attribute xlink:from { xsd:NMTOKEN }
-db.xlink.label.attribute =
-  
-  ## Specifies the XLink label
-  attribute xlink:label { xsd:NMTOKEN }
-db.xlink.to.attribute =
-  
-  ## Specifies the XLink traversal-to
-  attribute xlink:to { xsd:NMTOKEN }
-div {
-  db.extendedlink.role.attribute = attribute role { text }
-  db.extendedlink.attlist =
-    db.extendedlink.role.attribute?
-    & db.common.attributes
-    & 
-      ## Identifies the XLink link type 
-      [ a:defaultValue = "extended" ]
-      attribute xlink:type {
-        
-        ## An XLink extended link
-        "extended"
-      }?
-    & db.xlink.role.attribute?
-    & db.xlink.title.attribute?
-  db.extendedlink =
-    
-    ## An XLink extended link
-    element extendedlink {
-      db.extendedlink.attlist, (db.locator | db.arc | db.link)+
-    }
-}
-div {
-  db.locator.role.attribute = attribute role { text }
-  db.locator.attlist =
-    db.locator.role.attribute?
-    & db.common.attributes
-    & 
-      ## Identifies the XLink link type 
-      [ a:defaultValue = "locator" ]
-      attribute xlink:type {
-        
-        ## An XLink locator link
-        "locator"
-      }?
-    & db.xlink.href.attribute
-    & db.xlink.role.attribute?
-    & db.xlink.title.attribute?
-    & db.xlink.label.attribute?
-  db.locator =
-    
-    ## An XLink locator in an extendedlink
-    element locator { db.locator.attlist, empty }
-}
-div {
-  db.arc.role.attribute = attribute role { text }
-  db.arc.attlist =
-    db.arc.role.attribute?
-    & db.common.attributes
-    & 
-      ## Identifies the XLink link type 
-      [ a:defaultValue = "arc" ]
-      attribute xlink:type {
-        
-        ## An XLink arc link
-        "arc"
-      }?
-    & db.xlink.arcrole.attribute?
-    & db.xlink.title.attribute?
-    & db.xlink.show.attribute?
-    & db.xlink.actuate.attribute?
-    & db.xlink.from.attribute?
-    & db.xlink.to.attribute?
-  db.arc =
-    
-    ## An XLink arc in an extendedlink
-    element arc { db.arc.attlist, empty }
-}
-db.sect1.sections = (db.sect2+, db.simplesect*) | db.simplesect+
-div {
-  db.sect1.status.attribute = db.status.attribute
-  db.sect1.role.attribute = attribute role { text }
-  db.sect1.attlist =
-    db.sect1.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.label.attribute?
-    & db.sect1.status.attribute?
-  db.sect1.info = db._info.title.req
-  db.sect1 =
-    
-    ## A top-level section of document
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:sect1"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element sect1 {
-      db.sect1.attlist,
-      db.sect1.info,
-      ((db.all.blocks+, db.sect1.sections?) | db.sect1.sections)?,
-      db.navigation.components*
-    }
-}
-db.sect2.sections = (db.sect3+, db.simplesect*) | db.simplesect+
-div {
-  db.sect2.status.attribute = db.status.attribute
-  db.sect2.role.attribute = attribute role { text }
-  db.sect2.attlist =
-    db.sect2.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.label.attribute?
-    & db.sect2.status.attribute?
-  db.sect2.info = db._info.title.req
-  db.sect2 =
-    
-    ## A subsection within a sect1
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:sect2"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element sect2 {
-      db.sect2.attlist,
-      db.sect2.info,
-      ((db.all.blocks+, db.sect2.sections?) | db.sect2.sections)?,
-      db.navigation.components*
-    }
-}
-db.sect3.sections = (db.sect4+, db.simplesect*) | db.simplesect+
-div {
-  db.sect3.status.attribute = db.status.attribute
-  db.sect3.role.attribute = attribute role { text }
-  db.sect3.attlist =
-    db.sect3.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.label.attribute?
-    & db.sect3.status.attribute?
-  db.sect3.info = db._info.title.req
-  db.sect3 =
-    
-    ## A subsection within a sect2
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:sect3"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element sect3 {
-      db.sect3.attlist,
-      db.sect3.info,
-      ((db.all.blocks+, db.sect3.sections?) | db.sect3.sections)?,
-      db.navigation.components*
-    }
-}
-db.sect4.sections = (db.sect5+, db.simplesect*) | db.simplesect+
-div {
-  db.sect4.status.attribute = db.status.attribute
-  db.sect4.role.attribute = attribute role { text }
-  db.sect4.attlist =
-    db.sect4.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.label.attribute?
-    & db.sect4.status.attribute?
-  db.sect4.info = db._info.title.req
-  db.sect4 =
-    
-    ## A subsection within a sect3
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:sect4"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element sect4 {
-      db.sect4.attlist,
-      db.sect4.info,
-      ((db.all.blocks+, db.sect4.sections?) | db.sect4.sections)?,
-      db.navigation.components*
-    }
-}
-db.sect5.sections = db.simplesect+
-div {
-  db.sect5.status.attribute = db.status.attribute
-  db.sect5.role.attribute = attribute role { text }
-  db.sect5.attlist =
-    db.sect5.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.label.attribute?
-    & db.sect5.status.attribute?
-  db.sect5.info = db._info.title.req
-  db.sect5 =
-    
-    ## A subsection within a sect4
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:sect5"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element sect5 {
-      db.sect5.attlist,
-      db.sect5.info,
-      ((db.all.blocks+, db.sect5.sections?) | db.sect5.sections)?,
-      db.navigation.components*
-    }
-}
-db.toplevel.refsection = db.refsection+ | db.refsect1+
-db.secondlevel.refsection = db.refsection+ | db.refsect2+
-db.reference.components = db.refentry
-div {
-  db.reference.status.attribute = db.status.attribute
-  db.reference.role.attribute = attribute role { text }
-  db.reference.attlist =
-    db.reference.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.reference.status.attribute?
-    & db.label.attribute?
-  db.reference.info = db._info.title.req
-  db.reference =
-    
-    ## A collection of reference entries
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:reference"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element reference {
-      db.reference.attlist,
-      db.reference.info,
-      db.partintro?,
-      db.reference.components*
-    }
-}
-div {
-  db.refentry.status.attribute = db.status.attribute
-  db.refentry.role.attribute = attribute role { text }
-  db.refentry.attlist =
-    db.refentry.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.refentry.status.attribute?
-    & db.label.attribute?
-  db.refentry.info = db._info.title.forbidden
-  db.refentry =
-    
-    ## A reference page (originally a UNIX man-style reference page)
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:refentry"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element refentry {
-      db.refentry.attlist,
-      db.indexterm*,
-      db.refentry.info,
-      db.refmeta?,
-      db.refnamediv+,
-      db.refsynopsisdiv?,
-      db.toplevel.refsection
-    }
-}
-div {
-  db.refmeta.role.attribute = attribute role { text }
-  db.refmeta.attlist =
-    db.refmeta.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.refmeta =
-    
-    ## Meta-information for a reference entry
-    element refmeta {
-      db.refmeta.attlist,
-      db.indexterm*,
-      db.refentrytitle,
-      db.manvolnum?,
-      db.refmiscinfo*,
-      db.indexterm*
-    }
-}
-db.refmiscinfo.class.enumeration =
-  
-  ## The name of the software product or component to which this topic applies
-  "source"
-  | 
-    ## The version of the software product or component to which this topic applies
-    "version"
-  | 
-    ## The section title of the reference page (e.g., User Commands)
-    "manual"
-  | 
-    ## The section title of the reference page (believed synonymous with "manual" but in wide use)
-    "sectdesc"
-  | 
-    ## The name of the software product or component to which this topic applies (e.g., SunOS x.y; believed synonymous with "source" but in wide use)
-    "software"
-db.refmiscinfo.class-enum.attribute =
-  
-  ## Identifies the kind of miscellaneous information
-  attribute class { db.refmiscinfo.class.enumeration }?
-db.refmiscinfo.class-other.attribute =
-  
-  ## Identifies the nature of non-standard miscellaneous information
-  attribute otherclass { text }
-db.refmiscinfo.class-other.attributes =
-  
-  ## Identifies the kind of miscellaneious information
-  attribute class {
-    
-    ## Indicates that the information is some 'other' kind.
-    "other"
-  }
-  & db.refmiscinfo.class-other.attribute
-db.refmiscinfo.class.attribute =
-  db.refmiscinfo.class-enum.attribute
-  | db.refmiscinfo.class-other.attributes
-div {
-  db.refmiscinfo.role.attribute = attribute role { text }
-  db.refmiscinfo.attlist =
-    db.refmiscinfo.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.refmiscinfo.class.attribute?
-  db.refmiscinfo =
-    
-    ## Meta-information for a reference entry other than the title and volume number
-    element refmiscinfo { db.refmiscinfo.attlist, db._text }
-}
-div {
-  db.refnamediv.role.attribute = attribute role { text }
-  db.refnamediv.attlist =
-    db.refnamediv.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.refnamediv =
-    
-    ## The name, purpose, and classification of a reference page
-    element refnamediv {
-      db.refnamediv.attlist,
-      db.refdescriptor?,
-      db.refname+,
-      db.refpurpose,
-      db.refclass*
-    }
-}
-div {
-  db.refdescriptor.role.attribute = attribute role { text }
-  db.refdescriptor.attlist =
-    db.refdescriptor.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.refdescriptor =
-    
-    ## A description of the topic of a reference page
-    element refdescriptor { db.refdescriptor.attlist, db.all.inlines* }
-}
-div {
-  db.refname.role.attribute = attribute role { text }
-  db.refname.attlist =
-    db.refname.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.refname =
-    
-    ## The name of (one of) the subject(s) of a reference page
-    element refname { db.refname.attlist, db.all.inlines* }
-}
-div {
-  db.refpurpose.role.attribute = attribute role { text }
-  db.refpurpose.attlist =
-    db.refpurpose.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.refpurpose =
-    
-    ## A short (one sentence) synopsis of the topic of a reference page
-    element refpurpose { db.refpurpose.attlist, db.all.inlines* }
-}
-div {
-  db.refclass.role.attribute = attribute role { text }
-  db.refclass.attlist =
-    db.refclass.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.refclass =
-    
-    ## The scope or other indication of applicability of a reference entry
-    element refclass { db.refclass.attlist, (text | db.application)* }
-}
-div {
-  db.refsynopsisdiv.role.attribute = attribute role { text }
-  db.refsynopsisdiv.attlist =
-    db.refsynopsisdiv.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.refsynopsisdiv.info = db._info
-  db.refsynopsisdiv =
-    
-    ## A syntactic synopsis of the subject of the reference page
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:refsynopsisdiv"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element refsynopsisdiv {
-      db.refsynopsisdiv.attlist,
-      db.refsynopsisdiv.info,
-      ((db.all.blocks+, db.secondlevel.refsection?)
-       | db.secondlevel.refsection)
-    }
-}
-div {
-  db.refsection.status.attribute = db.status.attribute
-  db.refsection.role.attribute = attribute role { text }
-  db.refsection.attlist =
-    db.refsection.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.refsection.status.attribute?
-    & db.label.attribute?
-  db.refsection.info = db._info.title.req
-  db.refsection =
-    
-    ## A recursive section in a refentry
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:refsection"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element refsection {
-      db.refsection.attlist,
-      db.refsection.info,
-      ((db.all.blocks+, db.refsection*) | db.refsection+)
-    }
-}
-db.refsect1.sections = db.refsect2+
-div {
-  db.refsect1.status.attribute = db.status.attribute
-  db.refsect1.role.attribute = attribute role { text }
-  db.refsect1.attlist =
-    db.refsect1.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.label.attribute?
-    & db.refsect1.status.attribute?
-  db.refsect1.info = db._info.title.req
-  db.refsect1 =
-    
-    ## A major subsection of a reference entry
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:refsect1"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element refsect1 {
-      db.refsect1.attlist,
-      db.refsect1.info,
-      ((db.all.blocks+, db.refsect1.sections?) | db.refsect1.sections)
-    }
-}
-db.refsect2.sections = db.refsect3+
-div {
-  db.refsect2.status.attribute = db.status.attribute
-  db.refsect2.role.attribute = attribute role { text }
-  db.refsect2.attlist =
-    db.refsect2.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.label.attribute?
-    & db.refsect2.status.attribute?
-  db.refsect2.info = db._info.title.req
-  db.refsect2 =
-    
-    ## A subsection of a refsect1
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:refsect2"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element refsect2 {
-      db.refsect2.attlist,
-      db.refsect2.info,
-      ((db.all.blocks+, db.refsect2.sections?) | db.refsect2.sections)
-    }
-}
-div {
-  db.refsect3.status.attribute = db.status.attribute
-  db.refsect3.role.attribute = attribute role { text }
-  db.refsect3.attlist =
-    db.refsect3.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.label.attribute?
-    & db.refsect3.status.attribute?
-  db.refsect3.info = db._info.title.req
-  db.refsect3 =
-    
-    ## A subsection of a refsect2
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:refsect3"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element refsect3 {
-      db.refsect3.attlist, db.refsect3.info, db.all.blocks+
-    }
-}
-db.glossary.inlines =
-  db.firstterm | db.glossterm | db._firstterm | db._glossterm
-db.baseform.attribute =
-  
-  ## Specifies the base form of the term, the one that appears in the glossary. This allows adjectival, plural, and other variations of the term to appear in the element. The element content is the default base form.
-  attribute baseform { text }?
-div {
-  db.glosslist.role.attribute = attribute role { text }
-  db.glosslist.attlist =
-    db.glosslist.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.glosslist.info = db._info.title.only
-  db.glosslist =
-    
-    ## A wrapper for a list of glossary entries
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:glosslist"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element glosslist {
-      db.glosslist.attlist,
-      db.glosslist.info?,
-      db.all.blocks*,
-      db.glossentry+
-    }
-}
-div {
-  db.glossentry.role.attribute = attribute role { text }
-  db.glossentry.sortas.attribute =
-    
-    ## Specifies the string by which the element's content is to be sorted; if unspecified, the content is used
-    attribute sortas { text }
-  db.glossentry.attlist =
-    db.glossentry.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.glossentry.sortas.attribute?
-  db.glossentry =
-    
-    ## An entry in a glossary or glosslist
-    element glossentry {
-      db.glossentry.attlist,
-      db.glossterm,
-      db.acronym?,
-      db.abbrev?,
-      db.indexterm*,
-      (db.glosssee | db.glossdef+)
-    }
-}
-div {
-  db.glossdef.role.attribute = attribute role { text }
-  db.glossdef.subject.attribute =
-    
-    ## Specifies a list of keywords for the definition
-    attribute subject { text }
-  db.glossdef.attlist =
-    db.glossdef.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.glossdef.subject.attribute?
-  db.glossdef =
-    
-    ## A definition in a glossentry
-    element glossdef {
-      db.glossdef.attlist, db.all.blocks+, db.glossseealso*
-    }
-}
-div {
-  db.glosssee.role.attribute = attribute role { text }
-  db.glosssee.otherterm.attribute =
-    
-    ## Identifies the other term
-    attribute otherterm { xsd:IDREF }
-  db.glosssee.attlist =
-    db.glosssee.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.glosssee.otherterm.attribute?
-  db.glosssee =
-    
-    ## A cross-reference from one glossentry
-    ##  to another
-    [
-      s:pattern [
-        name = "Glosssary 'see' type constraint"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:glosssee[@otherterm]"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test =
-              "local-name(//*[@xml:id=current()/@otherterm]) = 'glossentry' and namespace-uri(//*[@xml:id=current()/@otherterm]) = 'http://docbook.org/ns/docbook'"
-            "@otherterm on glosssee must point to a glossentry."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element glosssee { db.glosssee.attlist, db.all.inlines* }
-}
-div {
-  db.glossseealso.role.attribute = attribute role { text }
-  db.glossseealso.otherterm.attribute =
-    
-    ## Identifies the other term
-    attribute otherterm { xsd:IDREF }
-  db.glossseealso.attlist =
-    db.glossseealso.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.glossseealso.otherterm.attribute?
-  db.glossseealso =
-    
-    ## A cross-reference from one glossentry to another
-    [
-      s:pattern [
-        name = "Glossary 'seealso' type constraint"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:glossseealso[@otherterm]"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test =
-              "local-name(//*[@xml:id=current()/@otherterm]) = 'glossentry' and namespace-uri(//*[@xml:id=current()/@otherterm]) = 'http://docbook.org/ns/docbook'"
-            "@otherterm on glossseealso must point to a glossentry."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element glossseealso { db.glossseealso.attlist, db.all.inlines* }
-}
-div {
-  db.firstterm.role.attribute = attribute role { text }
-  db.firstterm.attlist =
-    db.firstterm.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.baseform.attribute
-  db.firstterm =
-    
-    ## The first occurrence of a term
-    [
-      s:pattern [
-        name = "Glossary 'firstterm' type constraint"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:firstterm[@linkend]"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test =
-              "local-name(//*[@xml:id=current()/@linkend]) = 'glossentry' and namespace-uri(//*[@xml:id=current()/@linkend]) = 'http://docbook.org/ns/docbook'"
-            "@linkend on firstterm must point to a glossentry."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element firstterm { db.firstterm.attlist, db.all.inlines* }
-}
-div {
-  db._firstterm.role.attribute = attribute role { text }
-  db._firstterm.attlist =
-    db._firstterm.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.baseform.attribute
-  db._firstterm =
-    
-    ## The first occurrence of a term, with limited content
-    [
-      s:pattern [
-        name = "Glossary 'firstterm' type constraint"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:firstterm[@linkend]"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test =
-              "local-name(//*[@xml:id=current()/@linkend]) = 'glossentry' and namespace-uri(//*[@xml:id=current()/@linkend]) = 'http://docbook.org/ns/docbook'"
-            "@linkend on firstterm must point to a glossentry."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element firstterm { db._firstterm.attlist, db._text }
-}
-div {
-  db.glossterm.role.attribute = attribute role { text }
-  db.glossterm.attlist =
-    db.glossterm.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.baseform.attribute
-  db.glossterm =
-    
-    ## A glossary term
-    [
-      s:pattern [
-        name = "Glossary 'glossterm' type constraint"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:glossterm[@linkend]"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test =
-              "local-name(//*[@xml:id=current()/@linkend]) = 'glossentry' and namespace-uri(//*[@xml:id=current()/@linkend]) = 'http://docbook.org/ns/docbook'"
-            "@linkend on glossterm must point to a glossentry."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element glossterm { db.glossterm.attlist, db.all.inlines* }
-}
-div {
-  db._glossterm.role.attribute = attribute role { text }
-  db._glossterm.attlist =
-    db._glossterm.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.baseform.attribute
-  db._glossterm =
-    
-    ## A glossary term
-    [
-      s:pattern [
-        name = "Glossary 'glossterm' type constraint"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:glossterm[@linkend]"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test =
-              "local-name(//*[@xml:id=current()/@linkend]) = 'glossentry' and namespace-uri(//*[@xml:id=current()/@linkend]) = 'http://docbook.org/ns/docbook'"
-            "@linkend on glossterm must point to a glossentry."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element glossterm { db._glossterm.attlist, db._text }
-}
-div {
-  db.glossary.status.attribute = db.status.attribute
-  db.glossary.role.attribute = attribute role { text }
-  db.glossary.attlist =
-    db.glossary.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.label.attribute?
-    & db.glossary.status.attribute?
-  db.glossary.info = db._info
-  db.glossary =
-    
-    ## A glossary
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:glossary"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element glossary {
-      db.glossary.attlist,
-      db.glossary.info,
-      db.all.blocks*,
-      (db.glossdiv* | db.glossentry*),
-      db.bibliography?
-    }
-}
-div {
-  db.glossdiv.status.attribute = db.status.attribute
-  db.glossdiv.role.attribute = attribute role { text }
-  db.glossdiv.attlist =
-    db.glossdiv.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.label.attribute?
-    & db.glossdiv.status.attribute?
-  db.glossdiv.info = db._info.title.req
-  db.glossdiv =
-    
-    ## A division in a glossary
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:glossdiv"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element glossdiv {
-      db.glossdiv.attlist,
-      db.glossdiv.info,
-      db.all.blocks*,
-      db.glossentry+
-    }
-}
-div {
-  db.termdef.role.attribute = attribute role { text }
-  db.termdef.attlist =
-    db.termdef.role.attribute?
-    & db.glossentry.sortas.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.baseform.attribute
-  db.termdef =
-    
-    ## An inline definition of a term
-    [
-      s:pattern [
-        name = "Glossary term definition constraint"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:termdef"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "count(db:firstterm) = 1"
-            "A termdef must contain exactly one firstterm"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element termdef { db.termdef.attlist, db.all.inlines* }
-}
-db.relation.attribute =
-  
-  ## Identifies the relationship between the bibliographic elemnts
-  attribute relation { text }
-div {
-  db.biblioentry.role.attribute = attribute role { text }
-  db.biblioentry.attlist =
-    db.biblioentry.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.biblioentry =
-    
-    ## A raw entry in a bibliography
-    element biblioentry {
-      db.biblioentry.attlist, db.bibliographic.elements+
-    }
-}
-div {
-  db.bibliomixed.role.attribute = attribute role { text }
-  db.bibliomixed.attlist =
-    db.bibliomixed.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.bibliomixed =
-    
-    ## A cooked entry in a bibliography
-    element bibliomixed {
-      db.bibliomixed.attlist,
-      ((db._text
-        | db.honorific
-        | db.firstname
-        | db.surname
-        | db.lineage
-        | db.othername
-        | db.bibliographic.elements)*
-       | (db._text
-          | db.honorific
-          | db.givenname
-          | db.surname
-          | db.lineage
-          | db.othername
-          | db.bibliographic.elements)*)
-    }
-}
-div {
-  db.biblioset.relation.attribute = db.relation.attribute
-  db.biblioset.role.attribute = attribute role { text }
-  db.biblioset.attlist =
-    db.biblioset.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.biblioset.relation.attribute?
-  db.biblioset =
-    
-    ## A raw container for related bibliographic information
-    element biblioset {
-      db.biblioset.attlist, db.bibliographic.elements+
-    }
-}
-div {
-  db.bibliomset.relation.attribute = db.relation.attribute
-  db.bibliomset.role.attribute = attribute role { text }
-  db.bibliomset.attlist =
-    db.bibliomset.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.bibliomset.relation.attribute?
-  db.bibliomset =
-    
-    ## A cooked container for related bibliographic information
-    element bibliomset {
-      db.bibliomset.attlist,
-      ((db._text
-        | db.honorific
-        | db.firstname
-        | db.surname
-        | db.lineage
-        | db.othername
-        | db.bibliographic.elements)*
-       | (db._text
-          | db.honorific
-          | db.givenname
-          | db.surname
-          | db.lineage
-          | db.othername
-          | db.bibliographic.elements)*)
-    }
-}
-div {
-  db.bibliomisc.role.attribute = attribute role { text }
-  db.bibliomisc.attlist =
-    db.bibliomisc.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.bibliomisc =
-    
-    ## Untyped bibliographic information
-    element bibliomisc { db.bibliomisc.attlist, db._text }
-}
-div {
-  db.bibliography.status.attrib = db.status.attribute
-  db.bibliography.role.attribute = attribute role { text }
-  db.bibliography.attlist =
-    db.bibliography.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.label.attribute?
-    & db.bibliography.status.attrib?
-  db.bibliography.info = db._info
-  db.bibliography =
-    
-    ## A bibliography
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:bibliography"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element bibliography {
-      db.bibliography.attlist,
-      db.bibliography.info,
-      db.all.blocks*,
-      (db.bibliodiv+ | (db.biblioentry | db.bibliomixed)+)
-    }
-}
-div {
-  db.bibliodiv.status.attrib = db.status.attribute
-  db.bibliodiv.role.attribute = attribute role { text }
-  db.bibliodiv.attlist =
-    db.bibliodiv.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.label.attribute?
-    & db.bibliodiv.status.attrib?
-  db.bibliodiv.info = db._info.title.req
-  db.bibliodiv =
-    
-    ## A section of a bibliography
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:bibliodiv"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element bibliodiv {
-      db.bibliodiv.attlist,
-      db.bibliodiv.info,
-      db.all.blocks*,
-      (db.biblioentry | db.bibliomixed)+
-    }
-}
-div {
-  db.bibliolist.role.attribute = attribute role { text }
-  db.bibliolist.attlist =
-    db.bibliolist.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.bibliolist.info = db._info.title.only
-  db.bibliolist =
-    
-    ## A wrapper for a list of bibliography entries
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:bibliolist"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element bibliolist {
-      db.bibliolist.attlist,
-      db.bibliolist.info?,
-      db.all.blocks*,
-      (db.biblioentry | db.bibliomixed)+
-    }
-}
-div {
-  db.biblioref.role.attribute = attribute role { text }
-  db.biblioref.xrefstyle.attribute = db.xrefstyle.attribute
-  db.biblioref.endterm.attribute = db.endterm.attribute
-  db.biblioref.units.attribute =
-    
-    ## The units (for example, pages) used to identify the beginning and ending of a reference.
-    attribute units { xsd:token }
-  db.biblioref.begin.attribute =
-    
-    ## Identifies the beginning of a reference; the location within the work that is being referenced.
-    attribute begin { xsd:token }
-  db.biblioref.end.attribute =
-    
-    ## Identifies the end of a reference.
-    attribute end { xsd:token }
-  db.biblioref.attlist =
-    db.biblioref.role.attribute?
-    & db.common.attributes
-    & db.common.req.linking.attributes
-    & db.biblioref.xrefstyle.attribute?
-    & db.biblioref.endterm.attribute?
-    & db.biblioref.units.attribute?
-    & db.biblioref.begin.attribute?
-    & db.biblioref.end.attribute?
-  db.biblioref =
-    
-    ## A cross-reference to a bibliographic entry
-    element biblioref { db.biblioref.attlist, empty }
-}
-db.significance.enumeration =
-  
-  ## Normal
-  "normal"
-  | 
-    ## Preferred
-    "preferred"
-db.significance.attribute =
-  
-  ## Specifies the significance of the term
-  attribute significance { db.significance.enumeration }
-db.zone.attribute =
-  
-  ## Specifies the IDs of the elements to which this term applies
-  attribute zone { xsd:IDREFS }
-db.indexterm.pagenum.attribute =
-  
-  ## Indicates the page on which this index term occurs in some version of the printed document
-  attribute pagenum { text }
-db.scope.enumeration =
-  
-  ## All indexes
-  "all"
-  | 
-    ## The global index (as for a combined index of a set of books)
-    "global"
-  | 
-    ## The local index (the index for this document only)
-    "local"
-db.scope.attribute =
-  
-  ## Specifies the scope of the index term
-  attribute scope { db.scope.enumeration }
-db.sortas.attribute =
-  
-  ## Specifies the string by which the term is to be sorted; if unspecified, the term content is used
-  attribute sortas { text }
-db.index.type.attribute =
-  
-  ## Specifies the target index for this term
-  attribute type { text }
-div {
-  db.itermset.role.attribute = attribute role { text }
-  db.itermset.attlist =
-    db.itermset.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.itermset =
-    
-    ## A set of index terms in the meta-information of a document
-    element itermset { db.itermset.attlist, db.indexterm.singular+ }
-}
-db.indexterm.contentmodel =
-  db.primary?,
-  ((db.secondary,
-    ((db.tertiary, (db.see | db.seealso+)?)
-     | db.see
-     | db.seealso+)?)
-   | db.see
-   | db.seealso+)?
-div {
-  db.indexterm.singular.role.attribute = attribute role { text }
-  db.indexterm.singular.class.attribute =
-    
-    ## Identifies the class of index term
-    attribute class {
-      
-      ## A singular index term
-      "singular"
-    }
-  db.indexterm.singular.attlist =
-    db.indexterm.singular.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.significance.attribute?
-    & db.zone.attribute?
-    & db.indexterm.pagenum.attribute?
-    & db.scope.attribute?
-    & db.index.type.attribute?
-    & db.indexterm.singular.class.attribute?
-  db.indexterm.singular =
-    
-    ## A wrapper for an indexed term
-    element indexterm {
-      db.indexterm.singular.attlist, db.indexterm.contentmodel
-    }
-}
-div {
-  db.indexterm.startofrange.role.attribute = attribute role { text }
-  db.indexterm.startofrange.class.attribute =
-    
-    ## Identifies the class of index term
-    attribute class {
-      
-      ## The start of a range
-      "startofrange"
-    }
-  db.indexterm.startofrange.attlist =
-    db.indexterm.startofrange.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.significance.attribute?
-    & db.zone.attribute?
-    & db.indexterm.pagenum.attribute?
-    & db.scope.attribute?
-    & db.index.type.attribute?
-    & db.indexterm.startofrange.class.attribute
-  db.indexterm.startofrange =
-    
-    ## A wrapper for an indexed term that covers a range
-    element indexterm {
-      db.indexterm.startofrange.attlist, db.indexterm.contentmodel
-    }
-}
-div {
-  db.indexterm.endofrange.role.attribute = attribute role { text }
-  db.indexterm.endofrange.class.attribute =
-    
-    ## Identifies the class of index term
-    attribute class {
-      
-      ## The end of a range
-      "endofrange"
-    }
-  db.indexterm.endofrange.startref.attribute =
-    
-    ## Points to the start of the range
-    attribute startref { xsd:IDREF }
-  db.indexterm.endofrange.attlist =
-    db.indexterm.endofrange.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.indexterm.endofrange.class.attribute
-    & db.indexterm.endofrange.startref.attribute
-  db.indexterm.endofrange =
-    
-    ## Identifies the end of a range associated with an indexed term
-    element indexterm { db.indexterm.endofrange.attlist, empty }
-}
-div {
-  db.indexterm =
-    db.indexterm.singular
-    | db.indexterm.startofrange
-    | db.indexterm.endofrange
-}
-div {
-  db.primary.role.attribute = attribute role { text }
-  db.primary.attlist =
-    db.primary.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.sortas.attribute?
-  db.primary =
-    
-    ## The primary word or phrase under which an index term should be sorted
-    element primary { db.primary.attlist, db.all.inlines* }
-}
-div {
-  db.secondary.role.attribute = attribute role { text }
-  db.secondary.attlist =
-    db.secondary.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.sortas.attribute?
-  db.secondary =
-    
-    ## A secondary word or phrase in an index term
-    element secondary { db.secondary.attlist, db.all.inlines* }
-}
-div {
-  db.tertiary.role.attribute = attribute role { text }
-  db.tertiary.attlist =
-    db.tertiary.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.sortas.attribute?
-  db.tertiary =
-    
-    ## A tertiary word or phrase in an index term
-    element tertiary { db.tertiary.attlist, db.all.inlines* }
-}
-div {
-  db.see.role.attribute = attribute role { text }
-  db.see.attlist =
-    db.see.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.see =
-    
-    ## Part of an index term directing the reader instead to another entry in the index
-    element see { db.see.attlist, db.all.inlines* }
-}
-div {
-  db.seealso.role.attribute = attribute role { text }
-  db.seealso.attlist =
-    db.seealso.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.seealso =
-    
-    ## Part of an index term directing the reader also to another entry in the index
-    element seealso { db.seealso.attlist, db.all.inlines* }
-}
-div {
-  db.index.status.attribute = db.status.attribute
-  db.index.role.attribute = attribute role { text }
-  db.index.attlist =
-    db.index.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.label.attribute?
-    & db.index.status.attribute?
-    & db.index.type.attribute?
-  db.index.info = db._info
-  # Yes, db.indexdiv* and db.indexentry*; that way an <index/> is valid.
-  # Authors can use an empty index to indicate where a generated index should
-  # appear.
-  db.index =
-    
-    ## An index to a book or part of a book
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:index"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element index {
-      db.index.attlist,
-      db.index.info,
-      db.all.blocks*,
-      (db.indexdiv* | db.indexentry* | db.segmentedlist)
-    }
-}
-div {
-  db.setindex.status.attribute = db.status.attribute
-  db.setindex.role.attribute = attribute role { text }
-  db.setindex.attlist =
-    db.setindex.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.label.attribute?
-    & db.setindex.status.attribute?
-    & db.index.type.attribute?
-  db.setindex.info = db._info
-  db.setindex =
-    
-    ## An index to a set of books
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:setindex"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element setindex {
-      db.setindex.attlist,
-      db.setindex.info,
-      db.all.blocks*,
-      (db.indexdiv* | db.indexentry*)
-    }
-}
-div {
-  db.indexdiv.status.attribute = db.status.attribute
-  db.indexdiv.role.attribute = attribute role { text }
-  db.indexdiv.attlist =
-    db.indexdiv.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.label.attribute?
-    & db.indexdiv.status.attribute?
-  db.indexdiv.info = db._info.title.req
-  db.indexdiv =
-    
-    ## A division in an index
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:indexdiv"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element indexdiv {
-      db.indexdiv.attlist,
-      db.indexdiv.info,
-      db.all.blocks*,
-      (db.indexentry+ | db.segmentedlist)
-    }
-}
-div {
-  db.indexentry.role.attribute = attribute role { text }
-  db.indexentry.attlist =
-    db.indexentry.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.indexentry =
-    
-    ## An entry in an index
-    element indexentry {
-      db.indexentry.attlist,
-      db.primaryie,
-      (db.seeie | db.seealsoie)*,
-      (db.secondaryie, (db.seeie | db.seealsoie | db.tertiaryie)*)*
-    }
-}
-div {
-  db.primaryie.role.attribute = attribute role { text }
-  db.primaryie.attlist =
-    db.primaryie.role.attribute?
-    & db.common.attributes
-    & db.linkends.attribute?
-  db.primaryie =
-    
-    ## A primary term in an index entry, not in the text
-    element primaryie { db.primaryie.attlist, db.all.inlines* }
-}
-div {
-  db.secondaryie.role.attribute = attribute role { text }
-  db.secondaryie.attlist =
-    db.secondaryie.role.attribute?
-    & db.common.attributes
-    & db.linkends.attribute?
-  db.secondaryie =
-    
-    ## A secondary term in an index entry, rather than in the text
-    element secondaryie { db.secondaryie.attlist, db.all.inlines* }
-}
-div {
-  db.tertiaryie.role.attribute = attribute role { text }
-  db.tertiaryie.attlist =
-    db.tertiaryie.role.attribute?
-    & db.common.attributes
-    & db.linkends.attribute?
-  db.tertiaryie =
-    
-    ## A tertiary term in an index entry, rather than in the text
-    element tertiaryie { db.tertiaryie.attlist, db.all.inlines* }
-}
-div {
-  db.seeie.role.attribute = attribute role { text }
-  db.seeie.attlist =
-    db.seeie.role.attribute?
-    & db.common.attributes
-    & db.linkend.attribute?
-  db.seeie =
-    
-    ## A See
-    ## entry in an index, rather than in the text
-    element seeie { db.seeie.attlist, db.all.inlines* }
-}
-div {
-  db.seealsoie.role.attribute = attribute role { text }
-  db.seealsoie.attlist =
-    db.seealsoie.role.attribute?
-    & db.common.attributes
-    & db.linkends.attribute?
-  db.seealsoie =
-    
-    ## A See also
-    ##  entry in an index, rather than in the text
-    element seealsoie { db.seealsoie.attlist, db.all.inlines* }
-}
-db.toc.pagenum.attribute =
-  
-  ## Indicates the page on which this element occurs in some version of the printed document
-  attribute pagenum { text }
-div {
-  db.toc.role.attribute = attribute role { text }
-  db.toc.attlist =
-    db.toc.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.toc.info = db._info.title.only
-  db.toc =
-    
-    ## A table of contents
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:toc"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element toc {
-      db.toc.attlist,
-      db.toc.info,
-      db.all.blocks*,
-      (db.tocdiv | db.tocentry)*
-    }
-}
-div {
-  db.tocdiv.role.attribute = attribute role { text }
-  db.tocdiv.pagenum.attribute = db.toc.pagenum.attribute
-  db.tocdiv.attlist =
-    db.tocdiv.role.attribute?
-    & db.common.attributes
-    & db.tocdiv.pagenum.attribute?
-    & db.linkend.attribute?
-  db.tocdiv.info = db._info
-  db.tocdiv =
-    
-    ## A division in a table of contents
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:tocdiv"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element tocdiv {
-      db.tocdiv.attlist,
-      db.tocdiv.info,
-      db.all.blocks*,
-      (db.tocdiv | db.tocentry)+
-    }
-}
-div {
-  db.tocentry.role.attribute = attribute role { text }
-  db.tocentry.pagenum.attribute = db.toc.pagenum.attribute
-  db.tocentry.attlist =
-    db.tocentry.role.attribute?
-    & db.common.attributes
-    & db.tocentry.pagenum.attribute?
-    & db.linkend.attribute?
-  db.tocentry =
-    
-    ## A component title in a table of contents
-    element tocentry { db.tocentry.attlist, db.all.inlines* }
-}
-db.task.info = db._info.title.req
-div {
-  db.task.role.attribute = attribute role { text }
-  db.task.attlist =
-    db.task.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.task =
-    
-    ## A task to be completed
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:task"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element task {
-      db.task.attlist,
-      db.task.info,
-      db.tasksummary?,
-      db.taskprerequisites?,
-      db.procedure+,
-      db.example*,
-      db.taskrelated?
-    }
-}
-div {
-  db.tasksummary.role.attribute = attribute role { text }
-  db.tasksummary.attlist =
-    db.tasksummary.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.tasksummary.info = db._info.title.only
-  db.tasksummary =
-    
-    ## A summary of a task
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:tasksummary"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element tasksummary {
-      db.tasksummary.attlist, db.tasksummary.info, db.all.blocks+
-    }
-}
-div {
-  db.taskprerequisites.role.attribute = attribute role { text }
-  db.taskprerequisites.attlist =
-    db.taskprerequisites.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.taskprerequisites.info = db._info.title.only
-  db.taskprerequisites =
-    
-    ## The prerequisites for a task
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:taskprerequisites"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element taskprerequisites {
-      db.taskprerequisites.attlist,
-      db.taskprerequisites.info,
-      db.all.blocks+
-    }
-}
-div {
-  db.taskrelated.role.attribute = attribute role { text }
-  db.taskrelated.attlist =
-    db.taskrelated.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.taskrelated.info = db._info.title.only
-  db.taskrelated =
-    
-    ## Information related to a task
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:taskrelated"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element taskrelated {
-      db.taskrelated.attlist, db.taskrelated.info, db.all.blocks+
-    }
-}
-db.area.units.enumeration =
-  
-  ## Coordinates expressed as a pair of CALS graphic coordinates.
-  "calspair"
-  | 
-    ## Coordinates expressed as a line and column.
-    "linecolumn"
-  | 
-    ## Coordinates expressed as a pair of lines and columns.
-    "linecolumnpair"
-  | 
-    ## Coordinates expressed as a line range.
-    "linerange"
-db.area.units-enum.attribute =
-  
-  ## Identifies the units used in the coords attribute. The default units vary according to the type of callout specified: calspair
-  ##  for graphics and linecolumn
-  ##  for line-oriented elements.
-  attribute units { db.area.units.enumeration }?
-db.area.units-other.attributes =
-  
-  ## Indicates that non-standard units are used for this area
-  ## . In this case otherunits
-  ##  must be specified.
-  attribute units {
-    
-    ## Coordinates expressed in some non-standard units.
-    "other"
-  }?,
-  
-  ## Identifies the units used in the coords
-  ##  attribute when the units
-  ##  attribute is other
-  ## . This attribute is forbidden otherwise.
-  attribute otherunits { xsd:NMTOKEN }
-db.area.units.attribute =
-  db.area.units-enum.attribute | db.area.units-other.attributes
-div {
-  db.calloutlist.role.attribute = attribute role { text }
-  db.calloutlist.attlist =
-    db.calloutlist.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.calloutlist.info = db._info.title.only
-  db.calloutlist =
-    
-    ## A list of callout
-    ## s
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:calloutlist"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element calloutlist {
-      db.calloutlist.attlist,
-      db.calloutlist.info,
-      db.all.blocks*,
-      db.callout+
-    }
-}
-div {
-  db.callout.role.attribute = attribute role { text }
-  db.callout.arearefs.attribute =
-    
-    ## Identifies the areas described by this callout.
-    attribute arearefs { xsd:IDREFS }
-  db.callout.attlist =
-    db.callout.role.attribute?
-    & db.common.attributes
-    & db.callout.arearefs.attribute
-  db.callout =
-    
-    ## A called out
-    ##  description of a marked area
-    element callout { db.callout.attlist, db.all.blocks+ }
-}
-div {
-  db.programlistingco.role.attribute = attribute role { text }
-  db.programlistingco.attlist =
-    db.programlistingco.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.programlistingco.info = db._info.title.forbidden
-  db.programlistingco =
-    
-    ## A program listing with associated areas used in callouts
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:programlistingco"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element programlistingco {
-      db.programlistingco.attlist,
-      db.programlistingco.info,
-      db.areaspec,
-      db.programlisting,
-      db.calloutlist*
-    }
-}
-div {
-  db.areaspec.role.attribute = attribute role { text }
-  db.areaspec.attlist =
-    db.areaspec.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.area.units.attribute
-  db.areaspec =
-    
-    ## A collection of regions in a graphic or code example
-    element areaspec { db.areaspec.attlist, (db.area | db.areaset)+ }
-}
-div {
-  db.area.role.attribute = attribute role { text }
-  db.area.linkends.attribute =
-    
-    ## Point to the callout
-    ## s which refer to this area. (This provides bidirectional linking which may be useful in online presentation.)
-    attribute linkends { xsd:IDREFS }
-  db.area.label.attribute =
-    
-    ## Specifies an identifying number or string that may be used in presentation. The area label might be drawn on top of the figure, for example, at the position indicated by the coords attribute.
-    attribute label { text }
-  db.area.coords.attribute =
-    
-    ## Provides the coordinates of the area. The coordinates must be interpreted using the units
-    ##  specified.
-    attribute coords { text }
-  db.area.attlist =
-    db.area.role.attribute?
-    & db.common.idreq.attributes
-    & db.area.units.attribute
-    & (db.area.linkends.attribute | db.xlink.simple.link.attributes)?
-    & db.area.label.attribute?
-    & db.area.coords.attribute
-  db.area =
-    
-    ## A region defined for a callout in a graphic or code example
-    element area { db.area.attlist, db.alt? }
-}
-div {
-  # The only difference is that xml:id is optional
-  db.area.inareaset.attlist =
-    db.area.role.attribute?
-    & db.common.attributes
-    & db.area.units.attribute
-    & (db.area.linkends.attribute | db.xlink.simple.link.attributes)?
-    & db.area.label.attribute?
-    & db.area.coords.attribute
-  db.area.inareaset =
-    
-    ## A region defined for a callout in a graphic or code example
-    element area { db.area.inareaset.attlist, db.alt? }
-}
-div {
-  db.areaset.role.attribute = attribute role { text }
-  db.areaset.linkends.attribute = db.linkends.attribute
-  db.areaset.label.attribute = db.label.attribute
-  db.areaset.attlist =
-    db.areaset.role.attribute?
-    & db.common.idreq.attributes
-    & db.area.units.attribute
-    & (db.areaset.linkends.attribute | db.xlink.simple.link.attributes)?
-    & db.areaset.label.attribute?
-  db.areaset =
-    
-    ## A set of related areas in a graphic or code example
-    element areaset { db.areaset.attlist, db.area.inareaset+ }
-}
-div {
-  db.screenco.role.attribute = attribute role { text }
-  db.screenco.attlist =
-    db.screenco.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.screenco.info = db._info.title.forbidden
-  db.screenco =
-    
-    ## A screen with associated areas used in callouts
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:screenco"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element screenco {
-      db.screenco.attlist,
-      db.screenco.info,
-      db.areaspec,
-      db.screen,
-      db.calloutlist*
-    }
-}
-div {
-  db.imageobjectco.role.attribute = attribute role { text }
-  db.imageobjectco.attlist =
-    db.imageobjectco.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.imageobjectco.info = db._info.title.forbidden
-  db.imageobjectco =
-    
-    ## A wrapper for an image object with callouts
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:imageobjectco"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element imageobjectco {
-      db.imageobjectco.attlist,
-      db.imageobjectco.info,
-      db.areaspec,
-      db.imageobject+,
-      db.calloutlist*
-    }
-}
-div {
-  db.co.role.attribute = attribute role { text }
-  db.co.linkends.attribute = db.linkends.attribute
-  db.co.label.attribute = db.label.attribute
-  db.co.attlist =
-    db.co.role.attribute?
-    & db.common.idreq.attributes
-    & db.co.linkends.attribute?
-    & db.co.label.attribute?
-  db.co =
-    
-    ## The location of a callout embedded in text
-    element co { db.co.attlist, empty }
-}
-div {
-  db.coref.role.attribute = attribute role { text }
-  db.coref.label.attribute = db.label.attribute
-  db.coref.attlist =
-    db.coref.role.attribute?
-    & db.common.attributes
-    & db.linkend.attribute
-    & db.coref.label.attribute?
-  db.coref =
-    
-    ## A cross reference to a co
-    element coref { db.coref.attlist, empty }
-}
-div {
-  db.productionset.role.attribute = attribute role { text }
-  db.productionset.attlist =
-    db.productionset.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.productionset.info = db._info.title.only
-  db.productionset =
-    
-    ## A set of EBNF productions
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:productionset"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element productionset {
-      db.productionset.attlist,
-      db.productionset.info,
-      (db.production | db.productionrecap)+
-    }
-}
-div {
-  db.production.role.attribute = attribute role { text }
-  db.production.attlist =
-    db.production.role.attribute?
-    & db.common.idreq.attributes
-    & db.common.linking.attributes
-  db.production =
-    
-    ## A production in a set of EBNF productions
-    element production {
-      db.production.attlist, db.lhs, db.rhs+, db.constraint*
-    }
-}
-div {
-  db.lhs.role.attribute = attribute role { text }
-  db.lhs.attlist =
-    db.lhs.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.lhs =
-    
-    ## The left-hand side of an EBNF production
-    element lhs { db.lhs.attlist, text }
-}
-div {
-  db.rhs.role.attribute = attribute role { text }
-  db.rhs.attlist =
-    db.rhs.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.rhs =
-    
-    ## The right-hand side of an EBNF production
-    element rhs {
-      db.rhs.attlist,
-      (text | db.nonterminal | db.lineannotation | db.sbr)*
-    }
-}
-div {
-  db.nonterminal.role.attribute = attribute role { text }
-  db.nonterminal.def.attribute =
-    
-    ## Specifies a URI that points to a production
-    ## where the nonterminal
-    ##  is defined
-    attribute def { xsd:anyURI }
-  db.nonterminal.attlist =
-    db.nonterminal.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.nonterminal.def.attribute
-  db.nonterminal =
-    
-    ## A non-terminal in an EBNF production
-    element nonterminal { db.nonterminal.attlist, text }
-}
-div {
-  db.constraint.role.attribute = attribute role { text }
-  db.constraint.attlist =
-    db.constraint.role.attribute?
-    & db.common.attributes
-    & db.common.req.linking.attributes
-  db.constraint =
-    
-    ## A constraint in an EBNF production
-    element constraint { db.constraint.attlist, empty }
-}
-div {
-  db.productionrecap.role.attribute = attribute role { text }
-  db.productionrecap.attlist =
-    db.productionrecap.role.attribute?
-    & db.common.attributes
-    & db.common.req.linking.attributes
-  db.productionrecap =
-    
-    ## A cross-reference to an EBNF production
-    element productionrecap { db.productionrecap.attlist, empty }
-}
-div {
-  db.constraintdef.role.attribute = attribute role { text }
-  db.constraintdef.attlist =
-    db.constraintdef.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.constraintdef.info = db._info.title.only
-  db.constraintdef =
-    
-    ## The definition of a constraint in an EBNF production
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:constraintdef"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element constraintdef {
-      db.constraintdef.attlist, db.constraintdef.info, db.all.blocks+
-    }
-}
-db.char.attribute =
-  
-  ## Specifies the alignment character when align
-  ##  is set to char
-  ## .
-  attribute char { text }
-db.charoff.attribute =
-  
-  ## Specifies the percentage of the column's total width that should appear to the left of the first occurance of the character identified in char
-  ##  when align
-  ##  is set to char
-  ## .
-  attribute charoff {
-    xsd:decimal { minExclusive = "0" maxExclusive = "100" }
-  }
-db.frame.attribute =
-  
-  ## Specifies how the table is to be framed. Note that there is no way to obtain a border on only the starting edge (left, in left-to-right writing systems) of the table.
-  attribute frame {
-    
-    ## Frame all four sides of the table. In some environments with limited control over table border formatting, such as HTML, this may imply additional borders.
-    "all"
-    | 
-      ## Frame only the bottom of the table.
-      "bottom"
-    | 
-      ## Place no border on the table. In some environments with limited control over table border formatting, such as HTML, this may disable other borders as well.
-      "none"
-    | 
-      ## Frame the left and right sides of the table.
-      "sides"
-    | 
-      ## Frame the top of the table.
-      "top"
-    | 
-      ## Frame the top and bottom of the table.
-      "topbot"
-  }
-db.colsep.attribute =
-  
-  ## Specifies the presence or absence of the column separator
-  attribute colsep {
-    
-    ## No column separator rule.
-    "0"
-    | 
-      ## Provide a column separator rule on the right
-      "1"
-  }
-db.rowsep.attribute =
-  
-  ## Specifies the presence or absence of the row separator
-  attribute rowsep {
-    
-    ## No row separator rule.
-    "0"
-    | 
-      ## Provide a row separator rule below
-      "1"
-  }
-db.orient.attribute =
-  
-  ## Specifies the orientation of the table
-  attribute orient {
-    
-    ## 90 degrees counter-clockwise from the rest of the text flow.
-    "land"
-    | 
-      ## The same orientation as the rest of the text flow.
-      "port"
-  }
-db.tabstyle.attribute =
-  
-  ## Specifies the table style
-  attribute tabstyle { text }
-db.rowheader.attribute =
-  
-  ## Indicates whether or not the entries in the first column should be considered row headers
-  attribute rowheader {
-    
-    ## Indicates that entries in the first column of the table are functionally row headers (analogous to the way that a thead provides column headers).
-    "firstcol"
-    | 
-      ## Indicates that entries in the first column have no special significance with respect to column headers.
-      "norowheader"
-  }
-db.align.attribute =
-  
-  ## Specifies the horizontal alignment of text in an entry.
-  attribute align {
-    
-    ## Centered.
-    "center"
-    | 
-      ## Aligned on a particular character.
-      "char"
-    | 
-      ## Left and right justified.
-      "justify"
-    | 
-      ## Left justified.
-      "left"
-    | 
-      ## Right justified.
-      "right"
-  }
-db.valign.attribute =
-  
-  ## Specifies the vertical alignment of text in an entry.
-  attribute valign {
-    
-    ## Aligned on the bottom of the entry.
-    "bottom"
-    | 
-      ## Aligned in the middle.
-      "middle"
-    | 
-      ## Aligned at the top of the entry.
-      "top"
-  }
-db.specify-col-by-colname.attributes =
-  
-  ## Specifies a column specification by name.
-  attribute colname { text }
-db.specify-col-by-namest.attributes =
-  
-  ## Specifies a starting column by name.
-  attribute namest { text }
-db.specify-span-by-spanspec.attributes =
-  
-  ## Specifies a span by name.
-  attribute spanname { text }
-db.specify-span-directly.attributes =
-  
-  ## Specifies a starting column by name.
-  attribute namest { text }
-  & 
-    ## Specifies an ending column by name.
-    attribute nameend { text }
-db.column-spec.attributes =
-  db.specify-col-by-colname.attributes
-  | db.specify-col-by-namest.attributes
-  | db.specify-span-by-spanspec.attributes
-  | db.specify-span-directly.attributes
-db.colname.attribute =
-  
-  ## Provides a name for a column specification.
-  attribute colname { text }
-db.spanname.attribute =
-  
-  ## Provides a name for a span specification.
-  attribute spanname { text }
-div {
-  db.tgroup.role.attribute = attribute role { text }
-  db.tgroup.tgroupstyle.attribute =
-    
-    ## Additional style information for downstream processing; typically the name of a style.
-    attribute tgroupstyle { text }
-  db.tgroup.cols.attribute =
-    
-    ## The number of columns in the table. Must be an integer greater than zero.
-    attribute cols { xsd:positiveInteger }
-  db.tgroup.attlist =
-    db.tgroup.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.char.attribute?
-    & db.charoff.attribute?
-    & db.tgroup.tgroupstyle.attribute?
-    & db.tgroup.cols.attribute
-    & db.colsep.attribute?
-    & db.rowsep.attribute?
-    & db.align.attribute?
-  db.tgroup =
-    
-    ## A wrapper for the main content of a table, or part of a table
-    element tgroup {
-      db.tgroup.attlist,
-      db.colspec*,
-      db.spanspec*,
-      db.cals.thead?,
-      db.cals.tfoot?,
-      db.cals.tbody
-    }
-}
-div {
-  db.colspec.role.attribute = attribute role { text }
-  db.colspec.colnum.attribute =
-    
-    ## The number of the column to which this specification applies. Must be greater than any preceding column number. Defaults to one more than the number of the preceding column, if there is one, or one.
-    attribute colnum { xsd:positiveInteger }
-  db.colspec.colwidth.attribute =
-    
-    ## Specifies the width of the column.
-    attribute colwidth { text }
-  db.colspec.attlist =
-    db.colspec.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.colspec.colnum.attribute?
-    & db.char.attribute?
-    & db.colsep.attribute?
-    & db.colspec.colwidth.attribute?
-    & db.charoff.attribute?
-    & db.colname.attribute?
-    & db.rowsep.attribute?
-    & db.align.attribute?
-  db.colspec =
-    
-    ## Specifications for a column in a table
-    element colspec { db.colspec.attlist, empty }
-}
-div {
-  db.spanspec.role.attribute = attribute role { text }
-  db.spanspec.namest.attribute =
-    
-    ## Specifies a starting column by name.
-    attribute namest { text }
-  db.spanspec.nameend.attribute =
-    
-    ## Specifies an ending column by name.
-    attribute nameend { text }
-  db.spanspec.attlist =
-    db.spanspec.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.spanname.attribute
-    & db.spanspec.namest.attribute
-    & db.spanspec.nameend.attribute
-    & db.char.attribute?
-    & db.colsep.attribute?
-    & db.charoff.attribute?
-    & db.rowsep.attribute?
-    & db.align.attribute?
-  db.spanspec =
-    
-    ## Formatting information for a spanned column in a table
-    element spanspec { db.spanspec.attlist, empty }
-}
-div {
-  db.cals.thead.role.attribute = attribute role { text }
-  db.cals.thead.attlist =
-    db.cals.thead.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.valign.attribute?
-  db.cals.thead =
-    
-    ## A table header consisting of one or more rows
-    element thead { db.cals.thead.attlist, db.colspec*, db.row+ }
-}
-div {
-  db.cals.tfoot.role.attribute = attribute role { text }
-  db.cals.tfoot.attlist =
-    db.cals.tfoot.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.valign.attribute?
-  db.cals.tfoot =
-    
-    ## A table footer consisting of one or more rows
-    element tfoot { db.cals.tfoot.attlist, db.colspec*, db.row+ }
-}
-div {
-  db.cals.tbody.role.attribute = attribute role { text }
-  db.cals.tbody.attlist =
-    db.cals.tbody.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.valign.attribute?
-  db.cals.tbody =
-    
-    ## A wrapper for the rows of a table or informal table
-    element tbody { db.cals.tbody.attlist, db.row+ }
-}
-div {
-  db.row.role.attribute = attribute role { text }
-  db.row.attlist =
-    db.row.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.rowsep.attribute?
-    & db.valign.attribute?
-  db.row =
-    
-    ## A row in a table
-    element row { db.row.attlist, (db.entry | db.entrytbl)+ }
-}
-div {
-  db.entry.role.attribute = attribute role { text }
-  db.entry.morerows.attribute =
-    
-    ## Specifies the number of additional rows which this entry occupies. Defaults to zero.
-    attribute morerows { xsd:integer }
-  db.entry.rotate.attribute =
-    
-    ## Specifies the rotation of this entry. A value of 1 (true) rotates the cell 90 degrees counter-clockwise. A value of 0 (false) leaves the cell unrotated.
-    attribute rotate {
-      
-      ## Do not rotate the cell.
-      "0"
-      | 
-        ## Rotate the cell 90 degrees counter-clockwise.
-        "1"
-    }
-  db.entry.attlist =
-    db.entry.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.valign.attribute?
-    & db.char.attribute?
-    & db.colsep.attribute?
-    & db.charoff.attribute?
-    & db.entry.morerows.attribute?
-    & db.column-spec.attributes?
-    & db.rowsep.attribute?
-    & db.entry.rotate.attribute?
-    & db.align.attribute?
-  db.entry =
-    
-    ## A cell in a table
-    [
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:entry"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:table)"
-            "table must not occur among the children or descendants of entry"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:entry"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:informaltable)"
-            "informaltable must not occur among the children or descendants of entry"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element entry {
-      db.entry.attlist, (db.all.inlines* | db.all.blocks*)
-    }
-}
-div {
-  db.entrytbl.role.attribute = attribute role { text }
-  db.entrytbl.tgroupstyle.attribute =
-    
-    ## Additional style information for downstream processing; typically the name of a style.
-    attribute tgroupstyle { text }
-  db.entrytbl.cols.attribute =
-    
-    ## The number of columns in the entry table. Must be an integer greater than zero.
-    attribute cols { xsd:positiveInteger }
-  db.entrytbl.attlist =
-    db.entrytbl.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.char.attribute?
-    & db.charoff.attribute?
-    & db.column-spec.attributes?
-    & db.entrytbl.tgroupstyle.attribute?
-    & db.entrytbl.cols.attribute?
-    & db.colsep.attribute?
-    & db.rowsep.attribute?
-    & db.align.attribute?
-  db.entrytbl =
-    
-    ## A subtable appearing in place of an entry in a table
-    element entrytbl {
-      db.entrytbl.attlist,
-      db.colspec*,
-      db.spanspec*,
-      db.cals.entrytbl.thead?,
-      db.cals.entrytbl.tbody
-    }
-}
-div {
-  db.cals.entrytbl.thead.role.attribute = attribute role { text }
-  db.cals.entrytbl.thead.attlist =
-    db.cals.entrytbl.thead.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.valign.attribute?
-  db.cals.entrytbl.thead =
-    
-    ## A table header consisting of one or more rows
-    element thead {
-      db.cals.entrytbl.thead.attlist, db.colspec*, db.entrytbl.row+
-    }
-}
-div {
-  db.cals.entrytbl.tbody.role.attribute = attribute role { text }
-  db.cals.entrytbl.tbody.attlist =
-    db.cals.entrytbl.tbody.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.valign.attribute?
-  db.cals.entrytbl.tbody =
-    
-    ## A wrapper for the rows of a table or informal table
-    element tbody { db.cals.entrytbl.tbody.attlist, db.entrytbl.row+ }
-}
-div {
-  db.entrytbl.row.role.attribute = attribute role { text }
-  db.entrytbl.row.attlist =
-    db.entrytbl.row.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.rowsep.attribute?
-    & db.valign.attribute?
-  db.entrytbl.row =
-    
-    ## A row in a table
-    element row { db.entrytbl.row.attlist, db.entry+ }
-}
-div {
-  db.cals.table.role.attribute = attribute role { text }
-  db.cals.table.label.attribute = db.label.attribute
-  db.cals.table.attlist =
-    db.cals.table.role.attribute?
-    & db.cals.table.label.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.tabstyle.attribute?
-    & db.floatstyle.attribute?
-    & db.orient.attribute?
-    & db.colsep.attribute?
-    & db.rowsep.attribute?
-    & db.frame.attribute?
-    & db.pgwide.attribute?
-    & 
-      ## Indicates if the short or long title should be used in a List of Tables
-      attribute shortentry {
-        
-        ## Indicates that the full title should be used.
-        "0"
-        | 
-          ## Indicates that the short short title (titleabbrev) should be used.
-          "1"
-      }?
-    & 
-      ## Indicates if the table should appear in a List of Tables
-      attribute tocentry {
-        
-        ## Indicates that the table should not occur in the List of Tables.
-        "0"
-        | 
-          ## Indicates that the table should appear in the List of Tables.
-          "1"
-      }?
-    & db.rowheader.attribute?
-  db.cals.table.info = db._info.title.onlyreq
-  db.cals.table =
-    
-    ## A formal table in a document
-    [
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:table"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:example)"
-            "example must not occur among the children or descendants of table"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:table"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:figure)"
-            "figure must not occur among the children or descendants of table"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:table"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:equation)"
-            "equation must not occur among the children or descendants of table"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:table"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:caution)"
-            "caution must not occur among the children or descendants of table"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:table"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:important)"
-            "important must not occur among the children or descendants of table"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:table"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:note)"
-            "note must not occur among the children or descendants of table"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:table"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:tip)"
-            "tip must not occur among the children or descendants of table"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:table"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:warning)"
-            "warning must not occur among the children or descendants of table"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:table"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element table {
-      db.cals.table.attlist,
-      db.cals.table.info,
-      (db.alt? & db.indexing.inlines* & db.textobject*),
-      (db.mediaobject+ | db.tgroup+),
-      db.caption?
-    }
-}
-div {
-  db.cals.informaltable.role.attribute = attribute role { text }
-  db.cals.informaltable.attlist =
-    db.cals.informaltable.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.tabstyle.attribute?
-    & db.floatstyle.attribute?
-    & db.orient.attribute?
-    & db.colsep.attribute?
-    & db.rowsep.attribute?
-    & db.frame.attribute?
-    & db.pgwide.attribute?
-    & db.rowheader.attribute?
-  db.cals.informaltable.info = db._info.title.forbidden
-  db.cals.informaltable =
-    
-    ## A table without a title
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:informaltable"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element informaltable {
-      db.cals.informaltable.attlist,
-      db.cals.informaltable.info,
-      (db.alt? & db.indexing.inlines* & db.textobject*),
-      (db.mediaobject+ | db.tgroup+),
-      db.caption?
-    }
-}
-db.html.coreattrs =
-  
-  ## This attribute assigns a class name or set of class names to an element. Any number of elements may be assigned the same class name or names. Multiple class names must be separated by white space characters.
-  attribute class { text }?
-  & 
-    ## This attribute specifies style information for the current element.
-    attribute style { text }?
-  & 
-    ## This attribute offers advisory information about the element for which it is set.
-    attribute title { text }?
-db.html.i18n =
-  
-  ## This attribute specifies the base language of an element's attribute values and text content. The default value of this attribute is unknown.
-  attribute lang { text }?
-db.html.events =
-  
-  ## Occurs when the pointing device button is clicked over an element.
-  attribute onclick { text }?
-  & 
-    ## Occurs when the pointing device button is double clicked over an element.
-    attribute ondblclick { text }?
-  & 
-    ## Occurs when the pointing device button is pressed over an element.
-    attribute onmousedown { text }?
-  & 
-    ## Occurs when the pointing device button is released over an element.
-    attribute onmouseup { text }?
-  & 
-    ## Occurs when the pointing device is moved onto an element.
-    attribute onmouseover { text }?
-  & 
-    ## Occurs when the pointing device is moved while it is over an element.
-    attribute onmousemove { text }?
-  & 
-    ## Occurs when the pointing device is moved away from an element.
-    attribute onmouseout { text }?
-  & 
-    ## Occurs when a key is pressed and released over an element.
-    attribute onkeypress { text }?
-  & 
-    ## Occurs when a key is pressed down over an element.
-    attribute onkeydown { text }?
-  & 
-    ## Occurs when a key is released over an element.
-    attribute onkeyup { text }?
-db.html.attrs =
-  db.common.attributes
-  & db.html.coreattrs
-  & db.html.i18n
-  & db.html.events
-db.html.cellhalign =
-  
-  ## Specifies the alignment of data and the justification of text in a cell.
-  attribute align {
-    
-    ## Left-flush data/Left-justify text. This is the default value for table data.
-    "left"
-    | 
-      ## Center data/Center-justify text. This is the default value for table headers.
-      "center"
-    | 
-      ## Right-flush data/Right-justify text.
-      "right"
-    | 
-      ## Double-justify text.
-      "justify"
-    | 
-      ## Align text around a specific character. If a user agent doesn't support character alignment, behavior in the presence of this value is unspecified.
-      "char"
-  }?
-  & 
-    ## This attribute specifies a single character within a text fragment to act as an axis for alignment. The default value for this attribute is the decimal point character for the current language as set by the lang attribute (e.g., the period in English and the comma in French). User agents are not required to support this attribute.
-    attribute char { text }?
-  & 
-    ## When present, this attribute specifies the offset to the first occurrence of the alignment character on each line. If a line doesn't include the alignment character, it should be horizontally shifted to end at the alignment position. When charoff is used to set the offset of an alignment character, the direction of offset is determined by the current text direction (set by the dir attribute). In left-to-right texts (the default), offset is from the left margin. In right-to-left texts, offset is from the right margin. User agents are not required to support this attribute.
-    attribute charoff {
-      xsd:integer >> a:documentation [ "An explicit offset." ]
-      | xsd:string { pattern = "[0-9]+%" }
-        >> a:documentation [ "A percentage offset." ]
-    }?
-db.html.cellvalign =
-  
-  ## Specifies the vertical position of data within a cell.
-  attribute valign {
-    
-    ## Cell data is flush with the top of the cell.
-    "top"
-    | 
-      ## Cell data is centered vertically within the cell. This is the default value.
-      "middle"
-    | 
-      ## Cell data is flush with the bottom of the cell.
-      "bottom"
-    | 
-      ## All cells in the same row as a cell whose valign attribute has this value should have their textual data positioned so that the first text line occurs on a baseline common to all cells in the row. This constraint does not apply to subsequent text lines in these cells.
-      "baseline"
-  }?
-db.html.table.attributes =
-  
-  ## Provides a summary of the table's purpose and structure for user agents rendering to non-visual media such as speech and Braille.
-  attribute summary { text }?
-  & 
-    ## Specifies the desired width of the entire table and is intended for visual user agents. When the value is a percentage value, the value is relative to the user agent's available horizontal space. In the absence of any width specification, table width is determined by the user agent.
-    attribute width {
-      xsd:integer >> a:documentation [ "An explicit width." ]
-      | xsd:string { pattern = "[0-9]+%" }
-        >> a:documentation [ "A percentage width." ]
-    }?
-  & 
-    ## Specifies the width (in pixels only) of the frame around a table.
-    attribute border { xsd:nonNegativeInteger }?
-  & 
-    ## Specifies which sides of the frame surrounding a table will be visible.
-    attribute frame {
-      
-      ## No sides. This is the default value.
-      "void"
-      | 
-        ## The top side only.
-        "above"
-      | 
-        ## The bottom side only.
-        "below"
-      | 
-        ## The top and bottom sides only.
-        "hsides"
-      | 
-        ## The left-hand side only.
-        "lhs"
-      | 
-        ## The right-hand side only.
-        "rhs"
-      | 
-        ## The right and left sides only.
-        "vsides"
-      | 
-        ## All four sides.
-        "box"
-      | 
-        ## All four sides.
-        "border"
-    }?
-  & 
-    ## Specifies which rules will appear between cells within a table. The rendering of rules is user agent dependent.
-    attribute rules {
-      
-      ## No rules. This is the default value.
-      "none"
-      | 
-        ## Rules will appear between row groups (see thead, tfoot, and tbody) and column groups (see colgroup and col) only.
-        "groups"
-      | 
-        ## Rules will appear between rows only.
-        "rows"
-      | 
-        ## Rules will appear between columns only.
-        "cols"
-      | 
-        ## Rules will appear between all rows and columns.
-        "all"
-    }?
-  & 
-    ## Specifies how much space the user agent should leave between the left side of the table and the left-hand side of the leftmost column, the top of the table and the top side of the topmost row, and so on for the right and bottom of the table. The attribute also specifies the amount of space to leave between cells.
-    attribute cellspacing {
-      xsd:integer >> a:documentation [ "An explicit spacing." ]
-      | xsd:string { pattern = "[0-9]+%" }
-        >> a:documentation [ "A percentage spacing." ]
-    }?
-  & 
-    ## Specifies the amount of space between the border of the cell and its contents. If the value of this attribute is a pixel length, all four margins should be this distance from the contents. If the value of the attribute is a percentage length, the top and bottom margins should be equally separated from the content based on a percentage of the available vertical space, and the left and right margins should be equally separated from the content based on a percentage of the available horizontal space.
-    attribute cellpadding {
-      xsd:integer >> a:documentation [ "An explicit padding." ]
-      | xsd:string { pattern = "[0-9]+%" }
-        >> a:documentation [ "A percentage padding." ]
-    }?
-db.html.tablecell.attributes =
-  
-  ## Provides an abbreviated form of the cell's content and may be rendered by user agents when appropriate in place of the cell's content. Abbreviated names should be short since user agents may render them repeatedly. For instance, speech synthesizers may render the abbreviated headers relating to a particular cell before rendering that cell's content.
-  attribute abbr { text }?
-  & 
-    ## This attribute may be used to place a cell into conceptual categories that can be considered to form axes in an n-dimensional space. User agents may give users access to these categories (e.g., the user may query the user agent for all cells that belong to certain categories, the user agent may present a table in the form of a table of contents, etc.). Please consult an HTML reference for more details.
-    attribute axis { text }?
-  & 
-    ## Specifies the list of header cells that provide header information for the current data cell. The value of this attribute is a space-separated list of cell names; those cells must be named by setting their id attribute. Authors generally use the headers attribute to help non-visual user agents render header information about data cells (e.g., header information is spoken prior to the cell data), but the attribute may also be used in conjunction with style sheets.
-    attribute headers { text }?
-  & 
-    ## Specifies the set of data cells for which the current header cell provides header information. This attribute may be used in place of the headers attribute, particularly for simple tables.
-    attribute scope {
-      
-      ## The current cell provides header information for the rest of the row that contains it
-      "row"
-      | 
-        ## The current cell provides header information for the rest of the column that contains it.
-        "col"
-      | 
-        ## The header cell provides header information for the rest of the row group that contains it.
-        "rowgroup"
-      | 
-        ## The header cell provides header information for the rest of the column group that contains it.
-        "colgroup"
-    }?
-  & 
-    ## Specifies the number of rows spanned by the current cell. The default value of this attribute is one (1
-    ## ). The value zero (0
-    ## ) means that the cell spans all rows from the current row to the last row of the table section (thead
-    ## , tbody
-    ## , or tfoot
-    ## ) in which the cell is defined.
-    attribute rowspan { xsd:nonNegativeInteger }?
-  & 
-    ## Specifies the number of columns spanned by the current cell. The default value of this attribute is one (1
-    ## ). The value zero (0
-    ## ) means that the cell spans all columns from the current column to the last column of the column group (colgroup
-    ## ) in which the cell is defined.
-    attribute colspan { xsd:nonNegativeInteger }?
-db.html.table.info = db._info.title.forbidden
-db.html.table.model =
-  db.html.table.info?,
-  db.html.caption,
-  (db.html.col* | db.html.colgroup*),
-  db.html.thead?,
-  db.html.tfoot?,
-  (db.html.tbody+ | db.html.tr+)
-db.html.informaltable.info = db._info.title.forbidden
-db.html.informaltable.model =
-  db.html.informaltable.info?,
-  (db.html.col* | db.html.colgroup*),
-  db.html.thead?,
-  db.html.tfoot?,
-  (db.html.tbody+ | db.html.tr+)
-div {
-  db.html.table.role.attribute = attribute role { text }
-  db.html.table.label.attribute = db.label.attribute
-  db.html.table.attlist =
-    db.html.attrs
-    & db.html.table.attributes
-    & db.html.table.role.attribute?
-    & db.html.table.label.attribute?
-    & db.orient.attribute?
-    & db.pgwide.attribute?
-    & db.tabstyle.attribute?
-    & db.floatstyle.attribute?
-  db.html.table =
-    
-    ## A formal (captioned) HTML table in a document
-    [
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:table"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:example)"
-            "example must not occur among the children or descendants of table"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:table"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:figure)"
-            "figure must not occur among the children or descendants of table"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:table"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:equation)"
-            "equation must not occur among the children or descendants of table"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:table"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:caution)"
-            "caution must not occur among the children or descendants of table"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:table"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:important)"
-            "important must not occur among the children or descendants of table"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:table"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:note)"
-            "note must not occur among the children or descendants of table"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:table"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:tip)"
-            "tip must not occur among the children or descendants of table"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:table"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:warning)"
-            "warning must not occur among the children or descendants of table"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:table"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element table { db.html.table.attlist, db.html.table.model }
-}
-div {
-  db.html.informaltable.role.attribute = attribute role { text }
-  db.html.informaltable.label.attribute = db.label.attribute
-  db.html.informaltable.attlist =
-    db.html.attrs
-    & db.html.table.attributes
-    & db.html.informaltable.role.attribute?
-    & db.html.informaltable.label.attribute?
-    & db.orient.attribute?
-    & db.pgwide.attribute?
-    & db.tabstyle.attribute?
-    & db.floatstyle.attribute?
-  db.html.informaltable =
-    
-    ## An HTML table without a title
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:informaltable"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element informaltable {
-      db.html.informaltable.attlist, db.html.informaltable.model
-    }
-}
-div {
-  db.html.caption.attlist = db.html.attrs
-  db.html.caption =
-    
-    ## An HTML table caption
-    [
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:caption"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:example)"
-            "example must not occur among the children or descendants of caption"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:caption"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:figure)"
-            "figure must not occur among the children or descendants of caption"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:caption"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:table)"
-            "table must not occur among the children or descendants of caption"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:caption"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:equation)"
-            "equation must not occur among the children or descendants of caption"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:caption"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:sidebar)"
-            "sidebar must not occur among the children or descendants of caption"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:caption"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:task)"
-            "task must not occur among the children or descendants of caption"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:caption"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:caution)"
-            "caution must not occur among the children or descendants of caption"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:caption"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:important)"
-            "important must not occur among the children or descendants of caption"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:caption"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:note)"
-            "note must not occur among the children or descendants of caption"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:caption"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:tip)"
-            "tip must not occur among the children or descendants of caption"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:caption"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:warning)"
-            "warning must not occur among the children or descendants of caption"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:caption"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element caption { db.html.caption.attlist, db.all.inlines* }
-}
-div {
-  db.html.col.attlist =
-    db.html.attrs
-    & 
-      ## This attribute, whose value must be an integer > 0, specifies the number of columns spanned
-      ##  by the col
-      ##  element; the col
-      ##  element shares its attributes with all the columns it spans. The default value for this attribute is 1 (i.e., a single column). If the span attribute is set to N > 1, the current col
-      ##  element shares its attributes with the next N-1 columns.
-      attribute span { xsd:nonNegativeInteger }?
-    & 
-      ## Specifies a default width for each column spanned by the current col
-      ##  element. It has the same meaning as the width
-      ##  attribute for the colgroup
-      ##  element and overrides it.
-      attribute width { text }?
-    & db.html.cellhalign
-    & db.html.cellvalign
-  db.html.col =
-    
-    ## Specifications for a column in an HTML table
-    element col { db.html.col.attlist, empty }
-}
-div {
-  db.html.colgroup.attlist =
-    db.html.attrs
-    & 
-      ## This attribute, which must be an integer > 0, specifies the number of columns in a column group. In the absence of a span attribute, each colgroup
-      ##  defines a column group containing one column. If the span attribute is set to N > 0, the current colgroup
-      ##  element defines a column group containing N columns. User agents must ignore this attribute if the colgroup
-      ##  element contains one or more col
-      ##  elements.
-      attribute span { xsd:nonNegativeInteger }?
-    & 
-      ## This attribute specifies a default width for each column in the current column group. In addition to the standard pixel, percentage, and relative values, this attribute allows the special form 0*
-      ##  (zero asterisk) which means that the width of the each column in the group should be the minimum width necessary to hold the column's contents. This implies that a column's entire contents must be known before its width may be correctly computed. Authors should be aware that specifying 0*
-      ##  will prevent visual user agents from rendering a table incrementally. This attribute is overridden for any column in the column group whose width is specified via a col
-      ##  element.
-      attribute width { text }?
-    & db.html.cellhalign
-    & db.html.cellvalign
-  db.html.colgroup =
-    
-    ## A group of columns in an HTML table
-    element colgroup { db.html.colgroup.attlist, db.html.col* }
-}
-div {
-  db.html.thead.attlist =
-    db.html.attrs & db.html.cellhalign & db.html.cellvalign
-  db.html.thead =
-    
-    ## A table header consisting of one or more rows in an HTML table
-    element thead { db.html.thead.attlist, db.html.tr+ }
-}
-div {
-  db.html.tfoot.attlist =
-    db.html.attrs & db.html.cellhalign & db.html.cellvalign
-  db.html.tfoot =
-    
-    ## A table footer consisting of one or more rows in an HTML table
-    element tfoot { db.html.tfoot.attlist, db.html.tr+ }
-}
-div {
-  db.html.tbody.attlist =
-    db.html.attrs & db.html.cellhalign & db.html.cellvalign
-  db.html.tbody =
-    
-    ## A wrapper for the rows of an HTML table or informal HTML table
-    element tbody { db.html.tbody.attlist, db.html.tr+ }
-}
-div {
-  db.html.tr.attlist =
-    db.html.attrs & db.html.cellhalign & db.html.cellvalign
-  db.html.tr =
-    
-    ## A row in an HTML table
-    element tr { db.html.tr.attlist, (db.html.th | db.html.td)+ }
-}
-div {
-  db.html.th.attlist =
-    db.html.attrs
-    & db.html.tablecell.attributes
-    & db.html.cellhalign
-    & db.html.cellvalign
-  db.html.th =
-    
-    ## A table header entry in an HTML table
-    element th {
-      db.html.th.attlist, (db.all.inlines* | db.all.blocks*)
-    }
-}
-div {
-  db.html.td.attlist =
-    db.html.attrs
-    & db.html.tablecell.attributes
-    & db.html.cellhalign
-    & db.html.cellvalign
-  db.html.td =
-    
-    ## A table entry in an HTML table
-    element td {
-      db.html.td.attlist, (db.all.inlines* | db.all.blocks*)
-    }
-}
-div {
-  db.msgset.role.attribute = attribute role { text }
-  db.msgset.attlist =
-    db.msgset.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.msgset.info = db._info.title.only
-  db.msgset =
-    
-    ## A detailed set of messages, usually error messages
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:msgset"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element msgset {
-      db.msgset.attlist,
-      db.msgset.info,
-      (db.msgentry+ | db.simplemsgentry+)
-    }
-}
-div {
-  db.msgentry.role.attribute = attribute role { text }
-  db.msgentry.attlist =
-    db.msgentry.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.msgentry =
-    
-    ## A wrapper for an entry in a message set
-    element msgentry {
-      db.msgentry.attlist, db.msg+, db.msginfo?, db.msgexplan*
-    }
-}
-div {
-  db.simplemsgentry.role.attribute = attribute role { text }
-  db.simplemsgentry.msgaud.attribute =
-    
-    ## The audience to which the message relevant
-    attribute msgaud { text }
-  db.simplemsgentry.msgorig.attribute =
-    
-    ## The origin of the message
-    attribute msgorig { text }
-  db.simplemsgentry.msglevel.attribute =
-    
-    ## The level of importance or severity of a message
-    attribute msglevel { text }
-  db.simplemsgentry.attlist =
-    db.simplemsgentry.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.simplemsgentry.msgaud.attribute?
-    & db.simplemsgentry.msgorig.attribute?
-    & db.simplemsgentry.msglevel.attribute?
-  db.simplemsgentry =
-    
-    ## A wrapper for a simpler entry in a message set
-    element simplemsgentry {
-      db.simplemsgentry.attlist, db.msgtext, db.msgexplan+
-    }
-}
-div {
-  db.msg.role.attribute = attribute role { text }
-  db.msg.attlist =
-    db.msg.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.msg.info = db._info.title.only
-  db.msg =
-    
-    ## A message in a message set
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:msg"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element msg {
-      db.msg.attlist, db.msg.info, db.msgmain, (db.msgsub | db.msgrel)*
-    }
-}
-div {
-  db.msgmain.role.attribute = attribute role { text }
-  db.msgmain.attlist =
-    db.msgmain.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.msgmain.info = db._info.title.only
-  db.msgmain =
-    
-    ## The primary component of a message in a message set 
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:msgmain"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element msgmain { db.msgmain.attlist, db.msgmain.info, db.msgtext }
-}
-div {
-  db.msgsub.role.attribute = attribute role { text }
-  db.msgsub.attlist =
-    db.msgsub.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.msgsub.info = db._info.title.only
-  db.msgsub =
-    
-    ## A subcomponent of a message in a message set
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:msgsub"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element msgsub { db.msgsub.attlist, db.msgsub.info, db.msgtext }
-}
-div {
-  db.msgrel.role.attribute = attribute role { text }
-  db.msgrel.attlist =
-    db.msgrel.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.msgrel.info = db._info.title.only
-  db.msgrel =
-    
-    ## A related component of a message in a message set
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:msgrel"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element msgrel { db.msgrel.attlist, db.msgrel.info, db.msgtext }
-}
-div {
-  db.msgtext.role.attribute = attribute role { text }
-  db.msgtext.attlist =
-    db.msgtext.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.msgtext =
-    
-    ## The actual text of a message component in a message set
-    element msgtext { db.msgtext.attlist, db.all.blocks+ }
-}
-div {
-  db.msginfo.role.attribute = attribute role { text }
-  db.msginfo.attlist =
-    db.msginfo.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.msginfo =
-    
-    ## Information about a message in a message set
-    element msginfo {
-      db.msginfo.attlist, (db.msglevel | db.msgorig | db.msgaud)*
-    }
-}
-div {
-  db.msglevel.role.attribute = attribute role { text }
-  db.msglevel.attlist =
-    db.msglevel.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.msglevel =
-    
-    ## The level of importance or severity of a message in a message set
-    element msglevel { db.msglevel.attlist, db._text }
-}
-div {
-  db.msgorig.role.attribute = attribute role { text }
-  db.msgorig.attlist =
-    db.msgorig.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.msgorig =
-    
-    ## The origin of a message in a message set
-    element msgorig { db.msgorig.attlist, db._text }
-}
-div {
-  db.msgaud.role.attribute = attribute role { text }
-  db.msgaud.attlist =
-    db.msgaud.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.msgaud =
-    
-    ## The audience to which a message in a message set is relevant
-    element msgaud { db.msgaud.attlist, db._text }
-}
-div {
-  db.msgexplan.role.attribute = attribute role { text }
-  db.msgexplan.attlist =
-    db.msgexplan.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.msgexplan.info = db._info.title.only
-  db.msgexplan =
-    
-    ## Explanatory material relating to a message in a message set
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:msgexplan"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element msgexplan {
-      db.msgexplan.attlist, db.msgexplan.info, db.all.blocks+
-    }
-}
-div {
-  db.qandaset.role.attribute = attribute role { text }
-  db.qandaset.defaultlabel.enumeration =
-    
-    ## No labels
-    "none"
-    | 
-      ## Numeric labels
-      "number"
-    | 
-      ## "Q:" and "A:" labels
-      "qanda"
-  db.qandaset.defaultlabel.attribute =
-    
-    ## Specifies the default labelling
-    attribute defaultlabel { db.qandaset.defaultlabel.enumeration }
-  db.qandaset.attlist =
-    db.qandaset.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.qandaset.defaultlabel.attribute?
-  db.qandaset.info = db._info.title.only
-  db.qandaset =
-    
-    ## A question-and-answer set
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:qandaset"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element qandaset {
-      db.qandaset.attlist,
-      db.qandaset.info,
-      db.all.blocks*,
-      (db.qandadiv+ | db.qandaentry+)
-    }
-}
-div {
-  db.qandadiv.role.attribute = attribute role { text }
-  db.qandadiv.attlist =
-    db.qandadiv.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.qandadiv.info = db._info.title.only
-  db.qandadiv =
-    
-    ## A titled division in a qandaset
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:qandadiv"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element qandadiv {
-      db.qandadiv.attlist,
-      db.qandadiv.info,
-      db.all.blocks*,
-      (db.qandadiv+ | db.qandaentry+)
-    }
-}
-div {
-  db.qandaentry.role.attribute = attribute role { text }
-  db.qandaentry.attlist =
-    db.qandaentry.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.qandaentry.info = db._info.title.only
-  db.qandaentry =
-    
-    ## A question/answer set within a qandaset
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:qandaentry"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element qandaentry {
-      db.qandaentry.attlist, db.qandaentry.info, db.question, db.answer*
-    }
-}
-div {
-  db.question.role.attribute = attribute role { text }
-  db.question.attlist =
-    db.question.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.question =
-    
-    ## A question in a qandaset
-    element question { db.question.attlist, db.label?, db.all.blocks+ }
-}
-div {
-  db.answer.role.attribute = attribute role { text }
-  db.answer.attlist =
-    db.answer.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.answer =
-    
-    ## An answer to a question posed in a qandaset
-    element answer { db.answer.attlist, db.label?, db.all.blocks+ }
-}
-div {
-  db.label.role.attribute = attribute role { text }
-  db.label.attlist =
-    db.label.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.label =
-    
-    ## A label on a question or answer
-    element label { db.label.attlist, db._text }
-}
-db.math.inlines = db.inlineequation
-db.equation.content = (db.mediaobject+ | db.mathphrase+) | db._any.mml+
-db.inlineequation.content =
-  (db.inlinemediaobject+ | db.mathphrase+) | db._any.mml+
-div {
-  db.equation.role.attribute = attribute role { text }
-  db.equation.label.attribute = db.label.attribute
-  db.equation.attlist =
-    db.equation.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.equation.label.attribute?
-    & db.pgwide.attribute?
-    & db.floatstyle.attribute?
-  db.equation.info = db._info.title.only
-  db.equation =
-    
-    ## A displayed mathematical equation
-    [
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:equation"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:example)"
-            "example must not occur among the children or descendants of equation"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:equation"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:figure)"
-            "figure must not occur among the children or descendants of equation"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:equation"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:table)"
-            "table must not occur among the children or descendants of equation"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:equation"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:equation)"
-            "equation must not occur among the children or descendants of equation"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:equation"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:caution)"
-            "caution must not occur among the children or descendants of equation"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:equation"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:important)"
-            "important must not occur among the children or descendants of equation"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:equation"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:note)"
-            "note must not occur among the children or descendants of equation"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:equation"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:tip)"
-            "tip must not occur among the children or descendants of equation"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:equation"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:warning)"
-            "warning must not occur among the children or descendants of equation"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:equation"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element equation {
-      db.equation.attlist,
-      db.equation.info,
-      db.alt?,
-      db.equation.content,
-      db.caption?
-    }
-}
-div {
-  db.informalequation.role.attribute = attribute role { text }
-  db.informalequation.attlist =
-    db.informalequation.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.pgwide.attribute?
-    & db.floatstyle.attribute?
-  db.informalequation.info = db._info.title.forbidden
-  db.informalequation =
-    
-    ## A displayed mathematical equation without a title
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:informalequation"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element informalequation {
-      db.informalequation.attlist,
-      db.informalequation.info,
-      db.alt?,
-      db.equation.content,
-      db.caption?
-    }
-}
-div {
-  db.inlineequation.role.attribute = attribute role { text }
-  db.inlineequation.attlist =
-    db.inlineequation.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.inlineequation =
-    
-    ## A mathematical equation or expression occurring inline
-    element inlineequation {
-      db.inlineequation.attlist, db.alt?, db.inlineequation.content
-    }
-}
-div {
-  db.mathphrase.role.attribute = attribute role { text }
-  db.mathphrase.attlist =
-    db.mathphrase.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.mathphrase =
-    
-    ## A mathematical phrase that can be represented with ordinary text and a small amount of markup
-    element mathphrase {
-      db.mathphrase.attlist,
-      (db._text | db.ubiq.inlines | db._emphasis)*
-    }
-}
-db.imagedata.mathml.content = db._any.mml
-div {
-  db.imagedata.mathml.role.attribute = attribute role { text }
-  db.imagedata.mathml.attlist =
-    db.imagedata.mathml.role.attribute?
-    & db.common.attributes
-    & 
-      ## Specifies that the format of the data is MathML
-      attribute format {
-        
-        ## Specifies MathML.
-        "mathml"
-      }?
-    & db.imagedata.align.attribute?
-    & db.imagedata.valign.attribute?
-    & db.imagedata.width.attribute?
-    & db.imagedata.contentwidth.attribute?
-    & db.imagedata.scalefit.attribute?
-    & db.imagedata.scale.attribute?
-    & db.imagedata.depth.attribute?
-    & db.imagedata.contentdepth.attribute?
-  db.imagedata.mathml.info = db._info.title.forbidden
-  db.imagedata.mathml =
-    
-    ## A MathML expression in a media object
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:imagedata"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element imagedata {
-      db.imagedata.mathml.attlist,
-      db.imagedata.mathml.info,
-      db.imagedata.mathml.content+
-    }
-}
-div {
-  db._any.mml =
-    
-    ## Any element from the MathML namespace
-    element mml:* { (db._any.attribute | text | db._any)* }
-}
-db.imagedata.svg.content = db._any.svg
-div {
-  db.imagedata.svg.role.attribute = attribute role { text }
-  db.imagedata.svg.attlist =
-    db.imagedata.svg.role.attribute?
-    & db.common.attributes
-    & 
-      ## Specifies that the format of the data is SVG
-      attribute format {
-        
-        ## Specifies SVG.
-        "svg"
-      }?
-    & db.imagedata.align.attribute?
-    & db.imagedata.valign.attribute?
-    & db.imagedata.width.attribute?
-    & db.imagedata.contentwidth.attribute?
-    & db.imagedata.scalefit.attribute?
-    & db.imagedata.scale.attribute?
-    & db.imagedata.depth.attribute?
-    & db.imagedata.contentdepth.attribute?
-  db.imagedata.svg.info = db._info.title.forbidden
-  db.imagedata.svg =
-    
-    ## An SVG drawing in a media object
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:imagedata"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element imagedata {
-      db.imagedata.svg.attlist,
-      db.imagedata.svg.info,
-      db.imagedata.svg.content+
-    }
-}
-div {
-  db._any.svg =
-    
-    ## Any element from the SVG namespace
-    element svg:* { (db._any.attribute | text | db._any)* }
-}
-db.markup.inlines =
-  db.tag
-  | db.markup
-  | db.token
-  | db.symbol
-  | db.literal
-  | db.code
-  | db.constant
-  | db.email
-  | db.uri
-div {
-  db.markup.role.attribute = attribute role { text }
-  db.markup.attlist =
-    db.markup.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.markup =
-    
-    ## A string of formatting markup in text that is to be represented literally
-    element markup { db.markup.attlist, db._text }
-}
-div {
-  db.tag.role.attribute = attribute role { text }
-  db.tag.class.enumeration =
-    
-    ## An attribute
-    "attribute"
-    | 
-      ## An attribute value
-      "attvalue"
-    | 
-      ## An element
-      "element"
-    | 
-      ## An empty element tag
-      "emptytag"
-    | 
-      ## An end tag
-      "endtag"
-    | 
-      ## A general entity
-      "genentity"
-    | 
-      ## The local name part of a qualified name
-      "localname"
-    | 
-      ## A namespace
-      "namespace"
-    | 
-      ## A numeric character reference
-      "numcharref"
-    | 
-      ## A parameter entity
-      "paramentity"
-    | 
-      ## A processing instruction
-      "pi"
-    | 
-      ## The prefix part of a qualified name
-      "prefix"
-    | 
-      ## An SGML comment
-      "comment"
-    | 
-      ## A start tag
-      "starttag"
-    | 
-      ## An XML processing instruction
-      "xmlpi"
-  db.tag.class.attribute =
-    
-    ## Identifies the nature of the tag content
-    attribute class { db.tag.class.enumeration }
-  db.tag.namespace.attribute =
-    
-    ## Identifies the namespace of the tag content
-    attribute namespace { xsd:anyURI }
-  db.tag.attlist =
-    db.tag.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.tag.class.attribute?
-    & db.tag.namespace.attribute?
-  db.tag =
-    
-    ## A component of XML (or SGML) markup
-    element tag { db.tag.attlist, (db._text | db.tag)* }
-}
-div {
-  db.symbol.class.attribute =
-    
-    ## Identifies the class of symbol
-    attribute class {
-      
-      ## The value is a limit of some kind
-      "limit"
-    }
-  db.symbol.role.attribute = attribute role { text }
-  db.symbol.attlist =
-    db.symbol.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.symbol.class.attribute?
-  db.symbol =
-    
-    ## A name that is replaced by a value before processing
-    element symbol { db.symbol.attlist, db._text }
-}
-div {
-  db.token.role.attribute = attribute role { text }
-  db.token.attlist =
-    db.token.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.token =
-    
-    ## A unit of information
-    element token { db.token.attlist, db._text }
-}
-div {
-  db.literal.role.attribute = attribute role { text }
-  db.literal.attlist =
-    db.literal.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.literal =
-    
-    ## Inline text that is some literal value
-    element literal { db.literal.attlist, db._text }
-}
-div {
-  code.language.attribute =
-    
-    ## Identifies the (computer) language of the code fragment
-    attribute language { text }
-  db.code.role.attribute = attribute role { text }
-  db.code.attlist =
-    db.code.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & code.language.attribute?
-  db.code =
-    
-    ## An inline code fragment
-    element code {
-      db.code.attlist, (db.programming.inlines | db._text)*
-    }
-}
-div {
-  db.constant.class.attribute =
-    
-    ## Identifies the class of constant
-    attribute class {
-      
-      ## The value is a limit of some kind
-      "limit"
-    }
-  db.constant.role.attribute = attribute role { text }
-  db.constant.attlist =
-    db.constant.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.constant.class.attribute?
-  db.constant =
-    
-    ## A programming or system constant
-    element constant { db.constant.attlist, db._text }
-}
-div {
-  db.productname.role.attribute = attribute role { text }
-  db.productname.class.enumeration =
-    
-    ## A name with a copyright
-    "copyright"
-    | 
-      ## A name with a registered copyright
-      "registered"
-    | 
-      ## A name of a service
-      "service"
-    | 
-      ## A name which is trademarked
-      "trade"
-  db.productname.class.attribute =
-    
-    ## Specifies the class of product name
-    attribute class { db.productname.class.enumeration }
-  db.productname.attlist =
-    db.productname.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.productname.class.attribute?
-  db.productname =
-    
-    ## The formal name of a product
-    element productname { db.productname.attlist, db._text }
-}
-div {
-  db.productnumber.role.attribute = attribute role { text }
-  db.productnumber.attlist =
-    db.productnumber.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.productnumber =
-    
-    ## A number assigned to a product
-    element productnumber { db.productnumber.attlist, db._text }
-}
-div {
-  db.database.class.enumeration =
-    
-    ## An alternate or secondary key
-    "altkey"
-    | 
-      ## A constraint
-      "constraint"
-    | 
-      ## A data type
-      "datatype"
-    | 
-      ## A field
-      "field"
-    | 
-      ## A foreign key
-      "foreignkey"
-    | 
-      ## A group
-      "group"
-    | 
-      ## An index
-      "index"
-    | 
-      ## The first or primary key
-      "key1"
-    | 
-      ## An alternate or secondary key
-      "key2"
-    | 
-      ## A name
-      "name"
-    | 
-      ## The primary key
-      "primarykey"
-    | 
-      ## A (stored) procedure
-      "procedure"
-    | 
-      ## A record
-      "record"
-    | 
-      ## A rule
-      "rule"
-    | 
-      ## The secondary key
-      "secondarykey"
-    | 
-      ## A table
-      "table"
-    | 
-      ## A user
-      "user"
-    | 
-      ## A view
-      "view"
-  db.database.class.attribute =
-    
-    ## Identifies the class of database artifact
-    attribute class { db.database.class.enumeration }
-  db.database.role.attribute = attribute role { text }
-  db.database.attlist =
-    db.database.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.database.class.attribute?
-  db.database =
-    
-    ## The name of a database, or part of a database
-    element database { db.database.attlist, db._text }
-}
-div {
-  db.application.class.enumeration =
-    
-    ## A hardware application
-    "hardware"
-    | 
-      ## A software application
-      "software"
-  db.application.class.attribute =
-    
-    ## Identifies the class of application
-    attribute class { db.application.class.enumeration }
-  db.application.role.attribute = attribute role { text }
-  db.application.attlist =
-    db.application.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.application.class.attribute?
-  db.application =
-    
-    ## The name of a software program
-    element application { db.application.attlist, db._text }
-}
-div {
-  db.hardware.role.attribute = attribute role { text }
-  db.hardware.attlist =
-    db.hardware.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.hardware =
-    
-    ## A physical part of a computer system
-    element hardware { db.hardware.attlist, db._text }
-}
-db.gui.inlines =
-  db.guiicon
-  | db.guibutton
-  | db.guimenuitem
-  | db.guimenu
-  | db.guisubmenu
-  | db.guilabel
-  | db.menuchoice
-  | db.mousebutton
-div {
-  db.guibutton.role.attribute = attribute role { text }
-  db.guibutton.attlist =
-    db.guibutton.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.guibutton =
-    
-    ## The text on a button in a GUI
-    element guibutton {
-      db.guibutton.attlist,
-      (db._text | db.accel | db.superscript | db.subscript)*
-    }
-}
-div {
-  db.guiicon.role.attribute = attribute role { text }
-  db.guiicon.attlist =
-    db.guiicon.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.guiicon =
-    
-    ## Graphic and/or text appearing as a icon in a GUI
-    element guiicon {
-      db.guiicon.attlist,
-      (db._text | db.accel | db.superscript | db.subscript)*
-    }
-}
-div {
-  db.guilabel.role.attribute = attribute role { text }
-  db.guilabel.attlist =
-    db.guilabel.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.guilabel =
-    
-    ## The text of a label in a GUI
-    element guilabel {
-      db.guilabel.attlist,
-      (db._text | db.accel | db.superscript | db.subscript)*
-    }
-}
-div {
-  db.guimenu.role.attribute = attribute role { text }
-  db.guimenu.attlist =
-    db.guimenu.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.guimenu =
-    
-    ## The name of a menu in a GUI
-    element guimenu {
-      db.guimenu.attlist,
-      (db._text | db.accel | db.superscript | db.subscript)*
-    }
-}
-div {
-  db.guimenuitem.role.attribute = attribute role { text }
-  db.guimenuitem.attlist =
-    db.guimenuitem.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.guimenuitem =
-    
-    ## The name of a terminal menu item in a GUI
-    element guimenuitem {
-      db.guimenuitem.attlist,
-      (db._text | db.accel | db.superscript | db.subscript)*
-    }
-}
-div {
-  db.guisubmenu.role.attribute = attribute role { text }
-  db.guisubmenu.attlist =
-    db.guisubmenu.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.guisubmenu =
-    
-    ## The name of a submenu in a GUI
-    element guisubmenu {
-      db.guisubmenu.attlist,
-      (db._text | db.accel | db.superscript | db.subscript)*
-    }
-}
-div {
-  db.menuchoice.role.attribute = attribute role { text }
-  db.menuchoice.attlist =
-    db.menuchoice.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.menuchoice =
-    
-    ## A selection or series of selections from a menu
-    element menuchoice {
-      db.menuchoice.attlist,
-      db.shortcut?,
-      (db.guibutton
-       | db.guiicon
-       | db.guilabel
-       | db.guimenu
-       | db.guimenuitem
-       | db.guisubmenu)+
-    }
-}
-div {
-  db.mousebutton.role.attribute = attribute role { text }
-  db.mousebutton.attlist =
-    db.mousebutton.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.mousebutton =
-    
-    ## The conventional name of a mouse button
-    element mousebutton { db.mousebutton.attlist, db._text }
-}
-db.keyboard.inlines =
-  db.keycombo
-  | db.keycap
-  | db.keycode
-  | db.keysym
-  | db.shortcut
-  | db.accel
-div {
-  db.keycap.function.enumeration =
-    
-    ## The "Alt" key
-    "alt"
-    | 
-      ## The "Backspace" key
-      "backspace"
-    | 
-      ## The "Command" key
-      "command"
-    | 
-      ## The "Control" key
-      "control"
-    | 
-      ## The "Delete" key
-      "delete"
-    | 
-      ## The down arrow
-      "down"
-    | 
-      ## The "End" key
-      "end"
-    | 
-      ## The "Enter" or "Return" key
-      "enter"
-    | 
-      ## The "Escape" key
-      "escape"
-    | 
-      ## The "Home" key
-      "home"
-    | 
-      ## The "Insert" key
-      "insert"
-    | 
-      ## The left arrow
-      "left"
-    | 
-      ## The "Meta" key
-      "meta"
-    | 
-      ## The "Option" key
-      "option"
-    | 
-      ## The page down key
-      "pagedown"
-    | 
-      ## The page up key
-      "pageup"
-    | 
-      ## The right arrow
-      "right"
-    | 
-      ## The "Shift" key
-      "shift"
-    | 
-      ## The spacebar
-      "space"
-    | 
-      ## The "Tab" key
-      "tab"
-    | 
-      ## The up arrow
-      "up"
-  db.keycap.function-enum.attribute =
-    
-    ## Identifies the function key
-    attribute function { db.keycap.function.enumeration }?
-  db.keycap.function-other.attributes =
-    
-    ## Identifies the function key
-    attribute function {
-      
-      ## Indicates a non-standard function key
-      "other"
-    }?,
-    
-    ## Specifies a keyword that identifies the non-standard key
-    attribute otherfunction { text }
-  db.keycap.function.attrib =
-    db.keycap.function-enum.attribute
-    | db.keycap.function-other.attributes
-  db.keycap.role.attribute = attribute role { text }
-  db.keycap.attlist =
-    db.keycap.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.keycap.function.attrib
-  db.keycap =
-    
-    ## The text printed on a key on a keyboard
-    element keycap { db.keycap.attlist, db._text }
-}
-div {
-  db.keycode.role.attribute = attribute role { text }
-  db.keycode.attlist =
-    db.keycode.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.keycode =
-    
-    ## The internal, frequently numeric, identifier for a key on a keyboard
-    element keycode { db.keycode.attlist, db._text }
-}
-db.keycombination.contentmodel =
-  (db.keycap | db.keycombo | db.keysym) | db.mousebutton
-div {
-  db.keycombo.action.enumeration =
-    
-    ## A (single) mouse click.
-    "click"
-    | 
-      ## A double mouse click.
-      "double-click"
-    | 
-      ## A mouse or key press.
-      "press"
-    | 
-      ## Sequential clicks or presses.
-      "seq"
-    | 
-      ## Simultaneous clicks or presses.
-      "simul"
-  db.keycombo.action-enum.attribute =
-    
-    ## Identifies the nature of the action taken. If keycombo
-    ##  contains more than one element, simul
-    ##  is the default, otherwise there is no default.
-    attribute action { db.keycombo.action.enumeration }?
-  db.keycombo.action-other.attributes =
-    
-    ## Identifies the nature of the action taken
-    attribute action {
-      
-      ## Indicates a non-standard action
-      "other"
-    }?,
-    
-    ## Identifies the non-standard action in some unspecified way.
-    attribute otheraction { text }
-  db.keycombo.action.attrib =
-    db.keycombo.action-enum.attribute
-    | db.keycombo.action-other.attributes
-  db.keycombo.role.attribute = attribute role { text }
-  db.keycombo.attlist =
-    db.keycombo.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.keycombo.action.attrib
-  db.keycombo =
-    
-    ## A combination of input actions
-    element keycombo {
-      db.keycombo.attlist, db.keycombination.contentmodel+
-    }
-}
-div {
-  db.keysym.role.attribute = attribute role { text }
-  db.keysym.attlist =
-    db.keysym.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.keysym =
-    
-    ## The symbolic name of a key on a keyboard
-    element keysym { db.keysym.attlist, db._text }
-}
-div {
-  db.accel.role.attribute = attribute role { text }
-  db.accel.attlist =
-    db.accel.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.accel =
-    
-    ## A graphical user interface (GUI) keyboard shortcut
-    element accel { db.accel.attlist, db._text }
-}
-div {
-  db.shortcut.action.attrib = db.keycombo.action.attrib
-  db.shortcut.role.attribute = attribute role { text }
-  db.shortcut.attlist =
-    db.shortcut.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.shortcut.action.attrib
-  db.shortcut =
-    
-    ## A key combination for an action that is also accessible through a menu
-    element shortcut {
-      db.shortcut.attlist, db.keycombination.contentmodel+
-    }
-}
-db.os.inlines =
-  db.prompt
-  | db.envar
-  | db.filename
-  | db.command
-  | db.computeroutput
-  | db.userinput
-db.computeroutput.inlines =
-  (text | db.ubiq.inlines | db.os.inlines | db.technical.inlines)
-  | db.co
-  | db.markup.inlines
-db.userinput.inlines =
-  (text | db.ubiq.inlines | db.os.inlines | db.technical.inlines)
-  | db.co
-  | db.markup.inlines
-  | db.gui.inlines
-  | db.keyboard.inlines
-db.prompt.inlines = db._text | db.co
-div {
-  db.prompt.role.attribute = attribute role { text }
-  db.prompt.attlist =
-    db.prompt.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.prompt =
-    
-    ## A character or string indicating the start of an input field in a  computer display
-    element prompt { db.prompt.attlist, db.prompt.inlines* }
-}
-div {
-  db.envar.role.attribute = attribute role { text }
-  db.envar.attlist =
-    db.envar.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.envar =
-    
-    ## A software environment variable
-    element envar { db.envar.attlist, db._text }
-}
-div {
-  db.filename.class.enumeration =
-    
-    ## A device
-    "devicefile"
-    | 
-      ## A directory
-      "directory"
-    | 
-      ## A filename extension
-      "extension"
-    | 
-      ## A header file (as for a programming language)
-      "headerfile"
-    | 
-      ## A library file
-      "libraryfile"
-    | 
-      ## A partition (as of a hard disk)
-      "partition"
-    | 
-      ## A symbolic link
-      "symlink"
-  db.filename.class.attribute =
-    
-    ## Identifies the class of filename
-    attribute class { db.filename.class.enumeration }
-  db.filename.path.attribute =
-    
-    ## Specifies the path of the filename
-    attribute path { text }
-  db.filename.role.attribute = attribute role { text }
-  db.filename.attlist =
-    db.filename.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.filename.path.attribute?
-    & db.filename.class.attribute?
-  db.filename =
-    
-    ## The name of a file
-    element filename { db.filename.attlist, db._text }
-}
-div {
-  db.command.role.attribute = attribute role { text }
-  db.command.attlist =
-    db.command.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.command =
-    
-    ## The name of an executable program or other software command
-    element command { db.command.attlist, db._text }
-}
-div {
-  db.computeroutput.role.attribute = attribute role { text }
-  db.computeroutput.attlist =
-    db.computeroutput.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.computeroutput =
-    
-    ## Data, generally text, displayed or presented by a computer
-    element computeroutput {
-      db.computeroutput.attlist, db.computeroutput.inlines*
-    }
-}
-div {
-  db.userinput.role.attribute = attribute role { text }
-  db.userinput.attlist =
-    db.userinput.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.userinput =
-    
-    ## Data entered by the user
-    element userinput { db.userinput.attlist, db.userinput.inlines* }
-}
-div {
-  db.cmdsynopsis.role.attribute = attribute role { text }
-  db.cmdsynopsis.sepchar.attribute =
-    
-    ## Specifies the character that should separate the command and its top-level arguments
-    attribute sepchar { text }
-  db.cmdsynopsis.cmdlength.attribute =
-    
-    ## Indicates the displayed length of the command; this information may be used to intelligently indent command synopses which extend beyond one line
-    attribute cmdlength { text }
-  db.cmdsynopsis.label.attribute = db.label.attribute
-  db.cmdsynopsis.attlist =
-    db.cmdsynopsis.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.cmdsynopsis.sepchar.attribute?
-    & db.cmdsynopsis.cmdlength.attribute?
-    & db.cmdsynopsis.label.attribute?
-  db.cmdsynopsis.info = db._info.title.forbidden
-  db.cmdsynopsis =
-    
-    ## A syntax summary for a software command
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:cmdsynopsis"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element cmdsynopsis {
-      db.cmdsynopsis.attlist,
-      db.cmdsynopsis.info,
-      (db.command | db.arg | db.group | db.sbr)+,
-      db.synopfragment*
-    }
-}
-db.rep.enumeration =
-  
-  ## Can not be repeated.
-  "norepeat"
-  | 
-    ## Can be repeated.
-    "repeat"
-db.rep.attribute =
-  
-  ## Indicates whether or not repetition is possible.
-  [ a:defaultValue = "norepeat" ] attribute rep { db.rep.enumeration }
-db.choice.enumeration =
-  
-  ## Formatted to indicate that it is optional.
-  "opt"
-  | 
-    ## Formatted without indication.
-    "plain"
-  | 
-    ## Formatted to indicate that it is required.
-    "req"
-db.choice.opt.attribute =
-  
-  ## Indicates optionality.
-  [ a:defaultValue = "opt" ] attribute choice { db.choice.enumeration }
-db.choice.req.attribute =
-  
-  ## Indicates optionality.
-  [ a:defaultValue = "req" ] attribute choice { db.choice.enumeration }
-div {
-  db.arg.role.attribute = attribute role { text }
-  db.arg.rep.attribute = db.rep.attribute
-  db.arg.choice.attribute = db.choice.opt.attribute
-  db.arg.attlist =
-    db.arg.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.arg.rep.attribute?
-    & db.arg.choice.attribute?
-  db.arg =
-    
-    ## An argument in a cmdsynopsis
-    element arg {
-      db.arg.attlist,
-      (db._text
-       | db.arg
-       | db.group
-       | db.option
-       | db.synopfragmentref
-       | db.sbr)*
-    }
-}
-div {
-  db.group.role.attribute = attribute role { text }
-  db.group.rep.attribute = db.rep.attribute
-  db.group.choice.attribute = db.choice.opt.attribute
-  db.group.attlist =
-    db.group.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.group.rep.attribute?
-    & db.group.choice.attribute?
-  db.group =
-    
-    ## A group of elements in a cmdsynopsis
-    element group {
-      db.group.attlist,
-      (db.arg
-       | db.group
-       | db.option
-       | db.synopfragmentref
-       | db.replaceable
-       | db.sbr)+
-    }
-}
-div {
-  db.sbr.role.attribute = attribute role { text }
-  db.sbr.attlist = db.sbr.role.attribute? & db.common.attributes
-  db.sbr =
-    
-    ## An explicit line break in a command synopsis
-    element sbr { db.sbr.attlist, empty }
-}
-div {
-  db.synopfragment.role.attribute = attribute role { text }
-  db.synopfragment.attlist =
-    db.synopfragment.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.synopfragment =
-    
-    ## A portion of a cmdsynopsis broken out from the main body of the synopsis
-    element synopfragment {
-      db.synopfragment.attlist, (db.arg | db.group)+
-    }
-}
-div {
-  db.synopfragmentref.role.attribute = attribute role { text }
-  db.synopfragmentref.attlist =
-    db.synopfragmentref.role.attribute?
-    & db.common.attributes
-    & db.linkend.attribute
-  db.synopfragmentref =
-    
-    ## A reference to a fragment of a command synopsis
-    [
-      s:pattern [
-        name = "Synopsis fragment type constraint"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:synopfragmentref"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test =
-              "local-name(//*[@xml:id=current()/@linkend]) = 'synopfragment' and namespace-uri(//*[@xml:id=current()/@linkend]) = 'http://docbook.org/ns/docbook'"
-            "@linkend on synopfragmentref must point to a synopfragment."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element synopfragmentref { db.synopfragmentref.attlist, text }
-}
-db.programming.inlines =
-  db.function
-  | db.parameter
-  | db.varname
-  | db.returnvalue
-  | db.type
-  | db.classname
-  | db.exceptionname
-  | db.interfacename
-  | db.methodname
-  | db.modifier
-  | db.initializer
-  | db.oo.inlines
-db.oo.inlines = db.ooclass | db.ooexception | db.oointerface
-db.synopsis.blocks =
-  (db.funcsynopsis
-   | db.classsynopsis
-   | db.methodsynopsis
-   | db.constructorsynopsis
-   | db.destructorsynopsis
-   | db.fieldsynopsis)
-  | db.cmdsynopsis
-div {
-  db.synopsis.role.attribute = attribute role { text }
-  db.synopsis.label.attribute = db.label.attribute
-  db.synopsis.attlist =
-    db.synopsis.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.verbatim.attributes
-    & db.synopsis.label.attribute?
-  db.synopsis =
-    
-    ## A general-purpose element for representing the syntax of commands or functions
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:synopsis"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element synopsis { db.synopsis.attlist, db.verbatim.contentmodel }
-}
-div {
-  db.funcsynopsis.role.attribute = attribute role { text }
-  db.funcsynopsis.attlist =
-    db.funcsynopsis.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.language.attribute?
-  db.funcsynopsis.info = db._info.title.forbidden
-  db.funcsynopsis =
-    
-    ## The syntax summary for a function definition
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:funcsynopsis"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element funcsynopsis {
-      db.funcsynopsis.attlist,
-      db.funcsynopsis.info,
-      (db.funcsynopsisinfo | db.funcprototype)+
-    }
-}
-div {
-  db.funcsynopsisinfo.role.attribute = attribute role { text }
-  db.funcsynopsisinfo.attlist =
-    db.funcsynopsisinfo.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.verbatim.attributes
-  db.funcsynopsisinfo =
-    
-    ## Information supplementing the funcdefs of a funcsynopsis
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:funcsynopsisinfo"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element funcsynopsisinfo {
-      db.funcsynopsisinfo.attlist, db.verbatim.contentmodel
-    }
-}
-div {
-  db.funcprototype.role.attribute = attribute role { text }
-  db.funcprototype.attlist =
-    db.funcprototype.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.funcprototype =
-    
-    ## The prototype of a function
-    element funcprototype {
-      db.funcprototype.attlist,
-      db.modifier*,
-      db.funcdef,
-      (db.void
-       | db.varargs
-       | ((db.paramdef | db.group.paramdef)+, db.varargs?)),
-      db.modifier*
-    }
-}
-div {
-  db.funcdef.role.attribute = attribute role { text }
-  db.funcdef.attlist =
-    db.funcdef.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.funcdef =
-    
-    ## A function (subroutine) name and its return type
-    element funcdef {
-      db.funcdef.attlist, (db._text | db.type | db.function)*
-    }
-}
-div {
-  db.function.role.attribute = attribute role { text }
-  db.function.attlist =
-    db.function.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.function =
-    
-    ## The name of a function or subroutine, as in a programming language
-    element function { db.function.attlist, db._text }
-}
-div {
-  db.void.role.attribute = attribute role { text }
-  db.void.attlist =
-    db.void.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.void =
-    
-    ## An empty element in a function synopsis indicating that the function in question takes no arguments
-    element void { db.void.attlist, empty }
-}
-div {
-  db.varargs.role.attribute = attribute role { text }
-  db.varargs.attlist =
-    db.varargs.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.varargs =
-    
-    ## An empty element in a function synopsis indicating a variable number of arguments
-    element varargs { db.varargs.attlist, empty }
-}
-div {
-  db.group.paramdef.role.attribute = attribute role { text }
-  db.group.paramdef.choice.attribute = db.choice.opt.attribute
-  db.group.paramdef.attlist =
-    db.group.paramdef.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.group.paramdef.choice.attribute?
-  db.group.paramdef =
-    
-    ## A group of parameters
-    element group {
-      db.group.paramdef.attlist, (db.paramdef | db.group.paramdef)+
-    }
-}
-div {
-  db.paramdef.role.attribute = attribute role { text }
-  db.paramdef.choice.enumeration =
-    
-    ## Formatted to indicate that it is optional.
-    "opt"
-    | 
-      ## Formatted to indicate that it is required.
-      "req"
-  db.paramdef.choice.attribute =
-    
-    ## Indicates optionality.
-    [ a:defaultValue = "opt" ]
-    attribute choice { db.paramdef.choice.enumeration }
-  db.paramdef.attlist =
-    db.paramdef.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.paramdef.choice.attribute?
-  db.paramdef =
-    
-    ## Information about a function parameter in a programming language
-    element paramdef {
-      db.paramdef.attlist,
-      (db._text
-       | db.initializer
-       | db.type
-       | db.parameter
-       | db.funcparams)*
-    }
-}
-div {
-  db.funcparams.role.attribute = attribute role { text }
-  db.funcparams.attlist =
-    db.funcparams.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.funcparams =
-    
-    ## Parameters for a function referenced through a function pointer in a synopsis
-    element funcparams { db.funcparams.attlist, db._text }
-}
-div {
-  db.classsynopsis.role.attribute = attribute role { text }
-  db.classsynopsis.class.enumeration =
-    
-    ## This is the synopsis of a class
-    "class"
-    | 
-      ## This is the synopsis of an interface
-      "interface"
-  db.classsynopsis.class.attribute =
-    
-    ## Specifies the nature of the synopsis
-    attribute class { db.classsynopsis.class.enumeration }
-  db.classsynopsis.attlist =
-    db.classsynopsis.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.language.attribute?
-    & db.classsynopsis.class.attribute?
-  db.classsynopsis =
-    
-    ## The syntax summary for a class definition
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:classsynopsis"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element classsynopsis {
-      db.classsynopsis.attlist,
-      db.oo.inlines+,
-      (db.classsynopsisinfo
-       | db.methodsynopsis
-       | db.constructorsynopsis
-       | db.destructorsynopsis
-       | db.fieldsynopsis)*
-    }
-}
-div {
-  db.classsynopsisinfo.role.attribute = attribute role { text }
-  db.classsynopsisinfo.attlist =
-    db.classsynopsisinfo.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.verbatim.attributes
-  db.classsynopsisinfo =
-    
-    ## Information supplementing the contents of a classsynopsis
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:classsynopsisinfo"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element classsynopsisinfo {
-      db.classsynopsisinfo.attlist, db.verbatim.contentmodel
-    }
-}
-div {
-  db.ooclass.role.attribute = attribute role { text }
-  db.ooclass.attlist =
-    db.ooclass.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.ooclass =
-    
-    ## A class in an object-oriented programming language
-    element ooclass {
-      db.ooclass.attlist, (db.package | db.modifier)*, db.classname
-    }
-}
-div {
-  db.oointerface.role.attribute = attribute role { text }
-  db.oointerface.attlist =
-    db.oointerface.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.oointerface =
-    
-    ## An interface in an object-oriented programming language
-    element oointerface {
-      db.oointerface.attlist,
-      (db.package | db.modifier)*,
-      db.interfacename
-    }
-}
-div {
-  db.ooexception.role.attribute = attribute role { text }
-  db.ooexception.attlist =
-    db.ooexception.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.ooexception =
-    
-    ## An exception in an object-oriented programming language
-    element ooexception {
-      db.ooexception.attlist,
-      (db.package | db.modifier)*,
-      db.exceptionname
-    }
-}
-db.modifier.xml.space.attribute =
-  
-  ## Can be used to indicate that whitespace in the modifier should be preserved (for multi-line annotations, for example).
-  attribute xml:space {
-    
-    ## Extra whitespace and line breaks must be preserved.
-    [
-      # Ideally the definition of xml:space used on modifier would be
-      # different from the definition used on the verbatim elements. The
-      # verbatim elements forbid the use of xml:space="default" which
-      # wouldn't be a problem on modifier. But doing that causes the
-      # generated XSD schemas to be broken so I'm just reusing the existing
-      # definition for now. It won't be backwards incompatible to fix this
-      # problem in the future.
-      #    | ## Extra whitespace and line breaks are not preserved.
-      #      "default"
-      
-    ]
-    "preserve"
-  }
-div {
-  db.modifier.role.attribute = attribute role { text }
-  db.modifier.attlist =
-    db.modifier.xml.space.attribute?
-    & db.modifier.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.modifier =
-    
-    ## Modifiers in a synopsis
-    element modifier { db.modifier.attlist, db._text }
-}
-div {
-  db.interfacename.role.attribute = attribute role { text }
-  db.interfacename.attlist =
-    db.interfacename.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.interfacename =
-    
-    ## The name of an interface
-    element interfacename { db.interfacename.attlist, db._text }
-}
-div {
-  db.exceptionname.role.attribute = attribute role { text }
-  db.exceptionname.attlist =
-    db.exceptionname.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.exceptionname =
-    
-    ## The name of an exception
-    element exceptionname { db.exceptionname.attlist, db._text }
-}
-div {
-  db.fieldsynopsis.role.attribute = attribute role { text }
-  db.fieldsynopsis.attlist =
-    db.fieldsynopsis.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.language.attribute?
-  db.fieldsynopsis =
-    
-    ## The name of a field in a class definition
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:fieldsynopsis"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element fieldsynopsis {
-      db.fieldsynopsis.attlist,
-      db.modifier*,
-      db.type?,
-      db.varname,
-      db.initializer?
-    }
-}
-div {
-  db.initializer.role.attribute = attribute role { text }
-  db.initializer.attlist =
-    db.initializer.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.initializer.inlines = db._text | db.mathphrase | db.markup.inlines
-  db.initializer =
-    
-    ## The initializer for a fieldsynopsis
-    element initializer {
-      db.initializer.attlist, db.initializer.inlines*
-    }
-}
-div {
-  db.constructorsynopsis.role.attribute = attribute role { text }
-  db.constructorsynopsis.attlist =
-    db.constructorsynopsis.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.language.attribute?
-  db.constructorsynopsis =
-    
-    ## A syntax summary for a constructor
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:constructorsynopsis"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element constructorsynopsis {
-      db.constructorsynopsis.attlist,
-      db.modifier*,
-      db.methodname?,
-      ((db.methodparam | db.group.methodparam)+ | db.void?),
-      db.exceptionname*
-    }
-}
-div {
-  db.destructorsynopsis.role.attribute = attribute role { text }
-  db.destructorsynopsis.attlist =
-    db.destructorsynopsis.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.language.attribute?
-  db.destructorsynopsis =
-    
-    ## A syntax summary for a destructor
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:destructorsynopsis"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element destructorsynopsis {
-      db.destructorsynopsis.attlist,
-      db.modifier*,
-      db.methodname?,
-      ((db.methodparam | db.group.methodparam)+ | db.void?),
-      db.exceptionname*
-    }
-}
-div {
-  db.methodsynopsis.role.attribute = attribute role { text }
-  db.methodsynopsis.attlist =
-    db.methodsynopsis.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.language.attribute?
-  db.methodsynopsis =
-    
-    ## A syntax summary for a method
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:methodsynopsis"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element methodsynopsis {
-      db.methodsynopsis.attlist,
-      db.modifier*,
-      (db.type | db.void)?,
-      db.methodname,
-      ((db.methodparam | db.group.methodparam)+ | db.void),
-      db.exceptionname*,
-      db.modifier*
-    }
-}
-div {
-  db.methodname.role.attribute = attribute role { text }
-  db.methodname.attlist =
-    db.methodname.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.methodname =
-    
-    ## The name of a method
-    element methodname { db.methodname.attlist, db._text }
-}
-div {
-  db.methodparam.role.attribute = attribute role { text }
-  db.methodparam.rep.attribute = db.rep.attribute
-  db.methodparam.choice.attribute = db.choice.req.attribute
-  db.methodparam.attlist =
-    db.methodparam.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.methodparam.rep.attribute?
-    & db.methodparam.choice.attribute?
-  db.methodparam =
-    
-    ## Parameters to a method
-    element methodparam {
-      db.methodparam.attlist,
-      db.modifier*,
-      db.type?,
-      ((db.modifier*, db.parameter, db.initializer?) | db.funcparams),
-      db.modifier*
-    }
-}
-div {
-  db.group.methodparam.role.attribute = attribute role { text }
-  db.group.methodparam.choice.attribute = db.choice.opt.attribute
-  db.group.methodparam.attlist =
-    db.group.methodparam.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.group.methodparam.choice.attribute?
-  db.group.methodparam =
-    
-    ## A group of method parameters
-    element group {
-      db.group.methodparam.attlist,
-      (db.methodparam | db.group.methodparam)+
-    }
-}
-div {
-  db.varname.role.attribute = attribute role { text }
-  db.varname.attlist =
-    db.varname.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.varname =
-    
-    ## The name of a variable
-    element varname { db.varname.attlist, db._text }
-}
-div {
-  db.returnvalue.role.attribute = attribute role { text }
-  db.returnvalue.attlist =
-    db.returnvalue.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.returnvalue =
-    
-    ## The value returned by a function
-    element returnvalue { db.returnvalue.attlist, db._text }
-}
-div {
-  db.type.role.attribute = attribute role { text }
-  db.type.attlist =
-    db.type.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.type =
-    
-    ## The classification of a value
-    element type { db.type.attlist, db._text }
-}
-div {
-  db.classname.role.attribute = attribute role { text }
-  db.classname.attlist =
-    db.classname.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.classname =
-    
-    ## The name of a class, in the object-oriented programming sense
-    element classname { db.classname.attlist, db._text }
-}
-div {
-  db.programlisting.role.attribute = attribute role { text }
-  db.programlisting.width.attribute = db.width.characters.attribute
-  db.programlisting.attlist =
-    db.programlisting.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.verbatim.attributes
-    & db.programlisting.width.attribute?
-  db.programlisting =
-    
-    ## A literal listing of all or part of a program
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:programlisting"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element programlisting {
-      db.programlisting.attlist, db.verbatim.contentmodel
-    }
-}
-db.admonition.blocks =
-  db.caution | db.important | db.note | db.tip | db.warning
-db.admonition.contentmodel = db._info.title.only, db.all.blocks+
-div {
-  db.caution.role.attribute = attribute role { text }
-  db.caution.attlist =
-    db.caution.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.caution =
-    
-    ## A note of caution
-    [
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:caution"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:caution)"
-            "caution must not occur among the children or descendants of caution"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:caution"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:important)"
-            "important must not occur among the children or descendants of caution"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:caution"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:note)"
-            "note must not occur among the children or descendants of caution"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:caution"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:tip)"
-            "tip must not occur among the children or descendants of caution"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:caution"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:warning)"
-            "warning must not occur among the children or descendants of caution"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:caution"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element caution { db.caution.attlist, db.admonition.contentmodel }
-}
-div {
-  db.important.role.attribute = attribute role { text }
-  db.important.attlist =
-    db.important.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.important =
-    
-    ## An admonition set off from the text
-    [
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:important"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:caution)"
-            "caution must not occur among the children or descendants of important"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:important"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:important)"
-            "important must not occur among the children or descendants of important"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:important"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:note)"
-            "note must not occur among the children or descendants of important"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:important"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:tip)"
-            "tip must not occur among the children or descendants of important"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:important"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:warning)"
-            "warning must not occur among the children or descendants of important"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:important"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element important {
-      db.important.attlist, db.admonition.contentmodel
-    }
-}
-div {
-  db.note.role.attribute = attribute role { text }
-  db.note.attlist =
-    db.note.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.note =
-    
-    ## A message set off from the text
-    [
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:note"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:caution)"
-            "caution must not occur among the children or descendants of note"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:note"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:important)"
-            "important must not occur among the children or descendants of note"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:note"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:note)"
-            "note must not occur among the children or descendants of note"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:note"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:tip)"
-            "tip must not occur among the children or descendants of note"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:note"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:warning)"
-            "warning must not occur among the children or descendants of note"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:note"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element note { db.note.attlist, db.admonition.contentmodel }
-}
-div {
-  db.tip.role.attribute = attribute role { text }
-  db.tip.attlist =
-    db.tip.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.tip =
-    
-    ## A suggestion to the user, set off from the text
-    [
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:tip"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:caution)"
-            "caution must not occur among the children or descendants of tip"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:tip"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:important)"
-            "important must not occur among the children or descendants of tip"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:tip"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:note)"
-            "note must not occur among the children or descendants of tip"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:tip"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:tip)"
-            "tip must not occur among the children or descendants of tip"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:tip"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:warning)"
-            "warning must not occur among the children or descendants of tip"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:tip"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element tip { db.tip.attlist, db.admonition.contentmodel }
-}
-div {
-  db.warning.role.attribute = attribute role { text }
-  db.warning.attlist =
-    db.warning.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.warning =
-    
-    ## An admonition set off from the text
-    [
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:warning"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:caution)"
-            "caution must not occur among the children or descendants of warning"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:warning"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:important)"
-            "important must not occur among the children or descendants of warning"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:warning"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:note)"
-            "note must not occur among the children or descendants of warning"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:warning"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:tip)"
-            "tip must not occur among the children or descendants of warning"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Element exclusion"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "db:warning"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "not(.//db:warning)"
-            "warning must not occur among the children or descendants of warning"
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:warning"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element warning { db.warning.attlist, db.admonition.contentmodel }
-}
-db.error.inlines =
-  db.errorcode | db.errortext | db.errorname | db.errortype
-div {
-  db.errorcode.role.attribute = attribute role { text }
-  db.errorcode.attlist =
-    db.errorcode.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.errorcode =
-    
-    ## An error code
-    element errorcode { db.errorcode.attlist, db._text }
-}
-div {
-  db.errorname.role.attribute = attribute role { text }
-  db.errorname.attlist =
-    db.errorname.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.errorname =
-    
-    ## An error name
-    element errorname { db.errorname.attlist, db._text }
-}
-div {
-  db.errortext.role.attribute = attribute role { text }
-  db.errortext.attlist =
-    db.errortext.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.errortext =
-    
-    ## An error message.
-    element errortext { db.errortext.attlist, db._text }
-}
-div {
-  db.errortype.role.attribute = attribute role { text }
-  db.errortype.attlist =
-    db.errortype.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.errortype =
-    
-    ## The classification of an error message
-    element errortype { db.errortype.attlist, db._text }
-}
-db.systemitem.inlines = db._text | db.co
-div {
-  db.systemitem.class.enumeration =
-    
-    ## A daemon or other system process (syslogd)
-    "daemon"
-    | 
-      ## A domain name (example.com)
-      "domainname"
-    | 
-      ## An ethernet address (00:05:4E:49:FD:8E)
-      "etheraddress"
-    | 
-      ## An event of some sort (SIGHUP)
-      "event"
-    | 
-      ## An event handler of some sort (hangup)
-      "eventhandler"
-    | 
-      ## A filesystem (ext3)
-      "filesystem"
-    | 
-      ## A fully qualified domain name (my.example.com)
-      "fqdomainname"
-    | 
-      ## A group name (wheel)
-      "groupname"
-    | 
-      ## An IP address (127.0.0.1)
-      "ipaddress"
-    | 
-      ## A library (libncurses)
-      "library"
-    | 
-      ## A macro
-      "macro"
-    | 
-      ## A netmask (255.255.255.192)
-      "netmask"
-    | 
-      ## A newsgroup (comp.text.xml)
-      "newsgroup"
-    | 
-      ## An operating system name (Hurd)
-      "osname"
-    | 
-      ## A process (gnome-cups-icon)
-      "process"
-    | 
-      ## A protocol (ftp)
-      "protocol"
-    | 
-      ## A resource
-      "resource"
-    | 
-      ## A security context (a role, permission, or security token, for example)
-      "securitycontext"
-    | 
-      ## A server (mail.example.com)
-      "server"
-    | 
-      ## A service (ppp)
-      "service"
-    | 
-      ## A system name (hephaistos)
-      "systemname"
-    | 
-      ## A user name (ndw)
-      "username"
-  db.systemitem.class-enum.attribute =
-    
-    ## Identifies the nature of the system item
-    attribute class { db.systemitem.class.enumeration }?
-  db.systemitem.class-other.attribute =
-    
-    ## Identifies the nature of the non-standard system item
-    attribute otherclass { xsd:NMTOKEN }
-  db.systemitem.class-other.attributes =
-    
-    ## Identifies the kind of systemitemgraphic identifier
-    attribute class {
-      
-      ## Indicates that the system item is some 'other' kind.
-      "other"
-    }
-    & db.systemitem.class-other.attribute
-  db.systemitem.class.attribute =
-    db.systemitem.class-enum.attribute
-    | db.systemitem.class-other.attributes
-  db.systemitem.role.attribute = attribute role { text }
-  db.systemitem.attlist =
-    db.systemitem.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.systemitem.class.attribute?
-  db.systemitem =
-    
-    ## A system-related item or term
-    element systemitem { db.systemitem.attlist, db.systemitem.inlines* }
-}
-div {
-  db.option.role.attribute = attribute role { text }
-  db.option.attlist =
-    db.option.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.option =
-    
-    ## An option for a software command
-    element option { db.option.attlist, db._text }
-}
-div {
-  db.optional.role.attribute = attribute role { text }
-  db.optional.attlist =
-    db.optional.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.optional =
-    
-    ## Optional information
-    element optional { db.optional.attlist, db._text }
-}
-div {
-  db.property.role.attribute = attribute role { text }
-  db.property.attlist =
-    db.property.role.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-  db.property =
-    
-    ## A unit of data associated with some part of a computer system
-    element property { db.property.attlist, db._text }
-}
-div {
-  db.topic.status.attribute = db.status.attribute
-  db.topic.role.attribute = attribute role { text }
-  db.topic.type.attribute =
-    
-    ## Identifies the topic type
-    attribute type { text }
-  db.topic.attlist =
-    db.topic.role.attribute?
-    & db.topic.type.attribute?
-    & db.common.attributes
-    & db.common.linking.attributes
-    & db.label.attribute?
-    & db.topic.status.attribute?
-  db.topic.info = db._info.title.req
-  db.topic =
-    
-    ## A modular unit of documentation not part of any particular narrative flow
-    [
-      s:pattern [
-        name = "Root must have version"
-        "\x{a}" ~
-        "               "
-        s:rule [
-          context = "/db:topic"
-          "\x{a}" ~
-          "                  "
-          s:assert [
-            test = "@version"
-            "If this element is the root element, it must have a version attribute."
-          ]
-          "\x{a}" ~
-          "               "
-        ]
-        "\x{a}" ~
-        "            "
-      ]
-    ]
-    element topic {
-      db.topic.attlist,
-      db.topic.info,
-      db.navigation.components*,
-      db.toplevel.blocks.or.sections,
-      db.navigation.components*
-    }
-}

+ 0 - 221
stylesheets/lfs-xsl/docbook-xsl-1.78.1/assembly/topic-maker-chunk.xsl

@@ -1,221 +0,0 @@
-<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
-                xmlns:exsl="http://exslt.org/common"
-                xmlns:xlink="http://www.w3.org/1999/xlink"
-                xmlns="http://docbook.org/ns/docbook"
-		version="1.0"
-                exclude-result-prefixes="exsl">
-
-<!-- ********************************************************************
-     $Id: topic-maker-chunk.xsl,v 1.7 2012-04-16 00:29:35 bobs Exp $
-     ********************************************************************
--->
-
-<xsl:import href="topic-maker.xsl"/>
-
-<xsl:import href="../xhtml/chunk-common.xsl"/>
-
-<xsl:include href="../xhtml/chunk-code.xsl"/>
-
-<xsl:param name="root.id.suffix">-info</xsl:param>
-<xsl:param name="root.as.resourceref" select="1"/>
-
-<xsl:template match="/" priority="1">
-  <xsl:apply-templates select="/" mode="process.root"/>
-
-  <xsl:call-template name="make.assembly"/>
-
-</xsl:template>
-
-<xsl:template name="chunk-element-content">
-  <xsl:param name="content">
-    <xsl:apply-imports/>
-  </xsl:param>
-
-  <xsl:copy-of select="$content"/>
-</xsl:template>
-
-<xsl:template name="make.assembly">
-  <xsl:variable name="content">
-    <assembly xmlns:xlink="http://www.w3.org/1999/xlink">
-      <xsl:call-template name="make.resources"/>
-      <xsl:call-template name="make.structure"/>
-    </assembly>
-  </xsl:variable>
-
-  <xsl:variable name="filename">
-    <xsl:if test="$manifest.in.base.dir != 0">
-      <xsl:value-of select="$base.dir"/>
-    </xsl:if>
-    <xsl:value-of select="$assembly.filename"/>
-  </xsl:variable>
-
-  <xsl:call-template name="write.chunk">
-    <xsl:with-param name="content" select="$content"/>
-    <xsl:with-param name="filename" select="$filename"/>
-    <xsl:with-param name="indent">yes</xsl:with-param>
-  </xsl:call-template>
-
-</xsl:template>
-
-<xsl:template name="make.structure">
-  <xsl:param name="root" select="/*[1]"/>
-
-  <xsl:param name="root.resourceref">
-    <xsl:call-template name="object.id">
-      <xsl:with-param name="object" select="$root"/>
-    </xsl:call-template>
-  </xsl:param>
-
-  <xsl:choose>
-    <xsl:when test="$root.as.resourceref = 0">
-      <structure>
-        <xsl:attribute name="type">
-          <xsl:value-of select="local-name($root)"/>
-        </xsl:attribute>
-        <xsl:attribute name="xml:id">
-          <xsl:value-of select="$root.resourceref"/>
-        </xsl:attribute>
-    
-        <xsl:copy-of select="($root/title | $root/info/title)[1]"/>
-    
-        <!-- Put the title and info stuff in a content-only module -->
-        <module resourceref="{$root.resourceref}{$root.id.suffix}" contentonly="true"/>
-        <xsl:apply-templates select="$root/*" mode="module.list"/>
-      </structure>
-    </xsl:when>
-    <xsl:otherwise>
-      <structure>
-        <xsl:attribute name="resourceref">
-          <xsl:value-of select="$root.resourceref"/>
-        </xsl:attribute>
-
-        <output renderas="{local-name($root)}"/>
-
-        <xsl:apply-templates select="$root/*" mode="module.list"/>
-      </structure>
-    </xsl:otherwise>
-  </xsl:choose>
-</xsl:template>
-
-<xsl:template match="*" mode="module.list">
-  <xsl:variable name="is.chunk">
-    <xsl:call-template name="chunk">
-      <xsl:with-param name="node" select="."/>
-    </xsl:call-template>
-  </xsl:variable>
-
-  <!-- generate an output element for renderas? -->
-  <xsl:variable name="src.element" select="concat(' ', local-name(.), ' ')"/>
-
-  <xsl:variable name="is.topic">
-    <xsl:choose>
-      <xsl:when test="contains($topic.list, $src.element)">1</xsl:when>
-      <xsl:otherwise>0</xsl:otherwise>
-    </xsl:choose>
-  </xsl:variable>
-
-  <xsl:if test="$is.chunk = 1">
-    <module>
-      <xsl:attribute name="resourceref">
-        <xsl:call-template name="object.id"/>
-      </xsl:attribute>
-
-      <xsl:if test="$is.topic = 1">
-        <output renderas="{local-name()}"/>
-      </xsl:if>
-
-      <xsl:apply-templates select="*" mode="module.list"/>
-    </module>
-  </xsl:if>
-</xsl:template>
-
-<xsl:template name="make.resources">
-  <resources>
-    <!-- Add xml:base from $base.dir if manifest not in base.dir -->
-    <xsl:if test="string-length($base.dir) != 0 and
-                  $manifest.in.base.dir = 0">
-      <xsl:attribute name="xml:base">
-        <!-- strip off trailing slash for xml:base -->
-        <xsl:choose>
-          <xsl:when test="substring($base.dir, string-length($base.dir),1) = '/'">
-            <xsl:value-of select="substring($base.dir, 1, string-length($base.dir) -1)"/>
-          </xsl:when>
-          <xsl:otherwise>
-            <xsl:value-of select="$base.dir"/>
-          </xsl:otherwise>
-        </xsl:choose>
-      </xsl:attribute>
-    </xsl:if>
-    <xsl:apply-templates select="/*[1]" mode="resource.list"/>
-  </resources>
-</xsl:template>
-
-<xsl:template match="*" mode="resource.list">
-  <xsl:variable name="is.chunk">
-    <xsl:call-template name="chunk">
-      <xsl:with-param name="node" select="."/>
-    </xsl:call-template>
-  </xsl:variable>
-
-  <xsl:if test="$is.chunk = 1">
-    <resource>
-      <xsl:attribute name="fileref">
-        <!--
-        <xsl:if test="$manifest.in.base.dir = 0">
-          <xsl:value-of select="$base.dir"/>
-        </xsl:if>
-        -->
-        <xsl:apply-templates select="." mode="chunk-filename"/>
-      </xsl:attribute>
-
-      <xsl:attribute name="xml:id">
-        <xsl:call-template name="object.id"/>
-      </xsl:attribute>
-
-      <xsl:variable name="title">
-        <xsl:apply-templates select="." mode="title.markup"/>
-      </xsl:variable>
-      <xsl:if test="string-length($title) != 0">
-        <description>
-          <xsl:value-of select="$title"/>
-        </description>
-      </xsl:if>
-
-    </resource>
-  </xsl:if>
-
-  <xsl:apply-templates select="*" mode="resource.list"/>
-</xsl:template>
-
-<!-- special case for root id on structure element -->
-<xsl:template match="/*" mode="resource.list">
-  <xsl:param name="root.resourceref">
-    <xsl:call-template name="object.id">
-      <xsl:with-param name="object" select="."/>
-    </xsl:call-template>
-  </xsl:param>
-
-  <resource>
-    <xsl:attribute name="fileref">
-      <xsl:apply-templates select="." mode="chunk-filename"/>
-    </xsl:attribute>
-    <xsl:attribute name="xml:id">
-      <xsl:choose>
-        <xsl:when test="$root.as.resourceref = 0">
-          <xsl:value-of select="concat($root.resourceref,$root.id.suffix)"/>
-        </xsl:when>
-        <xsl:otherwise>
-          <xsl:value-of select="$root.resourceref"/>
-        </xsl:otherwise>
-      </xsl:choose>
-    </xsl:attribute>
-  </resource>
-  <xsl:apply-templates select="*" mode="resource.list"/>
-</xsl:template>
-
-<!-- This one must be here because of the template in chunk-code.xsl -->
-<xsl:template match="@fileref" priority="1">
-    <xsl:copy-of select="."/>
-</xsl:template>
-
-</xsl:stylesheet>

+ 0 - 78
stylesheets/lfs-xsl/docbook-xsl-1.78.1/assembly/topic-maker.xsl

@@ -1,78 +0,0 @@
-<?xml version="1.0" encoding="utf-8"?>
-<xsl:stylesheet 
-  xmlns:xsl="http://www.w3.org/1999/XSL/Transform" 
-  xmlns:exsl="http://exslt.org/common"
-  xmlns="http://docbook.org/ns/docbook"
-  exclude-result-prefixes="exsl"
-  version="1.0">
-
-<!-- $Id: topic-maker.xsl,v 1.3 2012-04-16 00:29:35 bobs Exp $ -->
-
-<!-- This stylesheet convert DocBook elements into topic element.
-     The chunking takes place elsewhere.  -->
-
-<xsl:import href="../xhtml/docbook.xsl"/>
-    
-    
-<xsl:param name="assembly.filename">myassembly.xml</xsl:param>
-<xsl:param name="chunk.section.depth" select="3"/>
-<xsl:param name="chunk.first.sections" select="1"/>
-<xsl:param name="use.id.as.filename" select="1"/>
-<xsl:param name="html.ext">.xml</xsl:param> 
-<xsl:param name="base.dir">topics/</xsl:param>
-<xsl:param name="root.filename" select="local-name(/*)"/>
-<xsl:param name="html.extra.head.links" select="0"/>
-<xsl:param name="stylesheet.result.type">xhtml</xsl:param>
-<xsl:param name="navig.showtitles" select="0"/>
-<xsl:param name="suppress.navigation" select="1"/>
-<xsl:param name="chunk.append"/>
-<xsl:param name="chunk.quietly" select="0"/>
-<xsl:param name="chunker.output.method" select="'xml'"/>
-<xsl:param name="chunker.output.encoding" select="'UTF-8'"/>
-<xsl:param name="chunker.output.indent" select="'no'"/>
-<xsl:param name="chunker.output.omit-xml-declaration" select="'no'"/>
-<xsl:param name="chunker.output.standalone" select="'no'"/>
-<xsl:param name="chunker.output.doctype-public" select="''"/>
-<xsl:param name="chunker.output.doctype-system" select="''"/>
-<xsl:param name="namespace">http://docbook.org/ns/docbook</xsl:param>
-
-<!-- These elements are converted to topic elements -->
-<xsl:param name="topic.elements">preface chapter article section</xsl:param>
-<xsl:variable name="topic.list"
-              select="concat(' ', normalize-space($topic.elements), ' ')"/>
-
-<!-- Default behavior is identity copy -->
-<xsl:template match="node()|@*">
-    <xsl:copy>
-      <xsl:apply-templates select="@*"/>
-      <xsl:apply-templates/>
-   </xsl:copy>
-</xsl:template>
-
-<xsl:template match="preface|chapter|appendix|section|article">
-  <xsl:variable name="element.name">
-    <xsl:call-template name="element.name"/>
-  </xsl:variable>
-
-  <xsl:element name="{$element.name}" namespace="{$namespace}">
-    <xsl:apply-templates select="@*"/>
-    <xsl:apply-templates/>
-  </xsl:element>
-</xsl:template>
-
-<xsl:template name="element.name">
-  <xsl:param name="node" select="."/>
-
-  <xsl:variable name="src.element" select="concat(' ', local-name($node), ' ')"/>
-  <xsl:choose>
-    <xsl:when test="contains($topic.list, $src.element)">
-      <xsl:text>topic</xsl:text>
-    </xsl:when>
-    <xsl:otherwise>
-      <xsl:value-of select="local-name($node)"/>
-    </xsl:otherwise>
-  </xsl:choose>
-</xsl:template>
-
-</xsl:stylesheet>
-

+ 0 - 8
stylesheets/lfs-xsl/docbook-xsl-1.78.1/catalog.xml

@@ -1,8 +0,0 @@
-<?xml version="1.0" encoding="utf-8"?>
-<catalog xmlns="urn:oasis:names:tc:entity:xmlns:xml:catalog">
-  <!-- XML Catalog file for DocBook XSL Stylesheets vsnapshot_9628 -->
-  <rewriteURI uriStartString="http://docbook.sourceforge.net/release/xsl/current/" rewritePrefix="./"/>
-  <rewriteSystem systemIdStartString="http://docbook.sourceforge.net/release/xsl/current/" rewritePrefix="./"/>
-  <rewriteURI uriStartString="http://docbook.sourceforge.net/release/xsl/snapshot_9628/" rewritePrefix="./"/>
-  <rewriteSystem systemIdStartString="http://docbook.sourceforge.net/release/xsl/snapshot_9628/" rewritePrefix="./"/>
-</catalog>

+ 0 - 10
stylesheets/lfs-xsl/docbook-xsl-1.78.1/docsrc/authors.xml

@@ -1,10 +0,0 @@
-<authorgroup xmlns="http://docbook.org/ns/docbook" version="5.0">
-  <author>
-    <personname>
-      <surname>Walsh</surname><firstname>Norman</firstname>
-    </personname>
-  </author>
-  <author>
-    <orgname>The DocBook Project</orgname>
-  </author>
-</authorgroup>

+ 0 - 18
stylesheets/lfs-xsl/docbook-xsl-1.78.1/docsrc/copyright.xml

@@ -1,18 +0,0 @@
-<info xmlns="http://docbook.org/ns/docbook" version="5.0">
-  <copyright>
-    <year>1999-2007</year>
-    <holder>Norman Walsh</holder>
-  </copyright>
-  <copyright>
-    <year>2003</year>
-    <holder>Jiří Kosek</holder>
-  </copyright>
-  <copyright>
-    <year>2004-2007</year>
-    <holder>Steve Ball</holder>
-  </copyright>
-  <copyright>
-    <year>2001-2007</year>
-    <holder>The DocBook Project</holder>
-  </copyright>
-</info>

+ 0 - 23
stylesheets/lfs-xsl/docbook-xsl-1.78.1/docsrc/license.xml

@@ -1,23 +0,0 @@
-<legalnotice xmlns="http://docbook.org/ns/docbook" version="5.0"
-  xml:id="copyright"><title>License</title>
-<para>Permission is hereby granted, free of charge, to any person
-obtaining a copy of this software and associated documentation files
-(the <quote>Software</quote>), to deal in the Software without
-restriction, including without limitation the rights to use, copy,
-modify, merge, publish, distribute, sublicense, and/or sell copies of
-the Software, and to permit persons to whom the Software is furnished
-to do so, subject to the following conditions:
-</para>
-<para>The above copyright notice and this permission notice shall be
-included in all copies or substantial portions of the Software.</para>
-<para>Except as contained in this notice, the names of individuals
-credited with contribution to this software shall not be used in
-advertising or otherwise to promote the sale, use or other dealings in
-this Software without prior written authorization from the individuals
-in question.</para>
-<para>Any stylesheet derived from this Software that is publically
-distributed will be identified with a different name and the version
-strings in any derived Software will be changed so that no possibility
-of confusion between the derived package and this Software will
-exist.</para>
-</legalnotice>

BIN
stylesheets/lfs-xsl/docbook-xsl-1.78.1/docsrc/page.png


+ 0 - 79
stylesheets/lfs-xsl/docbook-xsl-1.78.1/docsrc/reference.css

@@ -1,79 +0,0 @@
-/* reference.css, a stylesheet for reference documentation
- * generated by the DocBook XSL Stylesheets */
-/* $Id: reference.css 8234 2009-02-09 12:10:48Z xmldoc $ */
-
-div.legalnotice {
-  font-size: 80%;
-}
-
-div.note, div.tip, div.warning {
-  margin-left: 5%;
-  margin-right: 10%;
-  padding: 5px;
-}
-
-div.note, div.tip {
-  border-left: solid #d5dee3 20px;
-  border-right: solid #d5dee3 20px;
-}
-
-div.note, div.tip {
-  border-left: solid palegreen 20px;
-  border-right: solid palegreen 20px;
-}
-
-div.warning {
-  border-left: solid yellow 20px;
-  border-right: solid yellow 20px;
-}
-
-div.note p, div.tip p, div.warning p {
-  margin-top: 0px;
-  margin-bottom: 4px;
-}
-
-div.note h3, div.tip h3, div.warning h3 {
-  margin-top: 0;
-}
-
-div.informalexample {
-  background-color: #d5dee3;
-  border-top-width: 2px;
-  border-top-style: double;
-  border-top-color: #d3d3d3;
-  border-bottom-width: 2px;
-  border-bottom-style: double;
-  border-bottom-color: #d3d3d3;
-  padding: 4px;
-  margin: 0em;
-  margin-left: 2em;
-}
-
-pre.programlisting, pre.synopsis {
-  whitespace: pre;
-  font-family: monospace;
-  background-color: #d5dee3;
-  border-top-width: 1px;
-  border-top-style: single;
-  border-top-color: #d3d3d3;
-  border-bottom-width: 1px;
-  border-bottom-style: single;
-  border-bottom-color: #d3d3d3;
-  padding: 4px;
-  margin: 0em;
-  margin-top: 6px;
-  margin-bottom: 6px;
-}
-
-div.informalexample pre {
-  whitespace: pre;
-  font-family: monospace;
-  border-top-width: 0px;
-  border-bottom-width: 0px;
-  padding: 0px;
-}
-
-/* Parameter and PI titles */
-  div.refnamediv h2 {
-  font-size: 2em; 
-}

+ 0 - 241
stylesheets/lfs-xsl/docbook-xsl-1.78.1/docsrc/reference.xml

@@ -1,241 +0,0 @@
-<set xmlns="http://docbook.org/ns/docbook" version="5.0"
-  xmlns:xi="http://www.w3.org/2001/XInclude"
-  xmlns:src="http://nwalsh.com/xmlns/litprog/fragment"
-  xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
-  xmlns:xlink="http://www.w3.org/1999/xlink"
-  xml:base="../docsrc/"
-  >
-  <!-- * WARNING WARNING WARNING -->
-  <!-- * WARNING WARNING WARNING -->
-  <!-- * -->
-  <!-- * This document has duplicate IDs in it and is intended for -->
-  <!-- * processing using the chunk.xsl stylesheet to generate chunked -->
-  <!-- * output from it (not for generating a single HTML output file) -->
-  <!-- * -->
-  <!-- * WARNING WARNING WARNING -->
-  <!-- * WARNING WARNING WARNING -->
-  <title>DocBook XSL Stylesheets: Reference Documentation</title>
-  <info><releaseinfo role="meta">$Id: reference.xml 9625 2012-10-20 23:12:33Z dcramer $ </releaseinfo>
-    <xi:include href="./authors.xml"/>
-    <xi:include href="./copyright.xml" xpointer="xpointer(//*[local-name() = 'copyright'])"/>
-    <xi:include href="./license.xml"/>
-    <xi:include href="./warranty.xml"/>
-    <abstract xml:id="about">
-      <title>About this document</title>
-      <para>This is generated reference documentation for the DocBook
-        XSL stylesheets. It is available in the following formats:
-        <itemizedlist>
-          <listitem>
-            <para><link
-                xlink:href="http://docbook.sourceforge.net/release/xsl/current/doc/reference.html"
-                >HTML</link>,
-              <link
-                xlink:href="http://docbook.sourceforge.net/release/xsl/current/doc/reference.pdf"
-                >PDF</link>,
-              <link
-                xlink:href="http://docbook.sourceforge.net/release/xsl/current/doc/reference.txt"
-                >plain text</link></para>
-          </listitem>
-        </itemizedlist>
-        This is primarily documentation on the parameters and processing instructions you can use
-        to control the behavior of the stylesheets.
-        <note>
-          <para>This is purely reference documentation&#xa0;– not how-to
-            documentation. For a thorough step-by-step how-to guide to
-            publishing content using the DocBook XSL stylesheets, see
-            Bob Stayton’s <link 
-              xlink:href="http://www.sagehill.net/book-description.html"
-              >DocBook XSL: The Complete Guide</link>, available online
-            at <link
-              xlink:href="http://www.sagehill.net/docbookxsl/index.html"
-              >http://www.sagehill.net/docbookxsl/index.html</link>
-          </para>
-        </note>
-        This document is divided into three sets of references:
-        the first two sets provides user documentation; the third,
-        developer documentation.</para>
-    </abstract>
-  </info>
-  <book xml:id="param"><title>DocBook XSL Stylesheets User Reference: Parameters</title>
-    <info>
-      <abstract>
-        <para>This is generated reference documentation for all
-          user-configurable parameters in the DocBook XSL
-          stylesheets.
-          <note>
-            <para>This is purely reference documentation&#xa0;– not how-to
-              documentation. For a thorough step-by-step how-to guide to
-              publishing content using the DocBook XSL stylesheets, see
-              Bob Stayton’s <link 
-                xlink:href="http://www.sagehill.net/book-description.html"
-                >DocBook XSL: The Complete Guide</link>, available online
-              at <link
-                xlink:href="http://www.sagehill.net/docbookxsl/index.html"
-                >http://www.sagehill.net/docbookxsl/index.html</link>
-            </para>
-          </note>
-        </para>
-      </abstract>
-    </info>
-    <part xml:id="html">
-      <?dbhtml dir="html"?>
-      <?dbhtml filename="index.html"?>
-      <xi:include href="../html/param.xml" xpointer="xpointer(/book/info/title)" />
-      <partintro xml:id="htmlintro">
-        <xi:include href="../html/param.xml" xpointer="xpointer(/book/info/abstract/node())" />
-      </partintro>
-      <xi:include href="../html/param.xml" xpointer="xpointer(/book/reference)" />
-    </part>
-    <part xml:id="fo">
-      <?dbhtml dir="fo"?>
-      <?dbhtml filename="index.html"?>
-      <xi:include href="../fo/param.xml" xpointer="xpointer(/book/info/title)" />
-      <partintro xml:id="fointro">
-        <xi:include href="../fo/param.xml" xpointer="xpointer(/book/info/abstract/node())" />
-      </partintro>
-      <xi:include href="../fo/param.xml" xpointer="xpointer(/book/reference)" />
-    </part>
-    <part xml:id="manpages">
-      <?dbhtml dir="manpages"?>
-      <?dbhtml filename="index.html"?>
-      <xi:include href="../manpages/param.xml" xpointer="xpointer(/book/info/title)" />
-      <partintro xml:id="manintro">
-        <xi:include href="../manpages/param.xml" xpointer="xpointer(/book/info/abstract/node())" />
-      </partintro>
-      <xi:include href="../manpages/param.xml" xpointer="xpointer(/book/reference)" />
-    </part>
-    <part xml:id="roundtrip">
-      <?dbhtml dir="roundtrip"?>
-      <?dbhtml filename="index.html"?>
-      <xi:include href="../roundtrip/param.xml" xpointer="xpointer(/book/info/title)" />
-      <partintro xml:id="roundtripintro">
-        <xi:include href="../roundtrip/param.xml" xpointer="xpointer(/book/info/abstract/node())" />
-      </partintro>
-      <xi:include href="../roundtrip/param.xml" xpointer="xpointer(/book/reference/node()[not(self::title)])" />
-    </part>
-    <part xml:id="slides"><title>Slides Parameter Reference</title>
-      <?dbhtml dir="slides"?>
-      <?dbhtml filename="index.html"?>
-      <partintro xml:id="slidesintro">
-        <para>This is reference documentation for all
-          user-configurable parameters in the DocBook XSL Slides
-          stylesheets (for generating HTML and PDF slide
-          presentations).</para>
-        <note>
-          <para>The Slides stylesheet for HTML output is a
-            customization layer of the DocBook XSL HTML
-            stylesheet; the Slides stylesheet for FO output is a
-            customization layer of the DocBook XSL FO stylesheet.
-            Therefore, in addition to the slides-specific
-            parameters listed in this section, you can also use a
-            number of <link xlink:href="../html">HTML stylesheet
-              parameters</link> and <link xlink:href="../fo">FO
-              stylesheet parameters</link> to control Slides
-            output.</para>
-        </note>
-      </partintro>
-      <xi:include href="../slides/xhtml/param.xml" xpointer="xpointer(/book/reference)" />
-      <xi:include href="../slides/fo/param.xml" xpointer="xpointer(/book/reference)" />
-    </part>
-    <part xml:id="website">
-      <?dbhtml dir="website"?>
-      <?dbhtml filename="index.html"?>
-      <xi:include href="../website/param.xml" xpointer="xpointer(/book/info/title)" />
-      <partintro xml:id="websiteintro">
-        <xi:include href="../website/param.xml" xpointer="xpointer(/book/info/abstract/node())" />
-      </partintro>
-      <xi:include href="../website/param.xml" xpointer="xpointer(/book/reference)" />
-    </part>
-   <!-- Prepare WebHelp output
-    <part xml:id="webhelp">
-      <?dbhtml dir="webhelp"?>
-      <?dbhtml filename="index.html"?>
-      <xi:include href="../webhelp/param.xml" xpointer="xpointer(/book/info/title)" />
-      <partintro xml:id="webhelpintro">
-        <xi:include href="../webhelp/param.xml" xpointer="xpointer(/book/info/abstract/node())" />
-      </partintro>
-      <xi:include href="../webhelp/param.xml" xpointer="xpointer(/book/reference)" />
-    </part>
-   -->
-  </book>
- 
-  <book xml:id="pi"><title>DocBook XSL Stylesheets User Reference: PIs</title>
-    <?dbhtml dir="pi"?>
-    <?dbhtml filename="index.html"?>
-    <info>
-      <abstract>
-        <para>This is generated reference documentation for all
-          user-specifiable processing instructions in the DocBook
-          XSL stylesheets.
-          <note>
-            <para>You add these PIs at particular points in a document to
-              cause specific “exceptions” to formatting/output behavior. To
-              make global changes in formatting/output behavior across an
-              entire document, it’s better to do it by setting an
-              appropriate stylesheet parameter (if there is one).</para>
-          </note>
-        </para>
-      </abstract>
-    </info>
-    <part xml:id="pi-html">
-      <xi:include href="../html/pi.xml" xpointer="xpointer(/reference/node())" />
-    </part>
-    <part xml:id="pi-fo">
-      <xi:include href="../fo/pi.xml" xpointer="xpointer(/reference/node())" />
-    </part>
-    <part xml:id="pi-man">
-      <xi:include href="../manpages/pi.xml" xpointer="xpointer(/reference/node())" />
-    </part>
-    <part xml:id="pi-common">
-      <xi:include href="../common/pi.xml" xpointer="xpointer(/reference/node())" />
-    </part>
-  </book>
-  <book xml:id="developer"><title>DocBook XSL Stylesheets Developer Reference</title>
-    <info>
-      <abstract>
-        <para>This is technical reference documentation for
-          developers using the DocBook XSL Stylesheets. It is not
-          intended to be user documentation, but is instead
-          provided for developers writing customization layers for
-          the stylesheets.</para>
-      </abstract>
-    </info>
-    <part xml:id="lib">
-      <?dbhtml dir="lib"?>
-      <?dbhtml filename="index.html"?>
-      <xi:include href="../lib/lib.xml" xpointer="xpointer(/book/info/title)" />
-      <partintro xml:id="libintro">
-        <xi:include href="../lib/lib.xml" xpointer="xpointer(/book/info/abstract/node())" />
-      </partintro>
-      <xi:include href="../lib/lib.xml" xpointer="xpointer(/book/reference)" />
-    </part>
-    <part xml:id="common-part"><title>Common Template Reference</title>
-      <?dbhtml dir="common"?>
-      <?dbhtml filename="index.html"?>
-      <info>
-        <abstract>
-          <para>This is technical reference documentation for the
-            “base”, “refentry”, and “utility” sets of common
-            templates in the DocBook XSL Stylesheets. These
-            templates are “common” in that they are shared across
-            output formats (that is, they’re not
-            output-format-dependent)</para>
-          <para>This documentation is not intended to be user
-            documentation. It is provided for developers writing
-            customization layers for the stylesheets.</para>
-        </abstract>
-      </info>
-        <xi:include href="../common/common.xml"/>
-        <xi:include href="../common/refentry.xml"/>
-        <xi:include href="../common/utility.xml"/>
-        <xi:include href="../common/charmap.xml"/>
-    </part>
-    <part xml:id="table-templates">
-      <xi:include href="../fo/table.xml" xpointer="xpointer(/reference/node())"/>
-    </part>
-    <part xml:id="template"> 
-      <xi:include href="../template/titlepage.xml" xpointer="xpointer(/reference/node())"/>
-    </part>
-  </book>
-</set>
-<!-- * vim: set ft=docbk foldlevel=2: -->

+ 0 - 35597
stylesheets/lfs-xsl/docbook-xsl-1.78.1/docsrc/reference.xml.included

@@ -1,35597 +0,0 @@
-<?xml version="1.0" encoding="ASCII"?><set xmlns="http://docbook.org/ns/docbook" xmlns:xi="http://www.w3.org/2001/XInclude" xmlns:src="http://nwalsh.com/xmlns/litprog/fragment" xmlns:xsl="http://www.w3.org/1999/XSL/Transform" xmlns:xlink="http://www.w3.org/1999/xlink" version="5.0" xml:base="../docsrc/">
-  <!-- * WARNING WARNING WARNING -->
-  <!-- * WARNING WARNING WARNING -->
-  <!-- * -->
-  <!-- * This document has duplicate IDs in it and is intended for -->
-  <!-- * processing using the chunk.xsl stylesheet to generate chunked -->
-  <!-- * output from it (not for generating a single HTML output file) -->
-  <!-- * -->
-  <!-- * WARNING WARNING WARNING -->
-  <!-- * WARNING WARNING WARNING -->
-  <title>DocBook XSL Stylesheets: Reference&#160;Documentation</title>
-  <info><releaseinfo role="meta">$Id: reference.xml 9625 2012-10-20 23:12:33Z dcramer $ </releaseinfo>
-    <authorgroup version="5.0">
-  <author>
-    <personname>
-      <surname>Walsh</surname><firstname>Norman</firstname>
-    </personname>
-  </author>
-  <author>
-    <orgname>The DocBook Project</orgname>
-  </author>
-</authorgroup>
-    <copyright>
-    <year>1999-2007</year>
-    <holder>Norman Walsh</holder>
-  </copyright><copyright>
-    <year>2003</year>
-    <holder>Ji&#345;&#237; Kosek</holder>
-  </copyright><copyright>
-    <year>2004-2007</year>
-    <holder>Steve Ball</holder>
-  </copyright><copyright>
-    <year>2001-2007</year>
-    <holder>The DocBook Project</holder>
-  </copyright>
-    <legalnotice version="5.0" id="copyright"><title>License</title>
-<para>Permission is hereby granted, free of charge, to any person
-obtaining a copy of this software and associated documentation files
-(the <quote>Software</quote>), to deal in the Software without
-restriction, including without limitation the rights to use, copy,
-modify, merge, publish, distribute, sublicense, and/or sell copies of
-the Software, and to permit persons to whom the Software is furnished
-to do so, subject to the following conditions:
-</para>
-<para>The above copyright notice and this permission notice shall be
-included in all copies or substantial portions of the Software.</para>
-<para>Except as contained in this notice, the names of individuals
-credited with contribution to this software shall not be used in
-advertising or otherwise to promote the sale, use or other dealings in
-this Software without prior written authorization from the individuals
-in question.</para>
-<para>Any stylesheet derived from this Software that is publically
-distributed will be identified with a different name and the version
-strings in any derived Software will be changed so that no possibility
-of confusion between the derived package and this Software will
-exist.</para>
-</legalnotice>
-    <legalnotice version="5.0" id="warranty"><title>Warranty</title>
-<para>THE SOFTWARE IS PROVIDED <quote>AS IS</quote>,
-WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT
-LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR
-PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL NORMAN WALSH OR ANY
-OTHER CONTRIBUTOR BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
-WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT
-OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
-THE SOFTWARE.</para>
-</legalnotice>
-    <abstract id="about">
-      <title>About this document</title>
-      <para>This is generated reference documentation for the DocBook
-        XSL stylesheets. It is available in the following formats:
-        <itemizedlist>
-          <listitem>
-            <para><link xlink:href="http://docbook.sourceforge.net/release/xsl/current/doc/reference.html">HTML</link>,
-              <link xlink:href="http://docbook.sourceforge.net/release/xsl/current/doc/reference.pdf">PDF</link>,
-              <link xlink:href="http://docbook.sourceforge.net/release/xsl/current/doc/reference.txt">plain text</link></para>
-          </listitem>
-        </itemizedlist>
-        This is primarily documentation on the parameters and processing instructions you can use
-        to control the behavior of the stylesheets.
-        <note>
-          <para>This is purely reference documentation&#160;&#8211; not how-to
-            documentation. For a thorough step-by-step how-to guide to
-            publishing content using the DocBook XSL stylesheets, see
-            Bob Stayton&#8217;s <link xlink:href="http://www.sagehill.net/book-description.html">DocBook XSL: The Complete Guide</link>, available online
-            at <link xlink:href="http://www.sagehill.net/docbookxsl/index.html">http://www.sagehill.net/docbookxsl/index.html</link>
-          </para>
-        </note>
-        This document is divided into three sets of references:
-        the first two sets provides user documentation; the third,
-        developer documentation.</para>
-    </abstract>
-  </info>
-  <book id="param"><title>DocBook XSL Stylesheets User&#160;Reference:&#160;Parameters</title>
-    <info>
-      <abstract>
-        <para>This is generated reference documentation for all
-          user-configurable parameters in the DocBook XSL
-          stylesheets.
-          <note>
-            <para>This is purely reference documentation&#160;&#8211; not how-to
-              documentation. For a thorough step-by-step how-to guide to
-              publishing content using the DocBook XSL stylesheets, see
-              Bob Stayton&#8217;s <link xlink:href="http://www.sagehill.net/book-description.html">DocBook XSL: The Complete Guide</link>, available online
-              at <link xlink:href="http://www.sagehill.net/docbookxsl/index.html">http://www.sagehill.net/docbookxsl/index.html</link>
-            </para>
-          </note>
-        </para>
-      </abstract>
-    </info>
-    <part id="html">
-      <?dbhtml dir="html"?>
-      <?dbhtml filename="index.html"?>
-      <title xml:base="../html/param.xml">HTML Parameter Reference</title>
-      <partintro id="htmlintro">
-        
-  <para xml:base="../html/param.xml">This is reference documentation for all user-configurable
-  parameters in the DocBook XSL HTML stylesheets (for generating
-  HTML output).</para>
-
-      </partintro>
-      <reference id="admons" xml:base="../html/param.xml"><title>Admonitions</title>
-<refentry version="5.0" id="admon.graphics.extension">
-<refmeta>
-<refentrytitle>admon.graphics.extension</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>admon.graphics.extension</refname>
-<refpurpose>Filename extension for admonition graphics</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="admon.graphics.extension.frag">
-&lt;xsl:param name="admon.graphics.extension"&gt;.png&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Sets the filename extension to use on admonition graphics.</para>
-
-<itemizedlist>
-  <para>The DocBook XSL distribution provides admonition graphics in the following formats:</para>
-  <listitem><para>GIF (extension: <filename class="extension">.gif</filename>)</para></listitem>
-  <listitem><para>PNG (extension: <filename class="extension">.png</filename>)</para></listitem>
-  <listitem><para>SVG (extension: <filename class="extension">.svg</filename>)</para></listitem>
-  <listitem><para>TIFF (extension: <filename class="extension">.tif</filename>)</para></listitem>
-</itemizedlist>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="admon.graphics.path">
-<refmeta>
-<refentrytitle>admon.graphics.path</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>admon.graphics.path</refname>
-<refpurpose>Path to admonition graphics</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="admon.graphics.path.frag">&lt;xsl:param name="admon.graphics.path"&gt;images/&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Sets the path to the directory containing the admonition graphics
-(caution.png, important.png etc). This location is normally relative
-to the output html directory. See <parameter>base.dir</parameter></para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="admon.graphics">
-<refmeta>
-<refentrytitle>admon.graphics</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>admon.graphics</refname>
-<refpurpose>Use graphics in admonitions?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="admon.graphics.frag">
-&lt;xsl:param name="admon.graphics" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If true (non-zero), admonitions are presented in an alternate style that uses
-a graphic.  Default graphics are provided in the distribution.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="admon.textlabel">
-<refmeta>
-<refentrytitle>admon.textlabel</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>admon.textlabel</refname>
-<refpurpose>Use text label in admonitions?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="admon.textlabel.frag">
-&lt;xsl:param name="admon.textlabel" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If true (non-zero), admonitions are presented with a generated
-text label such as Note or Warning in the appropriate language.
-If zero, such labels are turned off, but any title child
-of the admonition element are still output.
-The default value is 1.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="admon.style">
-<refmeta>
-<refentrytitle>admon.style</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>admon.style</refname>
-<refpurpose>Specifies the CSS style attribute that should be added to
-admonitions.</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="admon.style.frag">&lt;xsl:param name="admon.style"&gt;
-  &lt;xsl:value-of select="concat('margin-', $direction.align.start,            ': 0.5in; margin-', $direction.align.end, ': 0.5in;')"&gt;&lt;/xsl:value-of&gt;
-&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Specifies the value of the CSS <tag class="attribute">style</tag>
-attribute that should be added to admonitions.
-</para>
-
-</refsection>
-</refentry>
-
-</reference><reference id="callouts" xml:base="../html/param.xml"><title>Callouts</title>
-<refentry version="5.0" id="callout.defaultcolumn">
-<refmeta>
-<refentrytitle>callout.defaultcolumn</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">integer</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>callout.defaultcolumn</refname>
-<refpurpose>Indicates what column callouts appear in by default</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="callout.defaultcolumn.frag">
-&lt;xsl:param name="callout.defaultcolumn"&gt;60&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If a callout does not identify a column (for example, if it uses
-the <literal>linerange</literal> <tag class="attribute">unit</tag>),
-it will appear in the default column.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="callout.graphics.extension">
-<refmeta>
-<refentrytitle>callout.graphics.extension</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>callout.graphics.extension</refname>
-<refpurpose>Filename extension for callout graphics</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="callout.graphics.extension.frag">
-&lt;xsl:param name="callout.graphics.extension"&gt;.png&lt;/xsl:param&gt;
-
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-<para>Sets the filename extension to use on callout graphics. </para>
-
-<itemizedlist>
-<para>The Docbook XSL distribution provides callout graphics in the following formats:</para>
-<listitem><para>SVG (extension: <filename class="extension">.svg</filename>)</para></listitem>
-<listitem><para>PNG (extension: <filename class="extension">.png</filename>)</para></listitem>
-<listitem><para>GIF (extension: <filename class="extension">.gif</filename>)</para></listitem>
-</itemizedlist>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="callout.graphics.number.limit">
-<refmeta>
-<refentrytitle>callout.graphics.number.limit</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">integer</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>callout.graphics.number.limit</refname>
-<refpurpose>Number of the largest callout graphic</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="callout.graphics.number.limit.frag">
-&lt;xsl:param name="callout.graphics.number.limit"&gt;15&lt;/xsl:param&gt;
-
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If <parameter>callout.graphics</parameter> is non-zero, graphics
-are used to represent callout numbers instead of plain text. The value
-of <parameter>callout.graphics.number.limit</parameter> is the largest
-number for which a graphic exists. If the callout number exceeds this
-limit, the default presentation "(plain text instead of a graphic)"
-will  be used.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="callout.graphics.path">
-<refmeta>
-<refentrytitle>callout.graphics.path</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>callout.graphics.path</refname>
-<refpurpose>Path to callout graphics</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="callout.graphics.path.frag">
-&lt;xsl:param name="callout.graphics.path"&gt;images/callouts/&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Sets the path to the directory holding the callout graphics. his
-location is normally relative to the output html directory. see
-base.dir. Always terminate the directory with / since the graphic file
-is appended to this string, hence needs the separator.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="callout.graphics">
-<refmeta>
-<refentrytitle>callout.graphics</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>callout.graphics</refname>
-<refpurpose>Use graphics for callouts?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="callout.graphics.frag">
-&lt;xsl:param name="callout.graphics" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, callouts are presented with graphics (e.g., reverse-video
-circled numbers instead of "(1)", "(2)", etc.).
-Default graphics are provided in the distribution.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="callout.list.table">
-<refmeta>
-<refentrytitle>callout.list.table</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>callout.list.table</refname>
-<refpurpose>Present callout lists using a table?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="callout.list.table.frag">
-&lt;xsl:param name="callout.list.table" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The default presentation of <tag>calloutlist</tag>s uses
-an HTML <tag>DL</tag> element. Some browsers don't align DLs very well
-if <parameter>callout.graphics</parameter> is used. With this option
-turned on, <tag>calloutlist</tag>s are presented in an HTML
-<tag>TABLE</tag>, which usually results in better alignment
-of the callout number with the callout description.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="callout.unicode.number.limit">
-<refmeta>
-<refentrytitle>callout.unicode.number.limit</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">integer</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>callout.unicode.number.limit</refname>
-<refpurpose>Number of the largest unicode callout character</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="callout.unicode.number.limit.frag">
-&lt;xsl:param name="callout.unicode.number.limit"&gt;10&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If <parameter>callout.unicode</parameter>
-is non-zero, unicode characters are used to represent
-callout numbers. The value of
-<parameter>callout.unicode.number.limit</parameter>
-is
-the largest number for which a unicode character exists. If the callout number
-exceeds this limit, the default presentation "(nnn)" will always
-be used.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="callout.unicode.start.character">
-<refmeta>
-<refentrytitle>callout.unicode.start.character</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">integer</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>callout.unicode.start.character</refname>
-<refpurpose>First Unicode character to use, decimal value.</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="callout.unicode.start.character.frag">
-&lt;xsl:param name="callout.unicode.start.character"&gt;10102&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If <parameter>callout.graphics</parameter> is zero and <parameter>callout.unicode</parameter>
-is non-zero, unicode characters are used to represent
-callout numbers. The value of
-<parameter>callout.unicode.start.character</parameter>
-is the decimal unicode value used for callout number one. Currently, 
-only values 9312 and 10102 are supported in the stylesheets for this parameter. 
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="callout.unicode">
-<refmeta>
-<refentrytitle>callout.unicode</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>callout.unicode</refname>
-<refpurpose>Use Unicode characters rather than images for callouts.</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="callout.unicode.frag">&lt;xsl:param name="callout.unicode" select="0"&gt;&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The stylesheets can use either an image of the numbers one to ten, or the single Unicode character which represents the numeral, in white on a black background. Use this to select the Unicode character option.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="callouts.extension">
-<refmeta>
-<refentrytitle>callouts.extension</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>callouts.extension</refname>
-<refpurpose>Enable the callout extension</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="callouts.extension.frag">
-&lt;xsl:param name="callouts.extension" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The callouts extension processes <tag>areaset</tag>
-elements in <tag>programlistingco</tag> and other text-based
-callout elements.
-</para>
-
-</refsection>
-</refentry>
-
-</reference><reference id="ebnf" xml:base="../html/param.xml"><title>EBNF</title>
-<refentry version="5.0" id="ebnf.table.bgcolor">
-<refmeta>
-<refentrytitle>ebnf.table.bgcolor</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">color</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>ebnf.table.bgcolor</refname>
-<refpurpose>Background color for EBNF tables</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="ebnf.table.bgcolor.frag">
-&lt;xsl:param name="ebnf.table.bgcolor"&gt;#F5DCB3&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Sets the background color for EBNF tables (a pale brown). No
-<tag>bgcolor</tag> attribute is output if
-<parameter>ebnf.table.bgcolor</parameter> is set to the null string. </para>
-
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="ebnf.table.border">
-<refmeta>
-<refentrytitle>ebnf.table.border</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>ebnf.table.border</refname>
-<refpurpose>Selects border on EBNF tables</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="ebnf.table.border.frag">&lt;xsl:param name="ebnf.table.border" select="1"&gt;&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Selects the border on EBNF tables. If non-zero, the tables have
-borders, otherwise they don't.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="ebnf.assignment">
-<refmeta>
-<refentrytitle>ebnf.assignment</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">rtf</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>ebnf.assignment</refname>
-<refpurpose>The EBNF production assignment operator</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="ebnf.assignment.frag">
-&lt;xsl:param name="ebnf.assignment"&gt;
-&lt;code&gt;::=&lt;/code&gt;
-&lt;/xsl:param&gt;
-
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The <parameter>ebnf.assignment</parameter> parameter determines what
-text is used to show <quote>assignment</quote> in <tag>production</tag>s
-in <tag>productionset</tag>s.</para>
-
-<para>While <quote><literal>::=</literal></quote> is common, so are several
-other operators.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="ebnf.statement.terminator">
-<refmeta>
-<refentrytitle>ebnf.statement.terminator</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">rtf</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>ebnf.statement.terminator</refname>
-<refpurpose>Punctuation that ends an EBNF statement.</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="ebnf.statement.terminator.frag">
-&lt;xsl:param name="ebnf.statement.terminator"&gt;&lt;/xsl:param&gt;
-
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The <parameter>ebnf.statement.terminator</parameter> parameter determines what
-text is used to terminate each <tag>production</tag>
-in <tag>productionset</tag>.</para>
-
-<para>Some notations end each statement with a period.</para>
-
-</refsection>
-</refentry>
-
-</reference><reference id="toc_index" xml:base="../html/param.xml"><title>ToC/LoT/Index Generation</title>
-<refentry version="5.0" id="annotate.toc">
-<refmeta>
-<refentrytitle>annotate.toc</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>annotate.toc</refname>
-<refpurpose>Annotate the Table of Contents?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="annotate.toc.frag">&lt;xsl:param name="annotate.toc" select="1"&gt;&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If true, TOCs will be annotated. At present, this just means
-that the <tag>refpurpose</tag> of <tag>refentry</tag>
-TOC entries will be displayed.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="autotoc.label.separator">
-<refmeta>
-<refentrytitle>autotoc.label.separator</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>autotoc.label.separator</refname>
-<refpurpose>Separator between labels and titles in the ToC</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="autotoc.label.separator.frag">
-&lt;xsl:param name="autotoc.label.separator"&gt;. &lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>String used to separate labels and titles in a table of contents.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="autotoc.label.in.hyperlink">
-<refmeta>
-<refentrytitle>autotoc.label.in.hyperlink</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>autotoc.label.in.hyperlink</refname>
-<refpurpose>Include label in hyperlinked titles in TOC?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="autotoc.label.in.hyperlink.frag">&lt;xsl:param name="autotoc.label.in.hyperlink" select="1"&gt;&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If the value of
-<parameter>autotoc.label.in.hyperlink</parameter> is non-zero, labels
-are included in hyperlinked titles in the TOC. If it is instead zero,
-labels are still displayed prior to the hyperlinked titles, but
-are not hyperlinked along with the titles.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="process.source.toc">
-<refmeta>
-<refentrytitle>process.source.toc</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>process.source.toc</refname>
-<refpurpose>Process a non-empty <tag>toc</tag> element if it occurs in a source document?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="process.source.toc.frag">&lt;xsl:param name="process.source.toc" select="0"&gt;&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Specifies that the contents of a non-empty "hard-coded"
-<tag>toc</tag> element in a source document are processed to
-generate a TOC in output.
-<note>
-  <para>This parameter has no effect on automated generation of
-  TOCs. An automated TOC may still be generated along with the
-  "hard-coded" TOC. To suppress automated TOC generation, adjust the
-  value of the <parameter>generate.toc</parameter> paramameter.</para>
-
-  <para>The <tag>process.source.toc</tag> parameter also has
-  no effect if the <tag>toc</tag> element is empty; handling
-  for empty <tag>toc</tag> is controlled by the
-  <parameter>process.empty.source.toc</parameter> parameter.</para>
-</note>
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="process.empty.source.toc">
-<refmeta>
-<refentrytitle>process.empty.source.toc</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>process.empty.source.toc</refname>
-<refpurpose>Generate automated TOC if <tag>toc</tag> element occurs in a source document?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="process.empty.source.toc.frag">&lt;xsl:param name="process.empty.source.toc" select="0"&gt;&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Specifies that if an empty <tag>toc</tag> element is found in a
-source document, an automated TOC is generated at this point in the
-document.
-<note>
-  <para>Depending on what the value of the
-  <parameter>generate.toc</parameter> parameter is, setting this
-  parameter to <literal>1</literal> could result in generation of
-  duplicate automated TOCs. So the
-  <parameter>process.empty.source.toc</parameter> is primarily useful
-  as an "override": by placing an empty <tag>toc</tag> in your
-  document and setting this parameter to <literal>1</literal>, you can
-  force a TOC to be generated even if <tag>generate.toc</tag>
-  says not to.</para>
-</note>
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="bridgehead.in.toc">
-<refmeta>
-<refentrytitle>bridgehead.in.toc</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>bridgehead.in.toc</refname>
-<refpurpose>Should bridgehead elements appear in the TOC?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="bridgehead.in.toc.frag">&lt;xsl:param name="bridgehead.in.toc" select="0"&gt;&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, <tag>bridgehead</tag>s appear in the TOC. Note that
-this option is not fully supported and may be removed in a future
-version of the stylesheets.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="simplesect.in.toc">
-<refmeta>
-<refentrytitle>simplesect.in.toc</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>simplesect.in.toc</refname>
-<refpurpose>Should <tag>simplesect</tag> elements appear in the TOC?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="simplesect.in.toc.frag">&lt;xsl:param name="simplesect.in.toc" select="0"&gt;&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, <tag>simplesect</tag>s will be included in the TOC.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="manual.toc">
-<refmeta>
-<refentrytitle>manual.toc</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>manual.toc</refname>
-<refpurpose>An explicit TOC to be used for the TOC</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="manual.toc.frag">
-&lt;xsl:param name="manual.toc"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The <parameter>manual.toc</parameter> identifies an explicit TOC that
-will be used for building the printed TOC.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="toc.list.type">
-<refmeta>
-<refentrytitle>toc.list.type</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">list</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">dl</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">ul</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">ol</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>toc.list.type</refname>
-<refpurpose>Type of HTML list element to use for Tables of Contents</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="toc.list.type.frag">&lt;xsl:param name="toc.list.type"&gt;dl&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>When an automatically generated Table of Contents (or List of Titles)
-is produced, this HTML element will be used to make the list.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="toc.section.depth">
-<refmeta>
-<refentrytitle>toc.section.depth</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">integer</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>toc.section.depth</refname>
-<refpurpose>How deep should recursive <tag>section</tag>s appear
-in the TOC?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="toc.section.depth.frag">&lt;xsl:param name="toc.section.depth"&gt;2&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Specifies the depth to which recursive sections should appear in the
-TOC.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="toc.max.depth">
-<refmeta>
-<refentrytitle>toc.max.depth</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">integer</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>toc.max.depth</refname>
-<refpurpose>How many levels should be created for each TOC?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="toc.max.depth.frag">&lt;xsl:param name="toc.max.depth"&gt;8&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Specifies the maximal depth of TOC on all levels.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="generate.toc">
-<refmeta>
-<refentrytitle>generate.toc</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">table</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>generate.toc</refname>
-<refpurpose>Control generation of ToCs and LoTs</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="generate.toc.frag">
-&lt;xsl:param name="generate.toc"&gt;
-appendix  toc,title
-article/appendix  nop
-article   toc,title
-book      toc,title,figure,table,example,equation
-chapter   toc,title
-part      toc,title
-preface   toc,title
-qandadiv  toc
-qandaset  toc
-reference toc,title
-sect1     toc
-sect2     toc
-sect3     toc
-sect4     toc
-sect5     toc
-section   toc
-set       toc,title
-&lt;/xsl:param&gt;
-
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This parameter has a structured value. It is a table of space-delimited
-path/value pairs. Each path identifies some element in the source document
-using a restricted subset of XPath (only the implicit child axis, no wildcards,
-no predicates). Paths can be either relative or absolute.</para>
-
-<para>When processing a particular element, the stylesheets consult this table to
-determine if a ToC (or LoT(s)) should be generated.</para>
-
-<para>For example, consider the entry:</para>
-
-<screen>book toc,figure</screen>
-
-<para>This indicates that whenever a <tag>book</tag> is formatted, a
-Table Of Contents and a List of Figures should be generated. Similarly,</para>
-
-<screen>/chapter toc</screen>
-
-<para>indicates that whenever a document <emphasis>that has a root
-of</emphasis> <tag>chapter</tag> is formatted, a Table of
-Contents should be generated. The entry <literal>chapter</literal> would match
-all chapters, but <literal>/chapter</literal> matches only <tag>chapter</tag>
-document elements.</para>
-
-<para>Generally, the longest match wins. So, for example, if you want to distinguish
-articles in books from articles in parts, you could use these two entries:</para>
-
-<screen>book/article toc,figure
-part/article toc</screen>
-
-<para>Note that an article in a part can never match a <literal>book/article</literal>,
-so if you want nothing to be generated for articles in parts, you can simply leave
-that rule out.</para>
-
-<para>If you want to leave the rule in, to make it explicit that you're turning
-something off, use the value <quote>nop</quote>. For example, the following
-entry disables ToCs and LoTs for articles:</para>
-
-<screen>article nop</screen>
-
-<para>Do not simply leave the word <quote>article</quote> in the file
-without a matching value. That'd be just begging the silly little
-path/value parser to get confused.</para>
-
-<para>Section ToCs are further controlled by the
-<parameter>generate.section.toc.level</parameter> parameter.
-For a given section level to have a ToC, it must have both an entry in 
-<parameter>generate.toc</parameter> and be within the range enabled by
-<parameter>generate.section.toc.level</parameter>.</para>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="generate.section.toc.level">
-<refmeta>
-<refentrytitle>generate.section.toc.level</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">integer</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>generate.section.toc.level</refname>
-<refpurpose>Control depth of TOC generation in sections</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="generate.section.toc.level.frag">
-&lt;xsl:param name="generate.section.toc.level" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The <parameter>generate.section.toc.level</parameter> parameter
-controls the depth of <tag>section</tag> in which TOCs will be generated. Note
-that this is related to, but not the same as
-<parameter>toc.section.depth</parameter>, which controls the depth to
-which TOC entries will be generated in a given TOC.</para>
-<para>If, for example, <parameter>generate.section.toc.level</parameter>
-is <literal>3</literal>, TOCs will be generated in first, second, and third
-level sections, but not in fourth level sections.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="generate.index">
-<refmeta>
-<refentrytitle>generate.index</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>generate.index</refname>
-<refpurpose>Do you want an index?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="generate.index.frag">&lt;xsl:param name="generate.index" select="1"&gt;&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Specify if an index should be generated. </para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="index.method">
-<refmeta>
-<refentrytitle>index.method</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">list</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">basic</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">kosek</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">kimber</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>index.method</refname>
-<refpurpose>Select method used to group index entries in an index</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="index.method.frag">
-&lt;xsl:param name="index.method"&gt;basic&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This parameter lets you select which method to use for sorting and grouping
- index entries in an index.
-Indexes in Latin-based languages that have accented characters typically
-sort together accented words and unaccented words.
-Thus <quote>&#193;</quote> (U+00C1 LATIN CAPITAL LETTER A WITH ACUTE) would sort together
-with <quote>A</quote> (U+0041 LATIN CAPITAL LETTER A), so both would appear in the <quote>A</quote>
-section of the index.
-Languages using other alphabets (such as Russian,  which is written in the Cyrillic alphabet)
-and languages using ideographic chararacters (such as Japanese)
-require grouping specific to the languages and alphabets.
-</para>
-
-<para>The default indexing method is limited.
-It can group accented characters in Latin-based languages only.
-It cannot handle non-Latin alphabets or ideographic languages.
-The other indexing methods require extensions of one type or
-another, and do not work with
-all XSLT processors, which is why they are not used by default.</para>
-
-<para>The three choices for indexing method are:</para>
-<variablelist>
-<varlistentry>
-<term><literal>basic</literal></term>
-<listitem>
-<para>
-(default)  Sort and groups words based only on the Latin alphabet.
-Words with accented Latin letters will group and sort with
-their respective primary letter, but
-words in non-Latin alphabets will be
-put in the <quote>Symbols</quote> section of the index.
-</para>
-</listitem>
-</varlistentry>
-<varlistentry>
-<term><literal>kosek</literal></term>
-<listitem>
-<para>
-This method sorts and groups words based on letter groups configured in
-the DocBook locale file for the given language.
-See, for example, the French locale file <filename>common/fr.xml</filename>.
-This method requires that the XSLT processor
-supports the EXSLT extensions (most do).
-It also requires support for using 
-user-defined functions in xsl:key (xsltproc does not).
-</para>
-<para>This method is suitable for any language for which you can
-list all the individual characters that should appear
-in each letter group in an index.
-It is probably not practical to use it for ideographic languages
-such as Chinese that have hundreds or thousands of characters.
-</para>
-
-<para>To use the kosek method, you must:</para>
-
-<orderedlist>
-<listitem>
-<para>Use a processor that supports its extensions, such as
-Saxon 6 or Xalan (xsltproc and Saxon 8 do not).
-</para>
-</listitem>
-<listitem>
-<para>Set the index.method parameter's value to <quote>kosek</quote>.
-</para>
-</listitem>
-<listitem>
-<para>Import the appropriate index extensions stylesheet module
-<filename>fo/autoidx-kosek.xsl</filename> or 
-<filename>html/autoidx-kosek.xsl</filename> into your
-customization.
-</para>
-</listitem>
-</orderedlist>
-
-</listitem>
-</varlistentry>
-<varlistentry>
-<term><literal>kimber</literal></term>
-<listitem>
-<para>
-This method uses extensions to the Saxon processor to implement
-sophisticated indexing processes. It uses its own 
-configuration file, which can include information for any number of
-languages. Each language's configuration can group
-words using one of two processes. In the
-enumerated process similar to that used in the kosek method,
-you indicate the groupings character-by-character.
-In the between-key process, you specify the
-break-points in the sort order that should start a new group.
-The latter configuration is useful for ideographic languages
-such as Chinese, Japanese, and Korean.
-You can also define your own collation algorithms and how you
-want mixed Latin-alphabet words sorted.</para>
-<itemizedlist>
-<listitem>
-<para>For a whitepaper describing the extensions, see:
-<link xlink:href="http://www.innodata-isogen.com/knowledge_center/white_papers/back_of_book_for_xsl_fo.pdf">http://www.innodata-isogen.com/knowledge_center/white_papers/back_of_book_for_xsl_fo.pdf</link>.
-</para>
-</listitem>
-<listitem>
-<para>To download the extension library, see
-<link xlink:href="http://www.innodata-isogen.com/knowledge_center/tools_downloads/i18nsupport">http://www.innodata-isogen.com/knowledge_center/tools_downloads/i18nsupport</link>.
-</para>
-</listitem>
-</itemizedlist>
-
-<para>To use the kimber method, you must:</para>
-
-<orderedlist>
-<listitem>
-<para>Use Saxon (version 6 or 8) as your XSLT processor.
-</para>
-</listitem>
-<listitem>
-<para>Install and configure the Innodata Isogen library, using
-the documentation that comes with it.
-</para>
-</listitem>
-<listitem>
-<para>Set the index.method parameter's value to <quote>kimber</quote>.
-</para>
-</listitem>
-<listitem>
-<para>Import the appropriate index extensions stylesheet module
-<filename>fo/autoidx-kimber.xsl</filename> or 
-<filename>html/autoidx-kimber.xsl</filename> into your
-customization.
-</para>
-</listitem>
-</orderedlist>
-
-</listitem>
-</varlistentry>
-</variablelist>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="index.on.type">
-<refmeta>
-<refentrytitle>index.on.type</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>index.on.type</refname>
-<refpurpose>Select indexterms based on <tag class="attribute">type</tag>
-attribute value</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="index.on.type.frag">
-&lt;xsl:param name="index.on.type" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>
-If non-zero, 
-then an <tag>index</tag> element that has a
-<tag class="attribute">type</tag> attribute
-value will contain only those <tag>indexterm</tag>
-elements with a matching <tag class="attribute">type</tag> attribute value.
-If an <tag>index</tag> has no <tag class="attribute">type</tag>
-attribute or it is blank, then the index will contain
-all <tag>indexterm</tag>s in the current scope.
-</para>
-
-<para>
-If <literal>index.on.type</literal> is zero, then the
-<tag class="attribute">type</tag> attribute has no effect
-on selecting indexterms for an index.
-</para>
-
-<para>For those using DocBook version 4.2 or earlier,
-the <tag class="attribute">type</tag> attribute is not available
-for index terms.  However, you can achieve the same
-effect by using the <tag class="attribute">role</tag> attribute
-in the same manner on <tag>indexterm</tag>
-and <tag>index</tag>, and setting the stylesheet parameter 
-<parameter>index.on.role</parameter> to a nonzero value.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="index.on.role">
-<refmeta>
-<refentrytitle>index.on.role</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>index.on.role</refname>
-<refpurpose>Select indexterms based on <tag class="attribute">role</tag> value</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="index.on.role.frag">
-&lt;xsl:param name="index.on.role" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>
-If non-zero, 
-then an <tag>index</tag> element that has a
-<tag class="attribute">role</tag> attribute
-value will contain only those <tag>indexterm</tag>
-elements with a matching role value.
-If an <tag>index</tag> has no <tag class="attribute">role</tag>
-attribute or it is blank, then the index will contain
-all <tag>indexterm</tag>s in the current scope.
-</para>
-<para>
-If <literal>index.on.role</literal> is zero, then the
-<tag class="attribute">role</tag> attribute has no effect
-on selecting indexterms for an index.
-</para>
-
-<para>If you are using DocBook version 4.3 or later, you should
-use the <tag class="attribute">type</tag> attribute instead of <tag class="attribute">role</tag>
-on <tag>indexterm</tag> and <tag>index</tag>,
-and set the <parameter>index.on.type</parameter> to a nonzero
-value.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="index.links.to.section">
-<refmeta>
-<refentrytitle>index.links.to.section</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>index.links.to.section</refname>
-<refpurpose>HTML index entries link to container section title</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="index.links.to.section.frag">
-&lt;xsl:param name="index.links.to.section" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If zero, then an index entry in an index links
-directly to the location of the
-generated <tag>anchor</tag> that is output
-for the indexterm. If two identical indexterm elements
-exist in the same section, then both entries appear
-in the index with the same title but link to different
-locations.</para>
-
-<para>If non-zero, then an index entry in an index links to the
-section title containing the <tag>indexterm</tag>, rather than
-directly to the <tag>anchor</tag> output for the indexterm.
-Duplicate indexterm entries in the same section are dropped.
-</para>
-
-<para>The default value is 1, so index entries link to
-section titles by default.</para>
-
-<para>In both cases, the link text in an index entry is the
-title of the section containing the indexterm.
-That is because HTML does not have numbered pages.
-It also provides the reader with context information
-for each link.</para>
-
-<para>This parameter lets you choose which style of
-index linking you want. </para>
-
-<itemizedlist>
-<listitem>
-<para>When set to 0, an index entry takes you 
-to the precise location of its corresponding indexterm.
-However, if you have a lot of duplicate
-entries in sections, then you have a lot of duplicate
-titles in the index, which makes it more cluttered.
-The reader may not recognize why duplicate titles
-appear until they follow the links. Also, the links
-may land the reader in the middle of a section where the
-section title is not visible, which may also be
-confusing to the reader.</para>
-</listitem>
-<listitem>
-<para>When set to 1, an index entry link is
-less precise, but duplicate titles in the
-index entries are eliminated. 
-Landing on the section title location may confirm the reader's
-expectation that a link that
-shows a section title will take them to that section title,
-not a location within the section.
-</para>
-</listitem>
-</itemizedlist>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="index.prefer.titleabbrev">
-<refmeta>
-<refentrytitle>index.prefer.titleabbrev</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>index.prefer.titleabbrev</refname>
-<refpurpose>Should abbreviated titles be used as back references?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="index.prefer.titleabbrev.frag">
-&lt;xsl:param name="index.prefer.titleabbrev" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, and if a <tag>titleabbrev</tag> is defined, the abbreviated title
-is used as the link text of a back reference in the index.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="index.term.separator">
-<refmeta>
-<refentrytitle>index.term.separator</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>index.term.separator</refname>
-<refpurpose>Override for punctuation separating an index term 
-from its list of page references in an index</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="index.term.separator.frag">
-&lt;xsl:param name="index.term.separator"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This parameter permits you to override
-the text to insert between
-the end of an index term and its list of page references.
-Typically that might be a comma and a space.
-</para>
-
-<para>Because this text may be locale dependent,
-this parameter's value is normally taken from a gentext
-template named 'term-separator' in the
-context 'index' in the stylesheet
-locale file for the language
-of the current document.
-This parameter can be used to override the gentext string,
-and would typically be used on the command line.
-This parameter would apply to all languages.
-</para>
-
-<para>So this text string can be customized in two ways.
-You can reset the default gentext string using
-the <parameter>local.l10n.xml</parameter> parameter, or you can
-fill in the content for this normally empty 
-override parameter.
-The content can be a simple string, or it can be
-something more complex such as a call-template.
-For fo output, it could be an <tag>fo:leader</tag>
-element to provide space of a specific length, or a dot leader.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="index.number.separator">
-<refmeta>
-<refentrytitle>index.number.separator</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>index.number.separator</refname>
-<refpurpose>Override for punctuation separating page numbers in index</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="index.number.separator.frag">
-&lt;xsl:param name="index.number.separator"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This parameter permits you to override the text to insert between
-page references in a formatted index entry.  Typically 
-that would be a comma and a space.
-</para>
-
-<para>Because this text may be locale dependent,
-this parameter's value is normally taken from a gentext
-template named 'number-separator' in the
-context 'index' in the stylesheet
-locale file for the language
-of the current document.
-This parameter can be used to override the gentext string,
-and would typically be used on the command line.
-This parameter would apply to all languages.
-</para>
-
-<para>So this text string can be customized in two ways.
-You can reset the default gentext string using
-the <parameter>local.l10n.xml</parameter> parameter, or you can
-override the gentext with the content of this parameter.
-The content can be a simple string, or it can be
-something more complex such as a call-template.
-</para>
-
-<para>In HTML index output, section title references are used instead of
-page number references.  This punctuation appears between
-such section titles in an HTML index.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="index.range.separator">
-<refmeta>
-<refentrytitle>index.range.separator</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>index.range.separator</refname>
-<refpurpose>Override for punctuation separating the two numbers
-in a page range in index</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="index.range.separator.frag">
-&lt;xsl:param name="index.range.separator"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This parameter permits you
-to override the text to insert between
-the two numbers of a page range in an index.
-This parameter is only used by those XSL-FO processors
-that support an extension for generating such page ranges
-(such as XEP).</para>
-
-<para>Because this text may be locale dependent,
-this parameter's value is normally taken from a gentext
-template named 'range-separator' in the
-context 'index' in the stylesheet
-locale file for the language
-of the current document.
-This parameter can be used to override the gentext string,
-and would typically be used on the command line.
-This parameter would apply to all languages.
-</para>
-
-<para>So this text string can be customized in two ways.
-You can reset the default gentext string using
-the <parameter>local.l10n.xml</parameter> parameter, or you can
-override the gentext with the content of this parameter.
-The content can be a simple string, or it can be
-something more complex such as a call-template.
-</para>
-
-<para>In HTML index output, section title references are used instead of
-page number references. So there are no page ranges
-and this parameter has no effect.
-</para>
-
-</refsection>
-</refentry>
-
-</reference><reference id="dbk_ext" xml:base="../html/param.xml"><title>Stylesheet Extensions</title>
-<refentry version="5.0" id="linenumbering.everyNth">
-<refmeta>
-<refentrytitle>linenumbering.everyNth</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">integer</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>linenumbering.everyNth</refname>
-<refpurpose>Indicate which lines should be numbered</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="linenumbering.everyNth.frag">
-&lt;xsl:param name="linenumbering.everyNth"&gt;5&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If line numbering is enabled, everyNth line will be
-numbered. Note that numbering is one based, not zero based.
-</para>
-<para>See also <parameter>linenumbering.extension</parameter>,
-<parameter>linenumbering.separator</parameter>,
-<parameter>linenumbering.width</parameter> and
-<parameter>use.extensions</parameter></para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="linenumbering.extension">
-<refmeta>
-<refentrytitle>linenumbering.extension</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>linenumbering.extension</refname>
-<refpurpose>Enable the line numbering extension</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="linenumbering.extension.frag">
-&lt;xsl:param name="linenumbering.extension" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, verbatim environments (<tag>address</tag>, <tag>literallayout</tag>,
-<tag>programlisting</tag>, <tag>screen</tag>, <tag>synopsis</tag>) that specify line numbering will
-have line numbers.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="linenumbering.separator">
-<refmeta>
-<refentrytitle>linenumbering.separator</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>linenumbering.separator</refname>
-<refpurpose>Specify a separator between line numbers and lines</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="linenumbering.separator.frag">
-&lt;xsl:param name="linenumbering.separator"&gt;&lt;xsl:text&gt; &lt;/xsl:text&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The separator is inserted between line numbers and lines in the
-verbatim environment. The default value is a single white space.
- Note the interaction with <parameter>linenumbering.width</parameter>
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="linenumbering.width">
-<refmeta>
-<refentrytitle>linenumbering.width</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">integer</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>linenumbering.width</refname>
-<refpurpose>Indicates the width of line numbers</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="linenumbering.width.frag">
-&lt;xsl:param name="linenumbering.width"&gt;3&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If line numbering is enabled, line numbers will appear right
-justified in a field "width" characters wide.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="tablecolumns.extension">
-<refmeta>
-<refentrytitle>tablecolumns.extension</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>tablecolumns.extension</refname>
-<refpurpose>Enable the table columns extension function</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="tablecolumns.extension.frag">
-&lt;xsl:param name="tablecolumns.extension" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The table columns extension function adjusts the widths of table
-columns in the HTML result to more accurately reflect the specifications
-in the CALS table.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="textinsert.extension">
-  <refmeta>
-    <refentrytitle>textinsert.extension</refentrytitle>
-    <refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-  </refmeta>
-  <refnamediv>
-    <refname>textinsert.extension</refname>
-    <refpurpose>Enables the textinsert extension element</refpurpose>
-  </refnamediv>
-  <refsynopsisdiv>
-    <programlisting id="textinsert.extension.frag">
-  &lt;xsl:param name="textinsert.extension" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-  </refsynopsisdiv>
-  <refsection><info><title>Description</title></info>
-    <para>The textinsert extension element inserts the contents of
-      a file into the result tree (as text).</para>
-    <note>
-      <para>To use the textinsert extension element, you must use
-        either Saxon or Xalan as your XSLT processor (it doesn&#8217;t
-        work with xsltproc), along with either the DocBook Saxon
-        extensions or DocBook Xalan extensions (for more
-        information about those extensions, see <link role="tcg" xlink:href="InstallingAProcessor.html#SaxonExtensions">DocBook Saxon Extensions</link> and <link role="tcg" xlink:href="InstallingAProcessor.html#XalanExtensions">DocBook Xalan Extensions</link>), and you must set both
-        the <parameter>use.extensions</parameter> and
-        <parameter>textinsert.extension</parameter> parameters to
-        <literal>1</literal>.</para>
-      <para>As an alternative to using the textinsert element,
-        consider using an Xinclude element with the
-        <literal>parse="text"</literal> attribute and value
-        specified, as detailed in <link role="tcg" xlink:href="ExternalCode.html#XIncludeCode">Using XInclude for text inclusions</link>.</para>
-    </note>
-  </refsection>
-  <refsection><info><title>See Also</title></info>
-    <para>You can also use the <tag class="xmlpi">dbhtml-include&#160;href</tag> processing
-      instruction to insert external files &#8212; both files containing
-      plain text and files with markup content (including HTML
-      content).</para>
-  </refsection>
-  <refsection><info><title>More information</title></info>
-    <para>For how-to documentation on inserting contents of
-      external code files and other text files into output, see
-      <link role="tcg" xlink:href="ExternalCode.html">External code files</link>.</para>
-    <para>For guidelines on inserting contents of
-      HTML files into output, see <link role="tcg" xlink:href="InsertExtHtml.html">Inserting external HTML code</link>.</para>
-  </refsection>
-</refentry>
-
-<refentry version="5.0" id="textdata.default.encoding">
-<refmeta>
-<refentrytitle>textdata.default.encoding</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>textdata.default.encoding</refname>
-<refpurpose>Default encoding of external text files which are included
-using textdata element</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="textdata.default.encoding.frag">
-&lt;xsl:param name="textdata.default.encoding"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Specifies the encoding of any external text files included using
-<tag>textdata</tag> element. This value is used only when you do
-not specify encoding by the appropriate attribute 
-directly on textdata. An empty string is interpreted as the system
-default encoding.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="graphicsize.extension">
-<refmeta>
-<refentrytitle>graphicsize.extension</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>graphicsize.extension</refname>
-<refpurpose>Enable the getWidth()/getDepth() extension functions</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="graphicsize.extension.frag">
-&lt;xsl:param name="graphicsize.extension" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero (and if <parameter>use.extensions</parameter> is non-zero
-and if you're using a processor that supports extension functions), the
-<function>getWidth</function> and <function>getDepth</function> functions
-will be used to extract image sizes from graphics.</para>
-
-<para>The main supported image formats are GIF, JPEG, and PNG. Somewhat cruder 
-support for EPS and PDF images is also available.</para>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="graphicsize.use.img.src.path">
-<refmeta>
-<refentrytitle>graphicsize.use.img.src.path</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>graphicsize.use.img.src.path</refname>
-<refpurpose>Prepend <parameter>img.src.path</parameter> before
-filenames passed to extension functions</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="graphicsize.use.img.src.path.frag">
-&lt;xsl:param name="graphicsize.use.img.src.path" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero <parameter>img.src.path</parameter> parameter will
-be appended before filenames passed to extension functions for
-measuring image dimensions.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="use.extensions">
-<refmeta>
-<refentrytitle>use.extensions</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>use.extensions</refname>
-<refpurpose>Enable extensions</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="use.extensions.frag">
-&lt;xsl:param name="use.extensions" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, extensions may be used. Each extension is
-further controlled by its own parameter. But if
-<parameter>use.extensions</parameter> is zero, no extensions will
-be used.
-</para>
-
-</refsection>
-</refentry>
-
-</reference><reference id="labels" xml:base="../html/param.xml"><title>Automatic labelling</title>
-<refentry version="5.0" id="chapter.autolabel">
-<refmeta>
-<refentrytitle>chapter.autolabel</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">list</refmiscinfo> 
-<refmiscinfo class="other" otherclass="value">0<alt>none</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">1<alt>1,2,3...</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">A<alt>A,B,C...</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">a<alt>a,b,c...</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">i<alt>i,ii,iii...</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">I<alt>I,II,III...</alt></refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>chapter.autolabel</refname>
-<refpurpose>Specifies the labeling format for Chapter titles</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="chapter.autolabel.frag">
-&lt;xsl:param name="chapter.autolabel" select="1"&gt;&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, then chapters will be numbered using the parameter
-value as the number format if the value matches one of the following:
-</para>
-
-<variablelist>
-  <varlistentry>
-    <term>1 or arabic</term>
-    <listitem>
-      <para>Arabic numeration (1, 2, 3 ...).</para>
-    </listitem>
-  </varlistentry>
-  <varlistentry>
-    <term>A or upperalpha</term>
-    <listitem>
-      <para>Uppercase letter numeration (A, B, C ...).</para>
-    </listitem>
-  </varlistentry>
-  <varlistentry>
-    <term>a or loweralpha</term>
-    <listitem>
-      <para>Lowercase letter numeration (a, b, c ...).</para>
-    </listitem>
-  </varlistentry>
-  <varlistentry>
-    <term>I or upperroman</term>
-    <listitem>
-      <para>Uppercase roman numeration (I, II, III ...).</para>
-    </listitem>
-  </varlistentry>
-  <varlistentry>
-    <term>i or lowerroman</term>
-    <listitem>
-      <para>Lowercase roman letter numeration (i, ii, iii ...).</para>
-    </listitem>
-  </varlistentry>
-</variablelist>
-
-<para>Any nonzero value other than the above will generate
-the default number format (arabic).
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="appendix.autolabel">
-<refmeta>
-<refentrytitle>appendix.autolabel</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">list</refmiscinfo> 
-<refmiscinfo class="other" otherclass="value">0<alt>none</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">1<alt>1,2,3...</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">A<alt>A,B,C...</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">a<alt>a,b,c...</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">i<alt>i,ii,iii...</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">I<alt>I,II,III...</alt></refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>appendix.autolabel</refname>
-<refpurpose>Specifies the labeling format for Appendix titles</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="appendix.autolabel.frag">
-&lt;xsl:param name="appendix.autolabel"&gt;A&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, then appendices will be numbered using the
-parameter value as the number format if the value matches one of the
-following:
-</para>
-
-<variablelist>
-  <varlistentry>
-    <term>1 or arabic</term>
-    <listitem>
-      <para>Arabic numeration (1, 2, 3 ...).</para>
-    </listitem>
-  </varlistentry>
-  <varlistentry>
-    <term>A or upperalpha</term>
-    <listitem>
-      <para>Uppercase letter numeration (A, B, C ...).</para>
-    </listitem>
-  </varlistentry>
-  <varlistentry>
-    <term>a or loweralpha</term>
-    <listitem>
-      <para>Lowercase letter numeration (a, b, c ...).</para>
-    </listitem>
-  </varlistentry>
-  <varlistentry>
-    <term>I or upperroman</term>
-    <listitem>
-      <para>Uppercase roman numeration (I, II, III ...).</para>
-    </listitem>
-  </varlistentry>
-  <varlistentry>
-    <term>i or lowerroman</term>
-    <listitem>
-      <para>Lowercase roman letter numeration (i, ii, iii ...).</para>
-    </listitem>
-  </varlistentry>
-</variablelist>
-
-<para>Any nonzero value other than the above will generate
-the default number format (upperalpha).
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="part.autolabel">
-<refmeta>
-<refentrytitle>part.autolabel</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">list</refmiscinfo> 
-<refmiscinfo class="other" otherclass="value">0<alt>none</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">1<alt>1,2,3...</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">A<alt>A,B,C...</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">a<alt>a,b,c...</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">i<alt>i,ii,iii...</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">I<alt>I,II,III...</alt></refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>part.autolabel</refname>
-<refpurpose>Specifies the labeling format for Part titles</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="part.autolabel.frag">
-&lt;xsl:param name="part.autolabel"&gt;I&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, then parts will be numbered using the parameter
-value as the number format if the value matches one of the following:
-</para>
-
-<variablelist>
-  <varlistentry>
-    <term>1 or arabic</term>
-    <listitem>
-      <para>Arabic numeration (1, 2, 3 ...).</para>
-    </listitem>
-  </varlistentry>
-  <varlistentry>
-    <term>A or upperalpha</term>
-    <listitem>
-      <para>Uppercase letter numeration (A, B, C ...).</para>
-    </listitem>
-  </varlistentry>
-  <varlistentry>
-    <term>a or loweralpha</term>
-    <listitem>
-      <para>Lowercase letter numeration (a, b, c ...).</para>
-    </listitem>
-  </varlistentry>
-  <varlistentry>
-    <term>I or upperroman</term>
-    <listitem>
-      <para>Uppercase roman numeration (I, II, III ...).</para>
-    </listitem>
-  </varlistentry>
-  <varlistentry>
-    <term>i or lowerroman</term>
-    <listitem>
-      <para>Lowercase roman letter numeration (i, ii, iii ...).</para>
-    </listitem>
-  </varlistentry>
-</variablelist>
-
-<para>Any nonzero value other than the above will generate
-the default number format (upperroman).
-</para>
-
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="reference.autolabel">
-<refmeta>
-<refentrytitle>reference.autolabel</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">list</refmiscinfo> 
-<refmiscinfo class="other" otherclass="value">0<alt>none</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">1<alt>1,2,3...</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">A<alt>A,B,C...</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">a<alt>a,b,c...</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">i<alt>i,ii,iii...</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">I<alt>I,II,III...</alt></refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>reference.autolabel</refname>
-<refpurpose>Specifies the labeling format for Reference titles</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-<programlisting id="reference.autolabel.frag">
-  &lt;xsl:param name="reference.autolabel"&gt;I&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-<refsection><info><title>Description</title></info>
-<para>If non-zero, references will be numbered using the parameter
-  value as the number format if the value matches one of the
-  following:
-</para>
-<variablelist>
-  <varlistentry>
-    <term>1 or arabic</term>
-    <listitem>
-      <para>Arabic numeration (1, 2, 3 ...).</para>
-    </listitem>
-  </varlistentry>
-  <varlistentry>
-    <term>A or upperalpha</term>
-    <listitem>
-      <para>Uppercase letter numeration (A, B, C ...).</para>
-    </listitem>
-  </varlistentry>
-  <varlistentry>
-    <term>a or loweralpha</term>
-    <listitem>
-      <para>Lowercase letter numeration (a, b, c ...).</para>
-    </listitem>
-  </varlistentry>
-  <varlistentry>
-    <term>I or upperroman</term>
-    <listitem>
-      <para>Uppercase roman numeration (I, II, III ...).</para>
-    </listitem>
-  </varlistentry>
-  <varlistentry>
-    <term>i or lowerroman</term>
-    <listitem>
-      <para>Lowercase roman letter numeration (i, ii, iii ...).</para>
-    </listitem>
-  </varlistentry>
-</variablelist>
-<para>Any non-zero value other than the above will generate
-the default number format (upperroman).
-</para>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="preface.autolabel">
-<refmeta>
-<refentrytitle>preface.autolabel</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">list</refmiscinfo> 
-<refmiscinfo class="other" otherclass="value">0<alt>none</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">1<alt>1,2,3...</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">A<alt>A,B,C...</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">a<alt>a,b,c...</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">i<alt>i,ii,iii...</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">I<alt>I,II,III...</alt></refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>preface.autolabel</refname>
-<refpurpose>Specifices the labeling format for Preface titles</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="preface.autolabel.frag">&lt;xsl:param name="preface.autolabel" select="0"&gt;&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero then prefaces will be numbered using the parameter
-value as the number format if the value matches one of the following:
-</para>
-
-<variablelist>
-  <varlistentry>
-    <term>1 or arabic</term>
-    <listitem>
-      <para>Arabic numeration (1, 2, 3 ...).</para>
-    </listitem>
-  </varlistentry>
-  <varlistentry>
-    <term>A or upperalpha</term>
-    <listitem>
-      <para>Uppercase letter numeration (A, B, C ...).</para>
-    </listitem>
-  </varlistentry>
-  <varlistentry>
-    <term>a or loweralpha</term>
-    <listitem>
-      <para>Lowercase letter numeration (a, b, c ...).</para>
-    </listitem>
-  </varlistentry>
-  <varlistentry>
-    <term>I or upperroman</term>
-    <listitem>
-      <para>Uppercase roman numeration (I, II, III ...).</para>
-    </listitem>
-  </varlistentry>
-  <varlistentry>
-    <term>i or lowerroman</term>
-    <listitem>
-      <para>Lowercase roman letter numeration (i, ii, iii ...).</para>
-    </listitem>
-  </varlistentry>
-</variablelist>
-
-<para>Any nonzero value other than the above will generate
-the default number format (arabic).
-</para>
-
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="qandadiv.autolabel">
-<refmeta>
-<refentrytitle>qandadiv.autolabel</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>qandadiv.autolabel</refname>
-<refpurpose>Are divisions in QAndASets enumerated?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="qandadiv.autolabel.frag">&lt;xsl:param name="qandadiv.autolabel" select="1"&gt;&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, unlabeled qandadivs will be enumerated.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="section.autolabel">
-<refmeta>
-<refentrytitle>section.autolabel</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>section.autolabel</refname>
-<refpurpose>Are sections enumerated?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="section.autolabel.frag">&lt;xsl:param name="section.autolabel" select="0"&gt;&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If true (non-zero), unlabeled sections will be enumerated.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="section.autolabel.max.depth">
-<refmeta>
-<refentrytitle>section.autolabel.max.depth</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">integer</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>section.autolabel.max.depth</refname>
-<refpurpose>The deepest level of sections that are numbered.</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="section.autolabel.max.depth.frag">
-&lt;xsl:param name="section.autolabel.max.depth"&gt;8&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>When section numbering is turned on by the
-<parameter>section.autolabel</parameter> parameter, then this
-parameter controls the depth of <tag>section</tag> nesting that is
-numbered.  Sections nested to a level deeper than this value will not
-be numbered.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="section.label.includes.component.label">
-<refmeta>
-<refentrytitle>section.label.includes.component.label</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>section.label.includes.component.label</refname>
-<refpurpose>Do section labels include the component label?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="section.label.includes.component.label.frag">&lt;xsl:param name="section.label.includes.component.label" select="0"&gt;&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, section labels are prefixed with the label of the
-component that contains them.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="label.from.part">
-<refmeta>
-<refentrytitle>label.from.part</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>label.from.part</refname>
-<refpurpose>Renumber components in each part?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="label.from.part.frag">
-&lt;xsl:param name="label.from.part" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If <parameter>label.from.part</parameter> is non-zero, then
-  numbering of components &#8212; <tag>preface</tag>,
-  <tag>chapter</tag>, <tag>appendix</tag>, and
-  <tag>reference</tag> (when <tag>reference</tag> occurs at the
-  component level) &#8212; is re-started within each
-  <tag>part</tag>.</para>
-<para>If <parameter>label.from.part</parameter> is zero (the
-  default), numbering of components is <emphasis>not</emphasis>
-  re-started within each <tag>part</tag>; instead, components are
-  numbered sequentially throughout each <tag>book</tag>,
-  regardless of whether or not they occur within <tag>part</tag>
-  instances.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="component.label.includes.part.label">
-<refmeta>
-<refentrytitle>component.label.includes.part.label</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>component.label.includes.part.label</refname>
-<refpurpose>Do component labels include the part label?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="component.label.includes.part.label.frag">&lt;xsl:param name="component.label.includes.part.label" select="0"&gt;&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, number labels for <tag>chapter</tag>,
-<tag>appendix</tag>, and other component elements are prefixed with
-the label of the part element that contains them.  So you might see
-Chapter II.3 instead of Chapter 3.  Also, the labels for formal
-elements such as <tag>table</tag> and <tag>figure</tag> will include
-the part label.  If there is no part element container, then no prefix
-is generated.
-</para>
-<para>
-This feature is most useful when the
-<parameter>label.from.part</parameter> parameter is turned on.
-In that case, there would be more than one <tag>chapter</tag>
-<quote>1</quote>, and the extra part label prefix will identify
-each chapter unambiguously.
-</para>
-
-</refsection>
-</refentry>
-
-</reference><reference id="html" xml:base="../html/param.xml"><title>HTML</title>
-<refentry version="5.0" id="html.base">
-<refmeta>
-<refentrytitle>html.base</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">uri</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>html.base</refname>
-<refpurpose>An HTML base URI</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="html.base.frag">
-&lt;xsl:param name="html.base"&gt;&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If html.base is set, it is used for the <tag>base</tag> element
-in the <tag>head</tag> of the html documents.  The parameter specifies
-the base URL for all relative URLs in the document.  This is useful
-for dynamically served html where the base URI needs to be
-shifted.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="html.stylesheet">
-<refmeta>
-<refentrytitle>html.stylesheet</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>html.stylesheet</refname>
-<refpurpose>Name of the stylesheet(s) to use in the generated HTML</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="html.stylesheet.frag">
-&lt;xsl:param name="html.stylesheet"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The <parameter>html.stylesheet</parameter> parameter is either
-empty, indicating that no stylesheet <tag>link</tag> tag should be
-generated in the html output, or it is a list of one or more
-stylesheet files.</para>
-
-<para>Multiple stylesheets are space-delimited. If you need to
-reference a stylesheet URI that includes a space, encode it with
-<literal>%20</literal>. A separate html <literal>link</literal> element will
-be generated for each stylesheet in the order they are listed in the
-parameter.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="html.stylesheet.type">
-<refmeta>
-<refentrytitle>html.stylesheet.type</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>html.stylesheet.type</refname>
-<refpurpose>The type of the stylesheet used in the generated HTML</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="html.stylesheet.type.frag">&lt;xsl:param name="html.stylesheet.type"&gt;text/css&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The type of the stylesheet to place in the HTML <tag>link</tag> tag.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="css.decoration">
-<refmeta>
-<refentrytitle>css.decoration</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>css.decoration</refname>
-<refpurpose>Enable CSS decoration of elements</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="css.decoration.frag">
-&lt;xsl:param name="css.decoration" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>
-If non-zero, then html elements produced by the stylesheet may be
-decorated with <literal>style</literal> attributes.  For example, the
-<literal>li</literal> tags produced for list items may include a
-fragment of CSS in the <literal>style</literal> attribute which sets
-the CSS property "list-style-type".
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="html.script">
-<refmeta>
-<refentrytitle>html.script</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>html.script</refname>
-<refpurpose>Name of the script(s) to use in the generated HTML</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="html.script.frag">
-&lt;xsl:param name="html.script"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The <parameter>html.script</parameter> parameter is either
-empty (default), indicating that no <tag>script</tag> element should be
-generated in the html output, or it is a list of one or more
-script locations.</para>
-
-<para>Multiple script locations are space-delimited. If you need to
-reference a script URI that includes a space, encode it with
-<literal>%20</literal>. A separate html <literal>script</literal> element will
-be generated for each script in the order they are listed in the
-parameter.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="html.script.type">
-<refmeta>
-<refentrytitle>html.script.type</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>html.script.type</refname>
-<refpurpose>The type of script used in the generated HTML</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="html.script.type.frag">&lt;xsl:param name="html.script.type"&gt;text/javascript&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The type of script to place in the HTML <tag>script</tag> element.
-Specifically, the value of the <tag>script</tag> element's <tag>type</tag>
-attribute.
-The default value is <literal>text/javascript</literal>.
-This param is used only when the stylesheet parameter
-<tag>html.script</tag> is non-blank and specifies the location of a script.</para>
-
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="spacing.paras">
-<refmeta>
-<refentrytitle>spacing.paras</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>spacing.paras</refname>
-<refpurpose>Insert additional &lt;p&gt; elements for spacing?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="spacing.paras.frag">
-&lt;xsl:param name="spacing.paras" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>When non-zero, additional, empty paragraphs are inserted in
-several contexts (for example, around informal figures), to create a
-more pleasing visual appearance in many browsers.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="emphasis.propagates.style">
-<refmeta>
-<refentrytitle>emphasis.propagates.style</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>emphasis.propagates.style</refname>
-<refpurpose>Pass emphasis role attribute through to HTML?</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-<programlisting id="emphasis.propagates.style.frag">
-&lt;xsl:param name="emphasis.propagates.style" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-<refsection><info><title>Description</title></info>
-<para>If non-zero, the <literal>role</literal> attribute of
-<tag>emphasis</tag> elements will be passed through to the HTML as a
-class attribute on a <literal>span</literal> that surrounds the
-emphasis.</para>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="para.propagates.style">
-<refmeta>
-<refentrytitle>para.propagates.style</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>para.propagates.style</refname>
-<refpurpose>Pass para role attribute through to HTML?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="para.propagates.style.frag">
-&lt;xsl:param name="para.propagates.style" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If true, the role attribute of <tag>para</tag> elements
-will be passed through to the HTML as a class attribute on the
-<tag>p</tag> generated for the paragraph.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="phrase.propagates.style">
-<refmeta>
-<refentrytitle>phrase.propagates.style</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>phrase.propagates.style</refname>
-<refpurpose>Pass phrase role attribute through to HTML?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="phrase.propagates.style.frag">
-&lt;xsl:param name="phrase.propagates.style" select="1"&gt;&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, the role attribute of <tag>phrase</tag> elements
-will be passed through to the HTML as a <literal>class</literal>
-attribute on a <literal>span</literal> that surrounds the
-phrase.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="entry.propagates.style">
-<refmeta>
-<refentrytitle>entry.propagates.style</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>entry.propagates.style</refname>
-<refpurpose>Pass entry role attribute through to HTML?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="entry.propagates.style.frag">
-&lt;xsl:param name="entry.propagates.style" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If true, the role attribute of <tag>entry</tag> elements
-will be passed through to the HTML as a class attribute on the
-<tag>td</tag> or <tag>th</tag> generated for the table
-cell.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="html.longdesc">
-<refmeta>
-<refentrytitle>html.longdesc</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>html.longdesc</refname>
-<refpurpose>Should longdesc URIs be created?</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-<programlisting id="html.longdesc.frag">
-&lt;xsl:param name="html.longdesc" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-<refsection><info><title>Description</title></info>
-<para>If non-zero, HTML files will be created for the
-<literal>longdesc</literal> attribute. These files
-are created from the <tag>textobject</tag>s in
-<tag>mediaobject</tag>s and
-<tag>inlinemediaobject</tag>.
-</para>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="html.longdesc.link">
-<refmeta>
-<refentrytitle>html.longdesc.link</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>html.longdesc.link</refname>
-<refpurpose>Should a link to the longdesc be included in the HTML?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="html.longdesc.link.frag">
-&lt;xsl:param name="html.longdesc.link" select="$html.longdesc"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, links will be created to the
-HTML files created for the
-<literal>longdesc</literal> attribute. It makes no
-sense to enable this option without also enabling the
-<parameter>html.longdesc</parameter> parameter.</para>
-
-
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="make.valid.html">
-<refmeta>
-<refentrytitle>make.valid.html</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>make.valid.html</refname>
-<refpurpose>Attempt to make sure the HTML output is valid HTML</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="make.valid.html.frag">
-&lt;xsl:param name="make.valid.html" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If <parameter>make.valid.html</parameter> is true, the stylesheets take
-extra effort to ensure that the resulting HTML is valid. This may mean that some
-<tag>para</tag> tags are translated into HTML <tag>div</tag>s or
-that other substitutions occur.</para>
-
-<para>This parameter is different from <parameter>html.cleanup</parameter>
-because it changes the resulting markup; it does not use extension functions
-to manipulate result-tree-fragments and is therefore applicable to any
-XSLT processor.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="html.cleanup">
-<refmeta>
-<refentrytitle>html.cleanup</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>html.cleanup</refname>
-<refpurpose>Attempt to clean up the resulting HTML?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="html.cleanup.frag">
-&lt;xsl:param name="html.cleanup" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, and if the <link xlink:href="http://www.exslt.org/">EXSLT</link>
-extensions are supported by your processor, the resulting HTML will be
-<quote>cleaned up</quote>. This improves the chances that the
-resulting HTML will be valid. It may also improve the formatting of
-some elements.</para>
-
-<para>This parameter is different from <parameter>make.valid.html</parameter>
-because it uses extension functions to manipulate result-tree-fragments.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="html.append">
-<refmeta>
-<refentrytitle>html.append</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>html.append</refname>
-<refpurpose>Specifies content to append to HTML output</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="html.append.frag">&lt;xsl:param name="html.append"&gt;&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Specifies content to append to the end of HTML files output by
-the <filename>html/docbook.xsl</filename> stylesheet, after the
-closing <code>&lt;html&gt;</code> tag. You probably don&#8217;t want to set any
-value for this parameter; but if you do, the only value it should ever
-be set to is a newline character: <code>&amp;#x0a;</code> or
-<code>&amp;#10;</code></para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="draft.mode">
-<refmeta>
-<refentrytitle>draft.mode</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">list</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">no</refmiscinfo> 
-<refmiscinfo class="other" otherclass="value">yes</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">maybe</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>draft.mode</refname>
-<refpurpose>Select draft mode</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="draft.mode.frag">
-&lt;xsl:param name="draft.mode"&gt;no&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Selects draft mode. If <parameter>draft.mode</parameter> is
-<quote><literal>yes</literal></quote>, the entire document will be treated
-as a draft. If it is <quote><literal>no</literal></quote>, the entire document
-will be treated as a final copy. If it is <quote><literal>maybe</literal></quote>,
-individual sections will be treated as draft or final independently, depending
-on how their <literal>status</literal> attribute is set.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="draft.watermark.image">
-<refmeta>
-<refentrytitle>draft.watermark.image</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">uri</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>draft.watermark.image</refname>
-<refpurpose>The URI of the image to be used for draft watermarks</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="draft.watermark.image.frag">
-&lt;xsl:param name="draft.watermark.image"&gt;images/draft.png&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The image to be used for draft watermarks.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="generate.id.attributes">
-<refmeta>
-<refentrytitle>generate.id.attributes</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>generate.id.attributes</refname>
-<refpurpose>Generate ID attributes on container elements?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="generate.id.attributes.frag">
-&lt;xsl:param name="generate.id.attributes" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, the HTML stylesheet will generate ID attributes on
-containers. For example, the markup:</para>
-
-<screen>&lt;section id="foo"&gt;&lt;title&gt;Some Title&lt;/title&gt;
-&lt;para&gt;Some para.&lt;/para&gt;
-&lt;/section&gt;</screen>
-
-<para>might produce:</para>
-
-<screen>&lt;div class="section" id="foo"&gt;
-&lt;h2&gt;Some Title&lt;/h2&gt;
-&lt;p&gt;Some para.&lt;/p&gt;
-&lt;/div&gt;</screen>
-
-<para>The alternative is to generate anchors:</para>
-
-<screen>&lt;div class="section"&gt;
-&lt;h2&gt;&lt;a name="foo"&gt;&lt;/a&gt;Some Title&lt;/h2&gt;
-&lt;p&gt;Some para.&lt;/p&gt;
-&lt;/div&gt;</screen>
-
-<para>Because the <tag class="attribute">name</tag> attribute of
-the <tag>a</tag> element and the <tag class="attribute">id</tag>
-attribute of other tags are both of type <quote>ID</quote>, producing both
-generates invalid documents.</para>
-
-<para>As of version 1.50, you can use this switch to control which type of
-identifier is generated. For backwards-compatibility, generating
-<tag>a</tag> anchors is preferred.</para>
-
-<para>Note: at present, this switch is incompletely implemented.
-Disabling ID attributes will suppress them, but enabling ID attributes
-will not suppress the anchors.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="generate.consistent.ids">
-<refmeta>
-<refentrytitle>generate.consistent.ids</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>generate.consistent.ids</refname>
-<refpurpose>Generate consistent id values if document is unchanged</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="generate.consistent.ids.frag">
-&lt;xsl:param name="generate.consistent.ids" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>When the stylesheet assigns an id value to an output element,
-the generate-id() function may be used.  That function may not
-produce consistent values between runs.  Version control
-systems may misidentify the changing id values as changes
-to the document.</para>
-
-<para>If you set this parameter's value to 1, then the
-template named <literal>object.id</literal> will replace
-the use of the function generate-id() with
-<literal>&lt;xsl:number level="multiple" count="*"/&gt;</literal>.
-This counts preceding elements to generate a unique number for
-the id value.</para>
-
-<caution>
-<para>This param does not associate permanent unique id values
-with particular elements.
-The id values are consistent only as long as the document
-structure does not change.
-If the document structure changes, then the counting
-of elements changes, and all id values after
-the first such change may be different, even when there is
-no change to the element itself or its output.
-</para>
-</caution>
-
-<para>The default value of this parameter is zero, so generate-id() is used
-by default.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="generate.meta.abstract">
-<refmeta>
-<refentrytitle>generate.meta.abstract</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>generate.meta.abstract</refname>
-<refpurpose>Generate HTML <tag>META</tag> element from <tag>abstract</tag>?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="generate.meta.abstract.frag">
-&lt;xsl:param name="generate.meta.abstract" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, document abstracts will be reproduced in the HTML
-<literal>head</literal>, with <literal>&gt;meta name="description" content="..."</literal></para>
-
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="make.clean.html">
-<refmeta>
-<refentrytitle>make.clean.html</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>make.clean.html</refname>
-<refpurpose>Make HTML conform to modern coding standards</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="make.clean.html.frag">
-&lt;xsl:param name="make.clean.html" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If <parameter>make.clean.html</parameter> is true, the stylesheets take
-extra effort to ensure that the resulting HTML is conforms to
-modern HTML coding standards.  In addition to eliminating
-excessive and noncompliant coding, it moves presentation
-HTML coding to a CSS stylesheet.</para>
-
-<para>The resulting HTML is dependent on
-CSS for formatting, and so the stylesheet is capable of
-generating a supporting CSS file. The <parameter>docbook.css.source</parameter>
-and <parameter>custom.css.source</parameter> parameters control
-how a CSS file is generated.</para>
-
-<para>If you require your CSS to reside in the HTML 
-<tag>head</tag> element, then the <parameter>generate.css.header</parameter>
-can be used to do that.</para>
-
-<para>The <parameter>make.clean.html</parameter> parameter is
-different from <parameter>html.cleanup</parameter>
-because the former changes the resulting markup; it does not use extension functions
-like the latter to manipulate result-tree-fragments,
-and is therefore applicable to any XSLT processor.</para>
-
-<para>If <parameter>make.clean.html</parameter> is set to zero (the default),
-then the stylesheet retains its original 
-<quote>old style</quote>
-HTML formatting features.</para>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="docbook.css.source">
-  <refmeta>
-    <refentrytitle>docbook.css.source</refentrytitle>
-    <refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-  </refmeta>
-  <refnamediv>
-    <refname>docbook.css.source</refname>
-    <refpurpose>Name of the default CSS input file</refpurpose>
-  </refnamediv>
-
-  <refsynopsisdiv>
-    <programlisting id="docbook.css.source.frag">&lt;xsl:param name="docbook.css.source"&gt;docbook.css.xml&lt;/xsl:param&gt;</programlisting>
-  </refsynopsisdiv>
-
-  <refsection><info><title>Description</title></info>
-
-<para>The <parameter>docbook.css.source</parameter> parameter
-specifies the name of the file containing the default DocBook
-CSS styles.  Those styles are necessary when the
-<parameter>make.clean.html</parameter> parameter is nonzero.</para>
-
-<para>The file is a well-formed XML file that
-must consist of a single <tag>style</tag> root
-element that contains CSS styles as its text content.
-The default value of the parameter (and filename)
-is <literal>docbook.css.xml</literal>.
-The stylesheets ship with the default file. You can substitute
-your own and specify its path in this parameter.</para>
-
-<para>If <parameter>docbook.css.source</parameter> is not blank,
-and <parameter>make.clean.html</parameter> is nonzero, then
-the stylesheet takes the following actions:</para>
-
-<orderedlist>
-  <listitem>
-    <para>The stylesheet uses the XSLT <literal>document()</literal>
-    function to open the file specified by the parameter and
-    load it into a variable.</para>
-  </listitem>
-  <listitem>
-    <para>The stylesheet forms an output pathname consisting of the
-    value of the <parameter>base.dir</parameter> parameter (if it is set)
-    and the value of <parameter>docbook.css.source</parameter>,
-    with the <literal>.xml</literal> suffix stripped off.
-    </para>
-  </listitem>
-  <listitem>
-    <para>The stylesheet removes the <tag>style</tag>
-    wrapper element and writes just the CSS text content to the output file.</para>
-  </listitem>
-  <listitem>
-    <para>The stylesheet adds a <tag>link</tag> element to the
-    HTML <tag>HEAD</tag> element to reference the external CSS stylesheet.
-    For example:</para>
-    <programlisting>&lt;link rel="stylesheet" href="docbook.css" type="text/css"&gt;
-    </programlisting>
-    <para>However, if the <parameter>docbook.css.link</parameter>
-    parameter is set to zero, then no <tag>link</tag> is written
-    for the default CSS file.  That is useful if a custom
-    CSS file will import the default CSS stylesheet to ensure
-    proper cascading of styles.</para>
-  </listitem>
-</orderedlist>
-
-<para>If the <parameter>docbook.css.source</parameter> parameter
-is changed from its default <literal>docbook.css.xml</literal> to blank,
-then no default CSS is generated. Likewise if the
-<parameter>make.clean.html</parameter> parameter is set to zero,
-then no default CSS is generated. The 
-<parameter>custom.css.source</parameter> parameter can be used
-instead to generate a complete custom CSS file.</para>
-
-<para>You can use the <parameter>generate.css.header</parameter>
-parameter to instead write the CSS to each HTML <tag>HEAD</tag>
-element in a <tag>style</tag> tag instead of an external CSS file.</para>
-
-  </refsection>
-</refentry>
-
-<refentry version="5.0" id="docbook.css.link">
-<refmeta>
-<refentrytitle>docbook.css.link</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>docbook.css.link</refname>
-<refpurpose>Insert a link referencing the default CSS stylesheet</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="docbook.css.link.frag">
-&lt;xsl:param name="docbook.css.link" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The stylesheets are capable of generating a default
-CSS stylesheet file.  The parameters 
-<parameter>make.clean.html</parameter> and
-<parameter>docbook.css.source</parameter> control that feature.</para>
-
-<para>Normally if a default CSS file is generated, then 
-the stylesheet inserts a <tag>link</tag> tag in the HTML
-<tag>HEAD</tag> element to reference it.
-However, you can omit that <tag>link</tag> reference if
-you set the <parameter>docbook.css.link</parameter> to zero
-(1 is the default).</para>
-
-<para>This parameter is useful when you want to import the 
-default CSS into a custom CSS file generated using the
-<parameter>custom.css.source</parameter> parameter.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="custom.css.source">
-  <refmeta>
-    <refentrytitle>custom.css.source</refentrytitle>
-    <refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-  </refmeta>
-  <refnamediv>
-    <refname>custom.css.source</refname>
-    <refpurpose>Name of a custom CSS input file</refpurpose>
-  </refnamediv>
-
-  <refsynopsisdiv>
-    <programlisting id="custom.css.source.frag">&lt;xsl:param name="custom.css.source"&gt;&lt;/xsl:param&gt;</programlisting>
-  </refsynopsisdiv>
-
-  <refsection><info><title>Description</title></info>
-
-<para>The <parameter>custom.css.source</parameter>
-parameter enables you to add CSS styles to DocBook's
-HTML output.</para>
-
-<para>The parameter
-specifies the name of a file containing custom
-CSS styles.  The file must be a well-formed XML file that
-consists of a single <tag>style</tag> root
-element that contains CSS styles as its text content.
-For example:</para>
-<programlisting>&lt;?xml version="1.0"?&gt;
-&lt;style&gt;
-h2 {
-  font-weight: bold;
-  color: blue;
-}
-...
-&lt;/style&gt;
-</programlisting>
-
-<para>The filename specified by the parameter
-should have a <literal>.xml</literal>
-filename suffix, although that is not required.
-The default value of this parameter is blank.</para>
-
-<para>If <parameter>custom.css.source</parameter> is not blank, then
-the stylesheet takes the following actions.
-These actions take place regardless of the value of
-the <parameter>make.clean.html</parameter> parameter.</para>
-
-<orderedlist>
-  <listitem>
-    <para>The stylesheet uses the XSLT <literal>document()</literal>
-    function to open the file specified by the parameter and
-    load it into a variable.</para>
-  </listitem>
-  <listitem>
-    <para>The stylesheet forms an output pathname consisting of the
-    value of the <parameter>base.dir</parameter> parameter (if it is set)
-    and the value of <parameter>custom.css.source</parameter>,
-    with the <literal>.xml</literal> suffix stripped off.
-    </para>
-  </listitem>
-  <listitem>
-    <para>The stylesheet removes the <tag>style</tag>
-    wrapper element and writes just the CSS text content to the output file.</para>
-  </listitem>
-  <listitem>
-    <para>The stylesheet adds a <tag>link</tag> element to the
-    HTML <tag>HEAD</tag> element to reference this external CSS stylesheet.
-    For example:
-    <programlisting>&lt;link rel="stylesheet" href="custom.css" type="text/css"&gt;
-    </programlisting>
-    </para>
-  </listitem>
-</orderedlist>
-
-
-
-<para>If the <parameter>make.clean.html</parameter> parameter is nonzero
-(the default is zero),
-and if the <parameter>docbook.css.source</parameter> parameter
-is not blank (the default is not blank),
-then the stylesheet will also generate a default CSS file
-and add a <tag>link</tag> tag to reference it.
-The <tag>link</tag> to the custom CSS comes after the 
-<tag>link</tag> to the default, so it should cascade properly
-in most browsers.
-If you do not want two <tag>link</tag> tags, and
-instead want your custom CSS to import the default generated
-CSS file, then do the following:
-</para>
-
-<orderedlist>
-  <listitem>
-    <para>Add a line like the following to your custom CSS source file:</para>
-    <programlisting>@import url("docbook.css")
-    </programlisting>
-  </listitem>
-  <listitem>
-    <para>Set the <parameter>docbook.css.link</parameter> parameter 
-    to zero. This will omit the <tag>link</tag> tag
-    that references the default CSS file.</para>
-  </listitem>
-</orderedlist>
-
-<para>If you set <parameter>make.clean.html</parameter> to nonzero but
-you do not want the default CSS generated, then also set
-the <parameter>docbook.css.source</parameter> parameter to blank.
-Then no default CSS will be generated, and so
-all CSS styles must come from your custom CSS file.</para>
-
-<para>You can use the <parameter>generate.css.header</parameter>
-parameter to instead write the CSS to each HTML <tag>HEAD</tag>
-element in a <tag>style</tag> tag instead of an external CSS file.</para>
-
-  </refsection>
-</refentry>
-
-<refentry version="5.0" id="generate.css.header">
-<refmeta>
-<refentrytitle>generate.css.header</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>generate.css.header</refname>
-<refpurpose>Insert generated CSS styles in HEAD element</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="generate.css.header.frag">
-&lt;xsl:param name="generate.css.header" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The stylesheets are capable of generating both default
-and custom CSS stylesheet files.  The parameters 
-<parameter>make.clean.html</parameter>,
-<parameter>docbook.css.source</parameter>, and
-<parameter>custom.css.source</parameter> control that feature.</para>
-
-<para>If you require that CSS styles reside in the HTML 
-<tag>HEAD</tag> element instead of external CSS files,
-then set the <parameter>generate.css.header</parameter>
-parameter to nonzero (it is zero by default).
-Then instead of generating the CSS in external files,
-they are wrapped in <tag>style</tag> elements in
-the <tag>HEAD</tag> element of each HTML output file.
-</para>
-
-</refsection>
-</refentry>
-
-</reference><reference id="xslt" xml:base="../html/param.xml"><title>XSLT Processing</title>
-<refentry version="5.0" id="rootid">
-<refmeta>
-<refentrytitle>rootid</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>rootid</refname>
-<refpurpose>Specify the root element to format</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="rootid.frag">
-&lt;xsl:param name="rootid"&gt;&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If <parameter>rootid</parameter> is not empty, it must be the
-value of an ID that occurs in the document being formatted. The entire
-document will be loaded and parsed, but formatting will begin at the
-element identified, rather than at the root. For example, this allows
-you to process only <tag>chapter</tag> 4 of a <tag>book</tag>.</para>
-<para>Because the entire document is available to the processor, automatic
-numbering, cross references, and other dependencies are correctly
-resolved.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="suppress.navigation">
-<refmeta>
-<refentrytitle>suppress.navigation</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>suppress.navigation</refname>
-<refpurpose>Disable header and footer navigation</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="suppress.navigation.frag">
-&lt;xsl:param name="suppress.navigation" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>
-If non-zero, header and footer navigation will be suppressed.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="suppress.header.navigation">
-<refmeta>
-<refentrytitle>suppress.header.navigation</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>suppress.header.navigation</refname>
-<refpurpose>Disable header navigation</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="suppress.header.navigation.frag">
-&lt;xsl:param name="suppress.header.navigation" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, header navigation will be suppressed.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="suppress.footer.navigation">
-<refmeta>
-<refentrytitle>suppress.footer.navigation</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>suppress.footer.navigation</refname>
-<refpurpose>Disable footer navigation</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="suppress.footer.navigation.frag">&lt;xsl:param name="suppress.footer.navigation"&gt;0&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>
-If non-zero, footer navigation will be suppressed.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="header.rule">
-<refmeta>
-<refentrytitle>header.rule</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>header.rule</refname>
-<refpurpose>Rule under headers?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="header.rule.frag">
-&lt;xsl:param name="header.rule" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, a rule will be drawn below the page headers.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="footer.rule">
-<refmeta>
-<refentrytitle>footer.rule</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>footer.rule</refname>
-<refpurpose>Rule over footers?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="footer.rule.frag">
-&lt;xsl:param name="footer.rule" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, a rule will be drawn above the page footers.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="id.warnings">
-<refmeta>
-<refentrytitle>id.warnings</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>id.warnings</refname>
-<refpurpose>Should warnings be generated for titled elements without IDs?</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-<programlisting id="id.warnings.frag">
-&lt;xsl:param name="id.warnings" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-<refsection><info><title>Description</title></info>
-<para>If non-zero, the stylesheet will issue a warning for any element
-(other than the root element) which has a <tag>title</tag> but does not have an
-ID.</para>
-</refsection>
-</refentry>
-
-</reference><reference id="meta" xml:base="../html/param.xml"><title>Meta/*Info and Titlepages</title>
-<refentry version="5.0" id="inherit.keywords">
-<refmeta>
-<refentrytitle>inherit.keywords</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>inherit.keywords</refname>
-<refpurpose>Inherit keywords from ancestor elements?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="inherit.keywords.frag">
-&lt;xsl:param name="inherit.keywords" select="1"&gt;&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If <parameter>inherit.keywords</parameter>
-is non-zero, the keyword <literal>meta</literal> for each HTML
-<literal>head</literal> element will include all of the keywords from
-ancestor elements. Otherwise, only the keywords from the current section
-will be used.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="make.single.year.ranges">
-<refmeta>
-<refentrytitle>make.single.year.ranges</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>make.single.year.ranges</refname>
-<refpurpose>Print single-year ranges (e.g., 1998-1999)</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="make.single.year.ranges.frag">
-&lt;xsl:param name="make.single.year.ranges" select="0"&gt;&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, year ranges that span a single year will be printed
-in range notation (1998-1999) instead of discrete notation
-(1998, 1999).</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="make.year.ranges">
-<refmeta>
-<refentrytitle>make.year.ranges</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>make.year.ranges</refname>
-<refpurpose>Collate copyright years into ranges?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="make.year.ranges.frag">&lt;xsl:param name="make.year.ranges" select="0"&gt;&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, multiple copyright <tag>year</tag> elements will be
-collated into ranges.
-This works only if each year number is put into a separate
-year element.  The copyright element permits multiple
-year elements. If a year element contains a dash or
-a comma, then that year element will not be merged into
-any range.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="author.othername.in.middle">
-<refmeta>
-<refentrytitle>author.othername.in.middle</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>author.othername.in.middle</refname>
-<refpurpose>Is <tag>othername</tag> in <tag>author</tag> a
-middle name?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="author.othername.in.middle.frag">
-&lt;xsl:param name="author.othername.in.middle" select="1"&gt;&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, the <tag>othername</tag> of an <tag>author</tag>
-appears between the <tag>firstname</tag> and
-<tag>surname</tag>.  Otherwise, <tag>othername</tag>
-is suppressed.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="blurb.on.titlepage.enabled">
-<refmeta>
-<refentrytitle>blurb.on.titlepage.enabled</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>blurb.on.titlepage.enabled</refname>
-<refpurpose>Display personblurb and authorblurb on title pages?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="blurb.on.titlepage.enabled.frag">
-&lt;xsl:param name="blurb.on.titlepage.enabled" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, output from <tag>authorblurb</tag> and
-<tag>personblurb</tag> elements is displayed on title pages. If zero
-(the default), output from those elements is suppressed on title pages
-(unless you are using a <literal>titlepage</literal> customization
-that causes them to be included).</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="contrib.inline.enabled">
-<refmeta>
-<refentrytitle>contrib.inline.enabled</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>contrib.inline.enabled</refname>
-<refpurpose>Display contrib output inline?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="contrib.inline.enabled.frag">&lt;xsl:param name="contrib.inline.enabled"&gt;1&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero (the default), output of the <tag>contrib</tag> element is
-displayed as inline content rather than as block content.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="editedby.enabled">
-<refmeta>
-<refentrytitle>editedby.enabled</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>editedby.enabled</refname>
-<refpurpose>Display &#8220;Edited by&#8221; heading above editor name?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="editedby.enabled.frag">&lt;xsl:param name="editedby.enabled"&gt;1&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, a localized <emphasis role="bold">Edited
-by</emphasis> heading is displayed above editor names in output of the
-<tag>editor</tag> element.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="abstract.notitle.enabled">
-<refmeta>
-<refentrytitle>abstract.notitle.enabled</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>abstract.notitle.enabled</refname>
-<refpurpose>Suppress display of abstract titles?</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-  <programlisting id="abstract.notitle.enabled.frag">&lt;xsl:param name="abstract.notitle.enabled" select="0"&gt;&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-<refsection><info><title>Description</title></info>
-<para>If non-zero, in output of the <tag>abstract</tag> element on titlepages,
-display of the abstract title is suppressed.</para>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="othercredit.like.author.enabled">
-<refmeta>
-<refentrytitle>othercredit.like.author.enabled</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>othercredit.like.author.enabled</refname>
-<refpurpose>Display othercredit in same style as author?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="othercredit.like.author.enabled.frag">&lt;xsl:param name="othercredit.like.author.enabled"&gt;0&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, output of the
-<tag>othercredit</tag> element on titlepages is displayed in
-the same style as <tag>author</tag> and
-<tag>editor</tag> output. If zero then
-<tag>othercredit</tag> output is displayed using a style
-different than that of <tag>author</tag> and
-<tag>editor</tag>.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="generate.legalnotice.link">
-<refmeta>
-<refentrytitle>generate.legalnotice.link</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>generate.legalnotice.link</refname>
-<refpurpose>Write legalnotice to separate chunk and generate link?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="generate.legalnotice.link.frag">&lt;xsl:param name="generate.legalnotice.link" select="0"&gt;&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If the value of <parameter>generate.legalnotice.link</parameter>
-is non-zero, the stylesheet:
-
-<itemizedlist>
-  <listitem>
-    <para>writes the contents of <tag>legalnotice</tag> to a separate
-    HTML file</para>
-  </listitem>
-  <listitem>
-    <para>inserts a hyperlink to the <tag>legalnotice</tag> file</para>
-  </listitem>
-  <listitem>
-    <para>adds (in the HTML <literal>head</literal>) either a single
-    <literal>link</literal> or element or multiple
-    <literal>link</literal> elements (depending on the value of the
-    <parameter>html.head.legalnotice.link.multiple</parameter>
-    parameter), with the value or values derived from the
-    <parameter>html.head.legalnotice.link.types</parameter>
-    parameter</para>
-  </listitem>
-  </itemizedlist>
-
-  Otherwise, if <parameter>generate.legalnotice.link</parameter> is
-  zero, <tag>legalnotice</tag> contents are rendered on the title
-  page.</para>
-
-<para>The name of the separate HTML file is computed as follows:
-
-<orderedlist>
-<listitem>
-  <para>If a filename is given by the <tag class="xmlpi">dbhtml filename</tag> 
-processing instruction, that filename is used.</para>
-</listitem>
-<listitem>
-  <para>If the legalnotice has an <tag class="attribute">id</tag>/<tag class="attribute">xml:id</tag> 
-attribute, and if <parameter>use.id.as.filename</parameter> != 0, the filename 
-is the concatenation of the id value and the value of the <parameter>html.ext</parameter> 
-parameter.</para>
-</listitem>
-<listitem>
-  <para>If the legalnotice does not have an <tag class="attribute">id</tag>/<tag class="attribute">xml:id</tag>
- attribute, or if <parameter>use.id.as.filename</parameter> = 0, the filename is the concatenation of "ln-", 
-auto-generated id value, and <parameter>html.ext</parameter> value.
-  </para>
-</listitem>
-</orderedlist>
-
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="generate.revhistory.link">
-<refmeta>
-<refentrytitle>generate.revhistory.link</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>generate.revhistory.link</refname>
-<refpurpose>Write revhistory to separate chunk and generate link?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="generate.revhistory.link.frag">&lt;xsl:param name="generate.revhistory.link" select="0"&gt;&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, the contents of <tag>revhistory</tag> are written
-to a separate HTML file and a link to the file is
-generated. Otherwise, <tag>revhistory</tag> contents are rendered on
-the title page.</para>
-
-<para>The name of the separate HTML file is computed as follows:
-
-<orderedlist>
-<listitem>
-  <para>If a filename is given by the <tag class="xmlpi">dbhtml filename</tag> processing instruction, 
-that filename is used.</para>
-</listitem>
-<listitem>
-  <para>If the revhistory has an <tag class="attribute">id</tag>/<tag class="attribute">xml:id</tag> 
-attribute, and if <parameter>use.id.as.filename</parameter> != 0, the filename is the concatenation of 
-the id value and the value of the <parameter>html.ext</parameter> parameter.</para>
-</listitem>
-<listitem>
-  <para>If the revhistory does not have an <tag class="attribute">id</tag>/<tag class="attribute">xml:id</tag> 
-attribute, or if <parameter>use.id.as.filename</parameter> = 0, the filename is the concatenation of "rh-", 
-auto-generated id value, and <parameter>html.ext</parameter> value.
-  </para>
-</listitem>
-</orderedlist>
-
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="html.head.legalnotice.link.types">
-<refmeta>
-<refentrytitle>html.head.legalnotice.link.types</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>html.head.legalnotice.link.types</refname>
-<refpurpose>Specifies link types for legalnotice link in html head</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="html.head.legalnotice.link.types.frag">
-&lt;xsl:param name="html.head.legalnotice.link.types"&gt;copyright&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The value of
-<parameter>html.head.legalnotice.link.types</parameter> is a
-space-separated list of link types, as described in <link xlink:href="http://www.w3.org/TR/html401/types.html#type-links">Section 6.12
-of the HTML 4.01 specification</link>. If the value of the
-<parameter>generate.legalnotice.link</parameter> parameter is
-non-zero, then the stylesheet generates (in the
-<literal>head</literal> section of the HTML source) either a single
-HTML <literal>link</literal> element or, if the value of the
-<parameter>html.head.legalnotice.link.multiple</parameter> is
-non-zero, one <literal>link</literal> element for each link type
-specified. Each <literal>link</literal> has the following attributes:
-
-<itemizedlist>
-  <listitem>
-    <para>a <tag class="attribute">rel</tag> attribute whose
-    value is derived from the value of
-    <parameter>html.head.legalnotice.link.types</parameter></para>
-  </listitem>
-  <listitem>
-    <para>an <tag class="attribute">href</tag> attribute whose
-    value is set to the URL of the file containing the
-    <tag>legalnotice</tag></para>
-  </listitem>
-  <listitem>
-    <para>a <tag class="attribute">title</tag> attribute whose
-    value is set to the title of the corresponding
-    <tag>legalnotice</tag> (or a title programatically
-    determined by the stylesheet)</para>
-  </listitem>
-</itemizedlist>
-
-For example:
-
-<screen>  &lt;link rel="license" href="ln-id2524073.html" title="Legal Notice"&gt;</screen>
-</para>
-
-<refsection><info><title>About the default value</title></info>
-  
-  <para>In an ideal world, the default value of
-  <parameter>html.head.legalnotice.link.types</parameter> would
-  probably be &#8220;<literal>license</literal>&#8221;, since the content of the
-  DocBook <tag>legalnotice</tag> is typically license
-  information, not copyright information. However, the default value
-  is &#8220;<literal>copyright</literal>&#8221; for pragmatic reasons: because
-  that&#8217;s among the set of &#8220;recognized link types&#8221; listed in <link xlink:href="http://www.w3.org/TR/html401/types.html#type-links">Section
-  6.12 of the HTML 4.01 specification</link>, and because certain
-  browsers and browser extensions are preconfigured to recognize that
-  value.</para>
-</refsection>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="html.head.legalnotice.link.multiple">
-<refmeta>
-<refentrytitle>html.head.legalnotice.link.multiple</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>html.head.legalnotice.link.multiple</refname>
-<refpurpose>Generate multiple link instances in html head for legalnotice?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="html.head.legalnotice.link.multiple.frag">
-&lt;xsl:param name="html.head.legalnotice.link.multiple" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If <parameter>html.head.legalnotice.link.multiple</parameter> is
-non-zero and the value of
-<parameter>html.head.legalnotice.link.types</parameter> contains
-multiple link types, then the stylesheet generates (in the
-<literal>head</literal> section of the HTML source) one
-<literal>link</literal> element for each link type specified. For
-example, if the value of
-<parameter>html.head.legalnotice.link.types</parameter> is
-&#8220;<literal>copyright license</literal>&#8221;:
-
-<screen>  &lt;link rel="copyright" href="ln-id2524073.html" title="Legal Notice"&gt;
-  &lt;link rel="license" href="ln-id2524073.html" title="Legal Notice"&gt;</screen>
-
- Otherwise, the stylesheet generates generates a single
- <literal>link</literal> instance; for example:
-
-<screen>  &lt;link rel="copyright license" href="ln-id2524073.html" title="Legal Notice"&gt;</screen>
- 
-</para>
-</refsection>
-</refentry>
-
-</reference><reference id="refentry" xml:base="../html/param.xml"><title>Reference Pages</title>
-<refentry version="5.0" id="funcsynopsis.decoration">
-<refmeta>
-<refentrytitle>funcsynopsis.decoration</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>funcsynopsis.decoration</refname>
-<refpurpose>Decorate elements of a <tag>funcsynopsis</tag>?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="funcsynopsis.decoration.frag">
-&lt;xsl:param name="funcsynopsis.decoration" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, elements of the <tag>funcsynopsis</tag> will be
-decorated (e.g. rendered as bold or italic text). The decoration is controlled by
-templates that can be redefined in a customization layer.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="funcsynopsis.style">
-<refmeta>
-<refentrytitle>funcsynopsis.style</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">list</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">ansi</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">kr</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>funcsynopsis.style</refname>
-<refpurpose>What style of <tag>funcsynopsis</tag> should be generated?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="funcsynopsis.style.frag">&lt;xsl:param name="funcsynopsis.style"&gt;kr&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If <parameter>funcsynopsis.style</parameter> is <literal>ansi</literal>,
-ANSI-style function synopses are generated for a
-<tag>funcsynopsis</tag>, otherwise K&amp;R-style
-function synopses are generated.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="function.parens">
-<refmeta>
-<refentrytitle>function.parens</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>function.parens</refname>
-<refpurpose>Generate parens after a function?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="function.parens.frag">
-&lt;xsl:param name="function.parens" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, the formatting of a <tag>function</tag> element
-will include generated parentheses.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="refentry.generate.name">
-<refmeta>
-<refentrytitle>refentry.generate.name</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>refentry.generate.name</refname>
-<refpurpose>Output NAME header before <tag>refname</tag>s?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="refentry.generate.name.frag">
-&lt;xsl:param name="refentry.generate.name" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, a "NAME" section title is output before the list
-of <tag>refname</tag>s. This parameter and
-<parameter>refentry.generate.title</parameter> are mutually
-exclusive. This means that if you change this parameter to zero, you
-should set <parameter>refentry.generate.title</parameter> to non-zero unless
-you want get quite strange output.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="refentry.generate.title">
-<refmeta>
-<refentrytitle>refentry.generate.title</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>refentry.generate.title</refname>
-<refpurpose>Output title before <tag>refname</tag>s?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="refentry.generate.title.frag">
-&lt;xsl:param name="refentry.generate.title" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, the reference page title or first name is
-output before the list of <tag>refname</tag>s. This parameter and
-<parameter>refentry.generate.name</parameter> are mutually exclusive.
-This means that if you change this parameter to non-zero, you
-should set <parameter>refentry.generate.name</parameter> to zero unless
-you want get quite strange output.</para>
-
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="refentry.xref.manvolnum">
-<refmeta>
-<refentrytitle>refentry.xref.manvolnum</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>refentry.xref.manvolnum</refname>
-<refpurpose>Output <tag>manvolnum</tag> as part of 
-<tag>refentry</tag> cross-reference?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="refentry.xref.manvolnum.frag">
-&lt;xsl:param name="refentry.xref.manvolnum" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>if non-zero, the <tag>manvolnum</tag> is used when cross-referencing
-<tag>refentry</tag>s, either with <tag>xref</tag>
-or <tag>citerefentry</tag>.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="citerefentry.link">
-<refmeta>
-<refentrytitle>citerefentry.link</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>citerefentry.link</refname>
-<refpurpose>Generate URL links when cross-referencing RefEntrys?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="citerefentry.link.frag">
-&lt;xsl:param name="citerefentry.link" select="0"&gt;&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, a web link will be generated, presumably
-to an online man-&gt;HTML gateway. The text of the link is
-generated by the <literal>generate.citerefentry.link</literal> template.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="refentry.separator">
-<refmeta>
-<refentrytitle>refentry.separator</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>refentry.separator</refname>
-<refpurpose>Generate a separator between consecutive RefEntry elements?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="refentry.separator.frag">
-&lt;xsl:param name="refentry.separator" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If true, a separator will be generated between consecutive
-reference pages.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="refclass.suppress">
-<refmeta>
-<refentrytitle>refclass.suppress</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>refclass.suppress</refname>
-<refpurpose>Suppress display of refclass contents?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="refclass.suppress.frag">
-&lt;xsl:param name="refclass.suppress" select="0"&gt;&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If the value of <parameter>refclass.suppress</parameter> is
-non-zero, then display of <tag>refclass</tag> contents is
-suppressed in output.</para>
-
-</refsection>
-</refentry>
-
-</reference><reference id="tables" xml:base="../html/param.xml"><title>Tables</title>
-<refentry version="5.0" id="default.table.width">
-<refmeta>
-<refentrytitle>default.table.width</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">length</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>default.table.width</refname>
-<refpurpose>The default width of tables</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-<programlisting id="default.table.width.frag">
-&lt;xsl:param name="default.table.width"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-<refsection><info><title>Description</title></info>
-<para>If non-zero, this value will be used for the
-<literal>width</literal> attribute on <tag>table</tag>s that do not specify an
-alternate width (with the <tag class="xmlpi">dbhtml table-width</tag> or 
-<tag class="xmlpi">dbfo table-width</tag> processing instruction).</para>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="nominal.table.width">
-<refmeta>
-<refentrytitle>nominal.table.width</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">length</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>nominal.table.width</refname>
-<refpurpose>The (absolute) nominal width of tables</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="nominal.table.width.frag">
-&lt;xsl:param name="nominal.table.width"&gt;6in&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>In order to convert CALS column widths into HTML column widths, it
-is sometimes necessary to have an absolute table width to use for conversion
-of mixed absolute and relative widths. This value must be an absolute
-length (not a percentage).</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="table.borders.with.css">
-<refmeta>
-<refentrytitle>table.borders.with.css</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>table.borders.with.css</refname>
-<refpurpose>Use CSS to specify table, row, and cell borders?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="table.borders.with.css.frag">
-&lt;xsl:param name="table.borders.with.css" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, CSS will be used to draw table borders.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="table.cell.border.style">
-<refmeta>
-<refentrytitle>table.cell.border.style</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">list</refmiscinfo> 
-<refmiscinfo class="other" otherclass="value">none</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">solid</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">dotted</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">dashed</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">double</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">groove</refmiscinfo>                       
-<refmiscinfo class="other" otherclass="value">ridge</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">inset</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">outset</refmiscinfo>          
-<refmiscinfo class="other" otherclass="value">solid</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>table.cell.border.style</refname>
-<refpurpose>Specifies the border style of table cells</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="table.cell.border.style.frag">
-&lt;xsl:param name="table.cell.border.style"&gt;solid&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Specifies the border style of table cells.</para>
-
-<note>
-  <para>To control properties of cell borders in HTML output, you must also turn on the 
-  <parameter>table.borders.with.css</parameter> parameter.</para>
-</note>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="table.cell.border.thickness">
-<refmeta>
-<refentrytitle>table.cell.border.thickness</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">length</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>table.cell.border.thickness</refname>
-<refpurpose>Specifies the thickness of table cell borders</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="table.cell.border.thickness.frag">
-&lt;xsl:param name="table.cell.border.thickness"&gt;0.5pt&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, specifies the thickness of borders on table
-cells. The units are points. See <link xlink:href="http://www.w3.org/TR/CSS21/box.html#border-width-properties">
-CSS</link></para>
-
-<note>
-  <para>To control properties of cell borders in HTML output, you must also turn on the 
-  <parameter>table.borders.with.css</parameter> parameter.</para>
-</note>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="table.cell.border.color">
-<refmeta>
-<refentrytitle>table.cell.border.color</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">color</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>table.cell.border.color</refname>
-<refpurpose>Specifies the border color of table cells</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="table.cell.border.color.frag">
-&lt;xsl:param name="table.cell.border.color"&gt;&lt;/xsl:param&gt;
-
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Set the color of table cell borders. If non-zero, the value is used
-for the border coloration. See <link xlink:href="http://www.w3.org/TR/CSS21/syndata.html#value-def-color">CSS</link>. A
-<literal>color</literal> is either a keyword or a numerical RGB specification.
-Keywords are aqua, black, blue, fuchsia, gray, green, lime, maroon,
-navy, olive, orange, purple, red, silver, teal, white, and
-yellow.</para>
-
-<note>
-  <para>To control properties of cell borders in HTML output, you must also turn on the 
-  <parameter>table.borders.with.css</parameter> parameter.</para>
-</note>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="table.frame.border.style">
-<refmeta>
-<refentrytitle>table.frame.border.style</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">list</refmiscinfo> 
-<refmiscinfo class="other" otherclass="value">none</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">solid</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">dotted</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">dashed</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">double</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">groove</refmiscinfo>                       
-<refmiscinfo class="other" otherclass="value">ridge</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">inset</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">outset</refmiscinfo>          
-<refmiscinfo class="other" otherclass="value">solid</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>table.frame.border.style</refname>
-<refpurpose>Specifies the border style of table frames</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="table.frame.border.style.frag">
-&lt;xsl:param name="table.frame.border.style"&gt;solid&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Specifies the border style of table frames.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="table.frame.border.thickness">
-<refmeta>
-<refentrytitle>table.frame.border.thickness</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">length</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>table.frame.border.thickness</refname>
-<refpurpose>Specifies the thickness of the frame border</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="table.frame.border.thickness.frag">
-&lt;xsl:param name="table.frame.border.thickness"&gt;0.5pt&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Specifies the thickness of the border on the table's frame.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="table.frame.border.color">
-<refmeta>
-<refentrytitle>table.frame.border.color</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">color</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>table.frame.border.color</refname>
-<refpurpose>Specifies the border color of table frames</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="table.frame.border.color.frag">
-&lt;xsl:param name="table.frame.border.color"&gt;&lt;/xsl:param&gt;
-
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Specifies the border color of table frames.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="default.table.frame">
-<refmeta>
-<refentrytitle>default.table.frame</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>default.table.frame</refname>
-<refpurpose>The default framing of tables</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="default.table.frame.frag">
-&lt;xsl:param name="default.table.frame"&gt;all&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This value will be used when there is no frame attribute on the
-table. </para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="html.cellspacing">
-<refmeta>
-<refentrytitle>html.cellspacing</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">integer</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>html.cellspacing</refname>
-<refpurpose>Default value for cellspacing in HTML tables</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="html.cellspacing.frag">
-&lt;xsl:param name="html.cellspacing"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, this value will be used as the default cellspacing
-value in HTML tables. nn for pixels or nn% for percentage
-length. E.g. 5 or 5%</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="html.cellpadding">
-<refmeta>
-<refentrytitle>html.cellpadding</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">integer</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>html.cellpadding</refname>
-<refpurpose>Default value for cellpadding in HTML tables</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="html.cellpadding.frag">
-&lt;xsl:param name="html.cellpadding"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, this value will be used as the default cellpadding value
-in HTML tables. nn for pixels or nn% for percentage length. E.g. 5 or
-5%</para>
-
-</refsection>
-</refentry>
-
-</reference><reference id="qa" xml:base="../html/param.xml"><title>QAndASet</title>
-<refentry version="5.0" id="qanda.defaultlabel">
-<refmeta>
-<refentrytitle>qanda.defaultlabel</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">list</refmiscinfo> 
-<refmiscinfo class="other" otherclass="value">number</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">qanda</refmiscinfo> 
-<refmiscinfo class="other" otherclass="value">none</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>qanda.defaultlabel</refname>
-<refpurpose>Sets the default for defaultlabel on QandASet.</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="qanda.defaultlabel.frag">
-&lt;xsl:param name="qanda.defaultlabel"&gt;number&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If no <literal>defaultlabel</literal> attribute is specified on
-a <tag>qandaset</tag>, this value is used. It is generally one of the legal
-values for the defaultlabel attribute (<literal>none</literal>, 
-<literal>number</literal> or
-<literal>qanda</literal>), or one of the additional stylesheet-specific values
-(<literal>qnumber</literal> or <literal>qnumberanda</literal>).
-The default value is 'number'.
-</para>
-<para>The values are rendered as follows:</para>
-<variablelist>
-<varlistentry><term><literal>qanda</literal></term>
-<listitem>
-<para><tag>question</tag>s are labeled "Q:" and
-<tag>answer</tag>s are labeled "A:". </para>
-</listitem>
-</varlistentry>
-
-<varlistentry><term><literal>number</literal></term>
-<listitem>
-<para>The questions are enumerated and the answers
-are not labeled. </para>
-</listitem>
-</varlistentry>
-
-<varlistentry><term><literal>qnumber</literal></term>
-<listitem>
-<para>The questions are labeled "Q:" followed by a number, and answers are not 
-labeled. 
-When sections are numbered, adding a label
-to the number distinguishes the question numbers
-from the section numbers.
-This value is not allowed in the
-<tag class="attribute">defaultlabel</tag> attribute
-of a <tag>qandaset</tag> element.</para>
-</listitem>
-</varlistentry>
-
-<varlistentry><term><literal>qnumberanda</literal></term>
-<listitem>
-<para>The questions are labeled "Q:" followed by a number, and
-the answers are labeled "A:". 
-When sections are numbered, adding a label
-to the number distinguishes the question numbers
-from the section numbers.
-This value is not allowed in the
-<tag class="attribute">defaultlabel</tag> attribute
-of a <tag>qandaset</tag> element.</para>
-</listitem>
-</varlistentry>
-
-<varlistentry><term><literal>none</literal></term>
-<listitem>
-<para>No distinguishing label precedes Questions or Answers. 
-</para>
-</listitem>
-</varlistentry>
-</variablelist>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="qanda.inherit.numeration">
-<refmeta>
-<refentrytitle>qanda.inherit.numeration</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>qanda.inherit.numeration</refname>
-<refpurpose>Does enumeration of QandASet components inherit the numeration of parent elements?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="qanda.inherit.numeration.frag">
-&lt;xsl:param name="qanda.inherit.numeration" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, numbered <tag>qandadiv</tag> elements and
-<tag>question</tag> and <tag>answer</tag> inherit the enumeration of
-the ancestors of the <tag>qandaset</tag>.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="qanda.in.toc">
-<refmeta>
-<refentrytitle>qanda.in.toc</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>qanda.in.toc</refname>
-<refpurpose>Should qandaentry questions appear in 
-the document table of contents?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="qanda.in.toc.frag">&lt;xsl:param name="qanda.in.toc" select="0"&gt;&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If true (non-zero), then the generated table of contents
-for a document will include <tag>qandaset</tag> titles, 
-<tag>qandadiv</tag> titles,
-and <tag>question</tag> elements.  The default value (zero) excludes
-them from the TOC.
-</para>
-<para>This parameter does not affect any tables of contents
-that may be generated inside a qandaset or qandadiv.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="qanda.nested.in.toc">
-<refmeta>
-<refentrytitle>qanda.nested.in.toc</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>qanda.nested.in.toc</refname>
-<refpurpose>Should nested answer/qandaentry instances appear in TOC?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="qanda.nested.in.toc.frag">
-&lt;xsl:param name="qanda.nested.in.toc" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, instances of <tag>qandaentry</tag>
-that are children of <tag>answer</tag> elements are shown in
-the TOC.</para>
-
-</refsection>
-</refentry>
-
-</reference><reference id="links" xml:base="../html/param.xml"><title>Linking</title>
-<refentry version="5.0" id="target.database.document"> 
-<refmeta> 
-<refentrytitle>target.database.document</refentrytitle> 
-<refmiscinfo class="other" otherclass="datatype">uri</refmiscinfo> 
-</refmeta> 
-<refnamediv> 
-<refname>target.database.document</refname> 
-<refpurpose>Name of master database file for resolving
-olinks</refpurpose> 
-</refnamediv> 
-<refsynopsisdiv> 
-<programlisting id="target.database.document.frag">
- &lt;xsl:param name="target.database.document"&gt;olinkdb.xml&lt;/xsl:param&gt;
-</programlisting> 
-</refsynopsisdiv> 
-<refsection><info><title>Description</title></info>
- 
-<para>
-To resolve olinks between documents, the stylesheets use a master
-database document that identifies the target datafiles for all the
-documents within the scope of the olinks. This parameter value is the
-URI of the master document to be read during processing to resolve
-olinks.  The default value is <filename>olinkdb.xml</filename>.</para>
-
-<para>The data structure of the file is defined in the
-<filename>targetdatabase.dtd</filename> DTD.  The database file
-provides the high level elements to record the identifiers, locations,
-and relationships of documents. The cross reference data for
-individual documents is generally pulled into the database using
-system entity references or XIncludes. See also
-<parameter>targets.filename</parameter>.  </para> </refsection>
-</refentry>
-
-<refentry version="5.0" id="targets.filename"> 
-<refmeta> 
-<refentrytitle>targets.filename</refentrytitle> 
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo> 
-</refmeta> 
-<refnamediv> 
-<refname>targets.filename</refname> 
-<refpurpose>Name of cross reference targets data file</refpurpose> 
-</refnamediv> 
-<refsynopsisdiv> <programlisting id="targets.filename.frag">
-&lt;xsl:param name="targets.filename"&gt;target.db&lt;/xsl:param&gt;
-</programlisting> 
-</refsynopsisdiv> 
-<refsection><info><title>Description</title></info>
- 
-<para>
-In order to resolve olinks efficiently, the stylesheets can
-generate an external data file containing information about
-all potential cross reference endpoints in a document.
-This parameter lets you change the name of the generated
-file from the default name <filename>target.db</filename>.
-The name must agree with that used in the target database
-used to resolve olinks during processing.
-See also <parameter>target.database.document</parameter>.
-</para> 
-</refsection> 
-</refentry>
-
-<refentry version="5.0" id="olink.base.uri"> 
-<refmeta> 
-<refentrytitle>olink.base.uri</refentrytitle> 
-<refmiscinfo class="other" otherclass="datatype">uri</refmiscinfo> 
-</refmeta> 
-<refnamediv> 
-<refname>olink.base.uri</refname> 
-<refpurpose>Base URI used in olink hrefs</refpurpose> 
-</refnamediv> 
-<refsynopsisdiv> <programlisting id="olink.base.uri.frag">
-&lt;xsl:param name="olink.base.uri"&gt;&lt;/xsl:param&gt;
-</programlisting> 
-</refsynopsisdiv> 
-<refsection><info><title>Description</title></info> 
- 
-<para>When cross reference data is collected for resolving olinks, it
-may be necessary to prepend a base URI to each target's href. This
-parameter lets you set that base URI when cross reference data is
-collected. This feature is needed when you want to link to a document
-that is processed without chunking. The output filename for such a
-document is not known to the XSL stylesheet; the only target
-information consists of fragment identifiers such as
-<literal>#idref</literal>. To enable the resolution of olinks between
-documents, you should pass the name of the HTML output file as the
-value of this parameter. Then the hrefs recorded in the cross
-reference data collection look like
-<literal>outfile.html#idref</literal>, which can be reached as links
-from other documents.</para>
-</refsection> 
-</refentry>
-
-<refentry version="5.0" id="use.local.olink.style"> 
-<refmeta> 
-<refentrytitle>use.local.olink.style</refentrytitle> 
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo> 
-</refmeta> 
-<refnamediv> 
-<refname>use.local.olink.style</refname> 
-<refpurpose>Process olinks using xref style of current
-document</refpurpose> 
-</refnamediv> 
-<refsynopsisdiv> <programlisting id="use.local.olink.style.frag">
-&lt;xsl:param name="use.local.olink.style" select="0"&gt;&lt;/xsl:param&gt; </programlisting> 
-</refsynopsisdiv> 
-<refsection><info><title>Description</title></info> 
- 
-<para>When cross reference data is collected for use by olinks, the data for each potential target includes one field containing a completely assembled cross reference string, as if it were an xref generated in that document. Other fields record the separate title, number, and element name of each target. When an olink is formed to a target from another document, the olink resolves to that preassembled string by default. If the <parameter>use.local.olink.style</parameter> parameter is set to non-zero, then instead the cross
-reference string is formed again from the target title, number, and
-element name, using the stylesheet processing the targeting document.
-Then olinks will match the xref style in the targeting document
-rather than in the target document. If  both documents are processed
-with the same stylesheet, then the results will be the same.</para> 
-</refsection> 
-</refentry>
-
-<refentry version="5.0" id="current.docid"> 
-<refmeta> 
-<refentrytitle>current.docid</refentrytitle> 
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo> 
-</refmeta> 
-<refnamediv> 
-<refname>current.docid</refname> 
-<refpurpose>targetdoc identifier for the document being
-processed</refpurpose> 
-</refnamediv> 
-<refsynopsisdiv> <programlisting id="current.docid.frag">
-&lt;xsl:param name="current.docid"&gt;&lt;/xsl:param&gt;
-</programlisting> 
-</refsynopsisdiv> 
-<refsection><info><title>Description</title></info> 
- 
-<para>When olinks between documents are resolved for HTML output, the stylesheet can compute the relative path between the current document and the target document. The stylesheet needs to know the <literal>targetdoc</literal> identifiers for both documents, as they appear in the <parameter>target.database.document</parameter> database file. This parameter passes to the stylesheet
-the targetdoc identifier of the current document, since that
-identifier does not appear in the document itself. </para>
-<para>This parameter can also be used for print output. If an olink's  <literal>targetdoc</literal>  id differs from the <literal>current.docid</literal>, then the stylesheet can append the target document's title to the generated olink text. That identifies to the reader that the link is to a different document, not the current document. See also <parameter>olink.doctitle</parameter> to enable that feature.</para> 
-</refsection> 
-</refentry>
-
-<refentry version="5.0" id="olink.doctitle"> 
-<refmeta> 
-<refentrytitle>olink.doctitle</refentrytitle> 
-<refmiscinfo class="other" otherclass="datatype">list</refmiscinfo> 
-<refmiscinfo class="other" otherclass="value">no</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">yes</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">maybe</refmiscinfo>
-</refmeta> 
-<refnamediv> 
-<refname>olink.doctitle</refname> 
-<refpurpose>show the document title for external olinks?</refpurpose>
-
-</refnamediv> 
-<refsynopsisdiv> <programlisting id="olink.doctitle.frag">
-&lt;xsl:param name="olink.doctitle"&gt;no&lt;/xsl:param&gt; 
-</programlisting> 
-</refsynopsisdiv> 
-<refsection><info><title>Description</title></info> 
- 
-<para>When olinks between documents are resolved, the generated text
-may not make it clear that the reference is to another document.
-It is possible for the stylesheets to append the other document's
-title to external olinks. For this to happen, two parameters must
-be set.</para>
-<itemizedlist>
-<listitem>
-<para>This <parameter>olink.doctitle</parameter> parameter
-should be set to either <literal>yes</literal> or <literal>maybe</literal>
-to enable this feature.
-</para>
-</listitem>
-<listitem>
-<para>And you should also set the <parameter>current.docid</parameter>
-parameter to the document id for the  document currently
-being processed for output.
-</para>
-</listitem>
-</itemizedlist>
-
-<para>
-Then if an olink's  <literal>targetdoc</literal> id differs from
-the <literal>current.docid</literal> value, the stylesheet knows
-that it is a reference to another document and can
-append the target document's
-title to the generated olink text. </para> 
-
-<para>The text for the target document's title is copied from the
-olink database from the <tag>ttl</tag> element
-of the top-level <tag>div</tag> for that document.
-If that <tag>ttl</tag> element is missing or empty,
-no title is output.
-</para>
-
-<para>The supported values for <parameter>olink.doctitle</parameter> are:
-</para>
-<variablelist>
-<varlistentry>
-<term><literal>yes</literal></term>
-<listitem>
-<para>
-Always insert the title to the target document if it is not
-the current document.
-</para>
-</listitem>
-</varlistentry>
-<varlistentry>
-<term><literal>no</literal></term>
-<listitem>
-<para>
-Never insert the title to the target document, even if requested
-in an <tag class="attribute">xrefstyle</tag> attribute.
-</para>
-</listitem>
-</varlistentry>
-<varlistentry>
-<term><literal>maybe</literal></term>
-<listitem>
-<para>
-Only insert the title to the target document, if requested
-in an <tag class="attribute">xrefstyle</tag> attribute.
-</para>
-</listitem>
-</varlistentry>
-</variablelist>
-<para>An <tag class="attribute">xrefstyle</tag> attribute
-may override the global setting for individual olinks.
-The following values are supported in an
-<tag class="attribute">xrefstyle</tag>
-attribute using the <literal>select:</literal> syntax:
-</para>
-
-<variablelist>
-<varlistentry>
-<term><literal>docname</literal></term>
-<listitem>
-<para>
-Insert the target document name for this olink using the
-<literal>docname</literal> gentext template, but only
-if the value of <parameter>olink.doctitle</parameter>
-is not <literal>no</literal>.
-</para>
-</listitem>
-</varlistentry>
-<varlistentry>
-<term><literal>docnamelong</literal></term>
-<listitem>
-<para>
-Insert the target document name for this olink using the
-<literal>docnamelong</literal> gentext template, but only
-if the value of <parameter>olink.doctitle</parameter>
-is not <literal>no</literal>.
-</para>
-</listitem>
-</varlistentry>
-<varlistentry>
-<term><literal>nodocname</literal></term>
-<listitem>
-<para>
-Omit the target document name even if
-the value of <parameter>olink.doctitle</parameter>
-is <literal>yes</literal>.
-</para>
-</listitem>
-</varlistentry>
-</variablelist>
-<para>Another way of inserting the target document name 
-for a single olink is to employ an
-<tag class="attribute">xrefstyle</tag>
-attribute using the <literal>template:</literal> syntax.
-The <literal>%o</literal> placeholder (the letter o, not zero)
-in such a template
-will be filled in with the target document's title when it is processed.
-This will occur regardless of 
-the value of <parameter>olink.doctitle</parameter>.
-</para>
-<para>Note that prior to version 1.66 of the XSL stylesheets,
-the allowed values for this parameter were 0 and 1.  Those
-values are still supported and mapped to 'no' and 'yes', respectively.
-</para>
-</refsection> 
-</refentry>
-
-<refentry version="5.0" id="activate.external.olinks">
-<refmeta>
-<refentrytitle>activate.external.olinks</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>activate.external.olinks</refname>
-<refpurpose>Make external olinks into active links</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="activate.external.olinks.frag">
-&lt;xsl:param name="activate.external.olinks" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If <parameter>activate.external.olinks</parameter> is nonzero
-(the default), then any olinks that reference another document
-become active links that can be clicked on to follow the link.
-If the parameter is set to zero, then external olinks
-will have the appropriate link text generated, but the link is
-not made active.  Olinks to destinations in
-the current document remain active.</para>
-
-<para>To make an external olink active for HTML
-outputs, the link text is wrapped in an <tag>a</tag>
-element with an <tag>href</tag> attribute. To
-make an external olink active for FO outputs, the link text is
-wrapped in an <tag>fo:basic-link</tag> element with an
-<tag>external-destination</tag> attribute.</para>
-
-<para>This parameter is useful when you need external olinks
-to resolve but not be clickable. For example, if documents
-in a collection are available independently of each other,
-then having active links between them could lead to
-unresolved links when a given target document is missing.</para>
-
-<para>The epub stylesheets set this parameter to zero by default
-because there is no standard linking mechanism between Epub documents.</para>
-
-<para>If external links are made inactive, you should
-consider setting the
-stylesheet parameter <parameter>olink.doctitle</parameter>
-to <literal>yes</literal>. That will append the external document's
-title to the link text, making it easier for the user to
-locate the other document.</para>
-
-<para>An olink is considered external when the
-<parameter>current.docid</parameter> stylesheet parameter
-is set to some value, and the olink's <tag>targetdoc</tag>
-attribute has a different value. If the two values
-match, then the link is considered internal.  If the
-<parameter>current.docid</parameter> parameter is blank, or
-the <tag>olink</tag> element does not have a <tag>targetdoc</tag> attribute,
-then the link is considered to be internal and will become
-an active link.</para>
-
-<para>See also <parameter>olink.doctitle</parameter>,
-<parameter>prefer.internal.olink</parameter>.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="olink.debug">
-<refmeta>
-<refentrytitle>olink.debug</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>olink.debug</refname>
-<refpurpose>Turn on debugging messages for olinks</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="olink.debug.frag">
-&lt;xsl:param name="olink.debug" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, then each olink will generate several
-messages about how it is being resolved during processing.
-This is useful when an olink does not resolve properly
-and the standard error messages are not sufficient to
-find the problem. 
-</para>
-
-<para>You may need to read through the olink XSL templates
-to understand the context for some of the debug messages.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="olink.properties">
-<refmeta>
-<refentrytitle>olink.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>olink.properties</refname>
-<refpurpose>Properties associated with the cross-reference 
-text of an olink.</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="olink.properties.frag">
-&lt;xsl:attribute-set name="olink.properties"&gt;
-  &lt;xsl:attribute name="show-destination"&gt;replace&lt;/xsl:attribute&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This <literal>attribute set</literal> is applied to the
-<literal>fo:basic-link</literal> element of an olink. It is not applied to the
-optional page number or optional title of the external
-document.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="olink.lang.fallback.sequence"> 
-<refmeta> 
-<refentrytitle>olink.lang.fallback.sequence</refentrytitle> 
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo> 
-</refmeta> 
-<refnamediv> 
-<refname>olink.lang.fallback.sequence</refname> 
-<refpurpose>look up translated documents if olink not found?</refpurpose>
-
-</refnamediv> 
-<refsynopsisdiv> <programlisting id="olink.lang.fallback.sequence.frag">
-&lt;xsl:param name="olink.lang.fallback.sequence"&gt;&lt;/xsl:param&gt;
-</programlisting> 
-</refsynopsisdiv> 
-<refsection><info><title>Description</title></info> 
- 
-
-<para>This parameter defines a list of lang values
-to search among to resolve olinks.
-</para>
-
-<para>Normally an olink tries to resolve to a document in the same
-language as the olink itself.  The language of an olink
-is determined by its nearest ancestor element with a
-<tag class="attribute">lang</tag> attribute, otherwise the
-value of the <parameter>l10n.gentext.default.lang</parameter>
-parameter.
-</para>
-
-<para>An olink database can contain target data for the same
-document in multiple languages.  Each set of data has the
-same value for the <tag>targetdoc</tag> attribute in
-the <tag>document</tag> element in the database, but with a 
-different <tag>lang</tag> attribute value.
-</para>
-
-<para>When an olink is being resolved, the target is first
-sought in the document with the same language as the olink.
-If no match is found there, then this parameter is consulted
-for additional languages to try.</para>
-
-<para>The <parameter>olink.lang.fallback.sequence</parameter>
-must be a whitespace separated list of lang values to
-try.  The first one with a match in the olink database is used.
-The default value is empty.</para>
-
-<para>For example, a document might be written in German
-and contain an olink with
-<literal>targetdoc="adminguide"</literal>.
-When the document is processed, the processor
-first looks for a target dataset in the
-olink database starting with:</para>
-
-<literallayout><literal>&lt;document targetdoc="adminguide" lang="de"&gt;</literal>.
-</literallayout>
-
-<para>If there is no such element, then the
-<parameter>olink.lang.fallback.sequence</parameter> 
-parameter is consulted.
-If its value is, for example, <quote>fr en</quote>, then the processor next
-looks for <literal>targetdoc="adminguide" lang="fr"</literal>, and
-then for <literal>targetdoc="adminguide" lang="en"</literal>.
-If there is still no match, it looks for
-<literal>targetdoc="adminguide"</literal> with no
-lang attribute.
-</para>
-
-<para>This parameter is useful when a set of documents is only
-partially translated, or is in the process of being translated.  
-If a target of an olink has not yet been translated, then this
-parameter permits the processor to look for the document in
-other languages.  This assumes the reader would rather have
-a link to a document in a different language than to have
-a broken link.
-</para>
-
-</refsection> 
-</refentry>
-
-<refentry version="5.0" id="insert.olink.page.number">
-<refmeta>
-<refentrytitle>insert.olink.page.number</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">list</refmiscinfo> 
-<refmiscinfo class="other" otherclass="value">no</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">yes</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">maybe</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>insert.olink.page.number</refname>
-<refpurpose>Turns page numbers in olinks on and off</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="insert.olink.page.number.frag">
-&lt;xsl:param name="insert.olink.page.number"&gt;no&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The value of this parameter determines if
-cross references made between documents with
-<tag>olink</tag> will 
-include page number citations.
-In most cases this is only applicable to references in printed output.
-</para>
-<para>The parameter has three possible values.
-</para>
-<variablelist>
-<varlistentry>
-<term>no</term>
-<listitem><para>No page number references will be generated for olinks.
-</para></listitem>
-</varlistentry>
-<varlistentry>
-<term>yes</term>
-<listitem><para>Page number references will be generated
-for all <tag>olink</tag> references.
-The style of page reference may be changed
-if an <tag class="attribute">xrefstyle</tag>
-attribute is used.
-</para></listitem>
-</varlistentry>
-<varlistentry>
-<term>maybe</term>
-<listitem><para>Page number references will not be generated
-for an <tag>olink</tag> element unless 
-it has an
-<tag class="attribute">xrefstyle</tag>
-attribute whose value specifies a page reference.
-</para></listitem>
-</varlistentry>
-</variablelist>
-<para>Olinks that point to targets within the same document
-are treated as <tag>xref</tag>s, and controlled by
-the <parameter>insert.xref.page.number</parameter> parameter.
-</para>
-
-<para>Page number references for olinks to
-external documents can only be inserted if the 
-information exists in the olink database. 
-This means each olink target element 
-(<tag>div</tag> or <tag>obj</tag>)
-must have a <tag class="attribute">page</tag> attribute
-whose value is its page number in the target document.
-The XSL stylesheets are not able to extract that information
-during processing because pages have not yet been created in
-XSLT transformation.  Only the XSL-FO processor knows what
-page each element is placed on.
-Therefore some postprocessing must take place to populate
-page numbers in the olink database.
-</para>
-
-
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="insert.olink.pdf.frag">
-<refmeta>
-<refentrytitle>insert.olink.pdf.frag</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>insert.olink.pdf.frag</refname>
-<refpurpose>Add fragment identifiers for links into PDF files</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="insert.olink.pdf.frag.frag">
-&lt;xsl:param name="insert.olink.pdf.frag" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The value of this parameter determines whether
-the cross reference URIs to PDF documents made with
-<tag>olink</tag> will 
-include fragment identifiers.
-</para>
-
-<para>When forming a URI to link to a PDF document,
-a fragment identifier (typically a '#' followed by an
-id value) appended to the PDF filename can be used by
-the PDF viewer to open
-the PDF file to a location within the document instead of
-the first page.
-However, not all PDF files have id
-values embedded in them, and not all PDF viewers can
-handle fragment identifiers. 
-</para>
-
-<para>If <parameter>insert.olink.pdf.frag</parameter> is set
-to a non-zero value, then any olink targeting a
-PDF file will have the fragment identifier appended to the URI.
-The URI is formed by concatenating the value of the
-<parameter>olink.base.uri</parameter> parameter, the
-value of the <tag class="attribute">baseuri</tag>
-attribute from the <tag class="element">document</tag>
-element in the olink database with the matching
-<tag class="attribute">targetdoc</tag> value,
-and the value of the <tag class="attribute">href</tag>
-attribute for the targeted element in the olink database.
-The <tag class="attribute">href</tag> attribute
-contains the fragment identifier.
-</para>
-
-<para>If <parameter>insert.olink.pdf.frag</parameter> is set
-to zero (the default value), then 
-the <tag class="attribute">href</tag> attribute
-from the olink database
-is not appended to PDF olinks, so the fragment identifier is left off.
-A PDF olink is any olink for which the
-<tag class="attribute">baseuri</tag> attribute
-from the matching <tag class="element">document</tag>
-element in the olink database ends with '.pdf'.
-Any other olinks will still have the fragment identifier added.
-</para>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="prefer.internal.olink">
-<refmeta>
-<refentrytitle>prefer.internal.olink</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>prefer.internal.olink</refname>
-<refpurpose>Prefer a local olink reference to an external reference</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="prefer.internal.olink.frag">
-&lt;xsl:param name="prefer.internal.olink" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If you are re-using XML content modules in multiple documents,
-you may want to redirect some of your olinks.  This parameter
-permits you to redirect an olink to the current document.
-</para>
-
-<para>For example: you are writing documentation for a  product, 
-which includes 3 manuals: a little installation
-booklet (booklet.xml), a user 
-guide (user.xml), and a reference manual (reference.xml).
-All 3 documents begin with the same introduction section (intro.xml) that 
-contains a reference to the customization section (custom.xml) which is 
-included in both user.xml and reference.xml documents.
-</para>
-
-<para>How do you write the link to custom.xml in intro.xml
-so that it is interpreted correctly in all 3 documents?</para>
-<itemizedlist>
-<listitem><para>If you use xref, it will fail in user.xml.</para>
-</listitem>
-<listitem><para>If you use olink (pointing to reference.xml),
-the reference in user.xml  
-will point to the customization section of the reference manual, while it is 
-actually available in user.xml.</para>
-</listitem>
-</itemizedlist>
-
-<para>If you set the <parameter>prefer.internal.olink</parameter>
-parameter to a non-zero value, then the processor will
-first look in the olink database
-for the olink's <tag>targetptr</tag> attribute value
-in document matching the <parameter>current.docid</parameter>
-parameter value.  If it isn't found there, then
-it tries the document in the database
-with the <tag>targetdoc</tag>
-value that matches the olink's <tag>targetdoc</tag>
-attribute.
-</para>
-
-<para>This feature permits an olink reference to resolve to
-the current document if there is an element
-with an id matching the olink's <tag>targetptr</tag>
-value.  The current document's olink data must be
-included in the target database for this to work.</para>
-
-<caution>
-<para>There is a potential for incorrect links if
-the same <tag>id</tag> attribute value is used for different
-content in different documents.
-Some of your olinks may be redirected to the current document
-when they shouldn't be.  It is not possible to control
-individual olink instances.</para>
-</caution>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="link.mailto.url">
-<refmeta>
-<refentrytitle>link.mailto.url</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>link.mailto.url</refname>
-<refpurpose>Mailto URL for the LINK REL=made HTML HEAD element</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="link.mailto.url.frag">
-&lt;xsl:param name="link.mailto.url"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If not the empty string, this address will be used for the
-rel=made <literal>link</literal> element in the html <literal>head</literal>
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="ulink.target">
-<refmeta>
-<refentrytitle>ulink.target</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>ulink.target</refname>
-<refpurpose>The HTML anchor target for ULinks</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="ulink.target.frag">
-&lt;xsl:param name="ulink.target"&gt;_top&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If <parameter>ulink.target</parameter> is non-zero, its value will
-be used for the <literal>target</literal> attribute
-on anchors generated for <tag>ulink</tag>s.</para>
-
-</refsection>
-</refentry>
-
-</reference><reference id="xrefs" xml:base="../html/param.xml"><title>Cross References</title>
-<refentry version="5.0" id="collect.xref.targets"> 
-<refmeta> 
-<refentrytitle>collect.xref.targets</refentrytitle> 
-<refmiscinfo class="other" otherclass="datatype">list</refmiscinfo> 
-<refmiscinfo class="other" otherclass="value">no</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">yes</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">only</refmiscinfo>
-</refmeta> 
-<refnamediv> 
-<refname>collect.xref.targets</refname> 
-<refpurpose>Controls whether cross reference data is
-collected</refpurpose> 
-</refnamediv> 
-<refsynopsisdiv> <programlisting id="collect.xref.targets.frag">
-&lt;xsl:param name="collect.xref.targets"&gt;no&lt;/xsl:param&gt;
-</programlisting> 
-</refsynopsisdiv> 
-<refsection><info><title>Description</title></info> 
- 
-<para>
-In order to resolve olinks efficiently, the stylesheets can
-generate an external data file containing information about
-all potential cross reference endpoints in a document.
-This parameter determines whether the collection process is run when the document is processed by the stylesheet. The default value is  <literal>no</literal>, which means the data file is not generated during processing. The other choices are <literal>yes</literal>, which means the data file is created and the document is processed for output, and <literal>only</literal>, which means the data file is created but the document is not processed for output.
-See also <parameter>targets.filename</parameter>.
-</para> 
-</refsection> 
-</refentry>
-
-<refentry version="5.0" id="insert.xref.page.number">
-<refmeta>
-<refentrytitle>insert.xref.page.number</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">list</refmiscinfo> 
-<refmiscinfo class="other" otherclass="value">no</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">yes</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">maybe</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>insert.xref.page.number</refname>
-<refpurpose>Turns page numbers in xrefs on and off</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="insert.xref.page.number.frag">
-&lt;xsl:param name="insert.xref.page.number"&gt;no&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The value of this parameter determines if
-cross references (<tag>xref</tag>s) in
-printed output will
-include page number citations.
-It has three possible values.
-</para>
-<variablelist>
-<varlistentry>
-<term>no</term>
-<listitem><para>No page number references will be generated.
-</para></listitem>
-</varlistentry>
-<varlistentry>
-<term>yes</term>
-<listitem><para>Page number references will be generated
-for all <tag>xref</tag> elements.
-The style of page reference may be changed
-if an <tag class="attribute">xrefstyle</tag>
-attribute is used.
-</para></listitem>
-</varlistentry>
-<varlistentry>
-<term>maybe</term>
-<listitem><para>Page number references will not be generated
-for an <tag>xref</tag> element unless 
-it has an
-<tag class="attribute">xrefstyle</tag>
-attribute whose value specifies a page reference.
-</para></listitem>
-</varlistentry>
-</variablelist>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="use.role.as.xrefstyle">
-<refmeta>
-<refentrytitle>use.role.as.xrefstyle</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>use.role.as.xrefstyle</refname>
-<refpurpose>Use <tag class="attribute">role</tag> attribute for
-<tag class="attribute">xrefstyle</tag> on <tag>xref</tag>?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="use.role.as.xrefstyle.frag">
-&lt;xsl:param name="use.role.as.xrefstyle" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>In DocBook documents that conform to a schema older than V4.3, this parameter allows 
-<tag class="attribute">role</tag> to serve the purpose of specifying the cross reference style.</para>
-
-<para>If non-zero, the <tag class="attribute">role</tag> attribute on
-<tag>xref</tag> will be used to select the cross reference style.
-In DocBook V4.3, the <tag class="attribute">xrefstyle</tag> attribute was added for this purpose.
-If the <tag class="attribute">xrefstyle</tag> attribute is present, 
-<tag class="attribute">role</tag> will be ignored, regardless of the setting
-of this parameter.</para>
-
-</refsection>
-
-<refsection><info><title>Example</title></info>
-
-<para>The following small stylesheet shows how to configure the
-stylesheets to make use of the cross reference style:</para>
-
-<programlisting>&lt;?xml version="1.0"?&gt;
-&lt;xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
-                version="1.0"&gt;
-
-&lt;xsl:import href="../xsl/html/docbook.xsl"/&gt;
-
-&lt;xsl:output method="html"/&gt;
-
-&lt;xsl:param name="local.l10n.xml" select="document('')"/&gt;
-&lt;l:i18n xmlns:l="http://docbook.sourceforge.net/xmlns/l10n/1.0"&gt;
-  &lt;l:l10n xmlns:l="http://docbook.sourceforge.net/xmlns/l10n/1.0" language="en"&gt;
-   &lt;l:context name="xref"&gt;
-      &lt;l:template name="chapter" style="title" text="Chapter %n, %t"/&gt;
-      &lt;l:template name="chapter" text="Chapter %n"/&gt;
-    &lt;/l:context&gt;
-  &lt;/l:l10n&gt;
-&lt;/l:i18n&gt;
-
-&lt;/xsl:stylesheet&gt;</programlisting>
-
-<para>With this stylesheet, the cross references in the following document:</para>
-
-<programlisting>&lt;?xml version="1.0" encoding="utf-8"?&gt;
-&lt;!DOCTYPE book PUBLIC "-//OASIS//DTD DocBook XML V4.2//EN"
-                  "http://www.oasis-open.org/docbook/xml/4.2/docbookx.dtd"&gt;
-&lt;book id="book"&gt;&lt;title&gt;Book&lt;/title&gt;
-
-&lt;preface&gt;
-&lt;title&gt;Preface&lt;/title&gt;
-
-&lt;para&gt;Normal: &lt;xref linkend="ch1"/&gt;.&lt;/para&gt;
-&lt;para&gt;Title: &lt;xref xrefstyle="title" linkend="ch1"/&gt;.&lt;/para&gt;
-
-&lt;/preface&gt;
-
-&lt;chapter id="ch1"&gt;
-&lt;title&gt;First Chapter&lt;/title&gt;
-
-&lt;para&gt;Irrelevant.&lt;/para&gt;
-
-&lt;/chapter&gt;
-&lt;/book&gt;</programlisting>
-
-<para>will appear as:</para>
-
-<informalexample>
-<para>Normal: Chapter 1.</para>
-<para>Title: Chapter 1, <emphasis>First Chapter</emphasis>.</para>
-</informalexample>
-</refsection>
-
-</refentry>
-
-<refentry version="5.0" id="xref.with.number.and.title">
-<refmeta>
-<refentrytitle>xref.with.number.and.title</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>xref.with.number.and.title</refname>
-<refpurpose>Use number and title in cross references</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="xref.with.number.and.title.frag">
-&lt;xsl:param name="xref.with.number.and.title" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>A cross reference may include the number (for example, the number of
-an example or figure) and the <tag>title</tag> which is a required child of some
-targets. This parameter inserts both the relevant number as well as
-the title into the link. </para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="xref.label-page.separator">
-<refmeta>
-<refentrytitle>xref.label-page.separator</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>xref.label-page.separator</refname>
-<refpurpose>Punctuation or space separating label from page number in xref</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="xref.label-page.separator.frag">&lt;xsl:param name="xref.label-page.separator"&gt;&lt;xsl:text&gt; &lt;/xsl:text&gt;&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>
-This parameter allows you to control the punctuation of certain
-types of generated cross reference text.
-When cross reference text is generated for an 
-<tag class="element">xref</tag> or 
-<tag class="element">olink</tag> element
-using an <tag class="attribute">xrefstyle</tag> attribute
-that makes use of the <literal>select:</literal> feature,
-and the selected components include both label and page
-but no title,
-then the value of this parameter is inserted between
-label and page number in the output.  
-If a title is included, then other separators are used.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="xref.label-title.separator">
-<refmeta>
-<refentrytitle>xref.label-title.separator</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>xref.label-title.separator</refname>
-<refpurpose>Punctuation or space separating label from title in xref</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="xref.label-title.separator.frag">&lt;xsl:param name="xref.label-title.separator"&gt;: &lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>
-This parameter allows you to control the punctuation of certain
-types of generated cross reference text.
-When cross reference text is generated for an 
-<tag class="element">xref</tag> or 
-<tag class="element">olink</tag> element
-using an <tag class="attribute">xrefstyle</tag> attribute
-that makes use of the <literal>select:</literal> feature,
-and the selected components include both label and title,
-then the value of this parameter is inserted between
-label and title in the output.  
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="xref.title-page.separator">
-<refmeta>
-<refentrytitle>xref.title-page.separator</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>xref.title-page.separator</refname>
-<refpurpose>Punctuation or space separating title from page number in xref</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="xref.title-page.separator.frag">&lt;xsl:param name="xref.title-page.separator"&gt;&lt;xsl:text&gt; &lt;/xsl:text&gt;&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>
-This parameter allows you to control the punctuation of certain
-types of generated cross reference text.
-When cross reference text is generated for an 
-<tag class="element">xref</tag> or 
-<tag class="element">olink</tag> element
-using an <tag class="attribute">xrefstyle</tag> attribute
-that makes use of the <literal>select:</literal> feature,
-and the selected components include both title and page number,
-then the value of this parameter is inserted between
-title and page number in the output.  
-</para>
-
-</refsection>
-</refentry>
-
-</reference><reference id="lists" xml:base="../html/param.xml"><title>Lists</title>
-<refentry version="5.0" id="segmentedlist.as.table">
-<refmeta>
-<refentrytitle>segmentedlist.as.table</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>segmentedlist.as.table</refname>
-<refpurpose>Format segmented lists as tables?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="segmentedlist.as.table.frag">
-&lt;xsl:param name="segmentedlist.as.table" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, <tag>segmentedlist</tag>s will be formatted as
-tables.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="variablelist.as.table">
-<refmeta>
-<refentrytitle>variablelist.as.table</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>variablelist.as.table</refname>
-<refpurpose>Format <tag>variablelist</tag>s as tables?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="variablelist.as.table.frag">
-&lt;xsl:param name="variablelist.as.table" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, <tag>variablelist</tag>s will be formatted as
-tables. A processing instruction exists to specify a particular width for the 
-column containing the <tag>term</tag>s:   
-<tag class="xmlpi">dbhtml term-width=".25in"</tag></para>
-
-<para>You can override this setting with a processing instruction as the
-child of <tag>variablelist</tag>: <tag class="xmlpi">dbhtml
-list-presentation="table"</tag> or <tag class="xmlpi">dbhtml
-list-presentation="list"</tag>.</para>
-
-<para>This parameter only applies to the HTML transformations. In the
-FO case, proper list markup is robust enough to handle the formatting.
-But see also <parameter>variablelist.as.blocks</parameter>.</para>
-
-<programlisting>  &lt;variablelist&gt;
-        &lt;?dbhtml list-presentation="table"?&gt;
-        &lt;?dbhtml term-width="1.5in"?&gt;
-        &lt;?dbfo list-presentation="list"?&gt;
-        &lt;?dbfo term-width="1in"?&gt;
-        &lt;varlistentry&gt;
-          &lt;term&gt;list&lt;/term&gt;
-          &lt;listitem&gt;
-                &lt;para&gt;
-                  Formatted as a table even if variablelist.as.table is set to 0.
-                &lt;/para&gt;
-          &lt;/listitem&gt;
-        &lt;/varlistentry&gt;
-  &lt;/variablelist&gt;</programlisting>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="variablelist.term.separator">
-<refmeta>
-<refentrytitle>variablelist.term.separator</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>variablelist.term.separator</refname>
-<refpurpose>Text to separate <tag>term</tag>s within a multi-term
-<tag>varlistentry</tag></refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="variablelist.term.separator.frag">
-&lt;xsl:param name="variablelist.term.separator"&gt;, &lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>When a <tag>varlistentry</tag> contains multiple <tag>term</tag>
-elements, the string specified in the value of the
-<parameter>variablelist.term.separator</parameter> parameter is placed
-after each <tag>term</tag> except the last.</para>
-
-<note>
-  <para>To generate a line break between multiple <tag>term</tag>s in
-  a <tag>varlistentry</tag>, set a non-zero value for the
-  <parameter>variablelist.term.break.after</parameter> parameter. If
-  you do so, you may also want to set the value of the
-  <parameter>variablelist.term.separator</parameter> parameter to an
-  empty string (to suppress rendering of the default comma and space
-  after each <tag>term</tag>).</para>
-</note>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="variablelist.term.break.after">
-<refmeta>
-<refentrytitle>variablelist.term.break.after</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>variablelist.term.break.after</refname>
-<refpurpose>Generate line break after each <tag>term</tag> within a
-multi-term <tag>varlistentry</tag>?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="variablelist.term.break.after.frag">
-&lt;xsl:param name="variablelist.term.break.after"&gt;0&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Set a non-zero value for the
-<parameter>variablelist.term.break.after</parameter> parameter to
-generate a line break between <tag>term</tag>s in a
-multi-term <tag>varlistentry</tag>.</para>
-
-<note>
-<para>If you set a non-zero value for
-<parameter>variablelist.term.break.after</parameter>, you may also
-want to set the value of the
-<parameter>variablelist.term.separator</parameter> parameter to an
-empty string (to suppress rendering of the default comma and space
-after each <tag>term</tag>).</para>
-</note>
-
-</refsection>
-</refentry>
-
-</reference><reference id="biblio" xml:base="../html/param.xml"><title>Bibliography</title>
-<refentry version="5.0" id="bibliography.style">
-<refmeta>
-<refentrytitle>bibliography.style</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">list</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">normal</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">iso690</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>bibliography.style</refname>
-<refpurpose>Style used for formatting of biblioentries.</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="bibliography.style.frag">
-&lt;xsl:param name="bibliography.style"&gt;normal&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Currently only <literal>normal</literal> and
-<literal>iso690</literal> styles are supported.</para>
-
-<para>In order to use ISO690 style to the full extent you might need
-to use additional markup described on <link xlink:href="http://wiki.docbook.org/topic/ISO690Bibliography">the
-following WiKi page</link>.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="biblioentry.item.separator">
-<refmeta>
-<refentrytitle>biblioentry.item.separator</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>biblioentry.item.separator</refname>
-<refpurpose>Text to separate bibliography entries</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="biblioentry.item.separator.frag">&lt;xsl:param name="biblioentry.item.separator"&gt;. &lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Text to separate bibliography entries
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="bibliography.collection">
-<refmeta>
-<refentrytitle>bibliography.collection</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>bibliography.collection</refname>
-<refpurpose>Name of the bibliography collection file</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="bibliography.collection.frag">
-&lt;xsl:param name="bibliography.collection"&gt;http://docbook.sourceforge.net/release/bibliography/bibliography.xml&lt;/xsl:param&gt;
-
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Maintaining bibliography entries across a set of documents is tedious, time
-consuming, and error prone. It makes much more sense, usually, to store all of
-the bibliography entries in a single place and simply <quote>extract</quote>
-the ones you need in each document.</para>
-
-<para>That's the purpose of the
-<parameter>bibliography.collection</parameter> parameter. To setup a global
-bibliography <quote>database</quote>, follow these steps:</para>
-
-<para>First, create a stand-alone bibliography document that contains all of
-the documents that you wish to reference. Make sure that each bibliography
-entry (whether you use <tag>biblioentry</tag> or <tag>bibliomixed</tag>)
-has an ID.</para>
-
-<para>My global bibliography, <filename>~/bibliography.xml</filename> begins
-like this:</para>
-
-<informalexample>
-<programlisting>&lt;!DOCTYPE bibliography
-  PUBLIC "-//OASIS//DTD DocBook XML V4.1.2//EN"
-  "http://www.oasis-open.org/docbook/xml/4.1.2/docbookx.dtd"&gt;
-&lt;bibliography&gt;&lt;title&gt;References&lt;/title&gt;
-
-&lt;bibliomixed id="xml-rec"&gt;&lt;abbrev&gt;XML 1.0&lt;/abbrev&gt;Tim Bray,
-Jean Paoli, C. M. Sperberg-McQueen, and Eve Maler, editors.
-&lt;citetitle&gt;&lt;ulink url="http://www.w3.org/TR/REC-xml"&gt;Extensible Markup
-Language (XML) 1.0 Second Edition&lt;/ulink&gt;&lt;/citetitle&gt;.
-World Wide Web Consortium, 2000.
-&lt;/bibliomixed&gt;
-
-&lt;bibliomixed id="xml-names"&gt;&lt;abbrev&gt;Namespaces&lt;/abbrev&gt;Tim Bray,
-Dave Hollander,
-and Andrew Layman, editors.
-&lt;citetitle&gt;&lt;ulink url="http://www.w3.org/TR/REC-xml-names/"&gt;Namespaces in
-XML&lt;/ulink&gt;&lt;/citetitle&gt;.
-World Wide Web Consortium, 1999.
-&lt;/bibliomixed&gt;
-
-&lt;!-- ... --&gt;
-&lt;/bibliography&gt;
-</programlisting>
-</informalexample>
-
-<para>When you create a bibliography in your document, simply
-provide <emphasis>empty</emphasis> <tag>bibliomixed</tag>
-entries for each document that you wish to cite. Make sure that these
-elements have the same ID as the corresponding <quote>real</quote>
-entry in your global bibliography.</para>
-
-<para>For example:</para>
-
-<informalexample>
-<programlisting>&lt;bibliography&gt;&lt;title&gt;Bibliography&lt;/title&gt;
-
-&lt;bibliomixed id="xml-rec"/&gt;
-&lt;bibliomixed id="xml-names"/&gt;
-&lt;bibliomixed id="DKnuth86"&gt;Donald E. Knuth. &lt;citetitle&gt;Computers and
-Typesetting: Volume B, TeX: The Program&lt;/citetitle&gt;. Addison-Wesley,
-1986.  ISBN 0-201-13437-3.
-&lt;/bibliomixed&gt;
-&lt;bibliomixed id="relaxng"/&gt;
-
-&lt;/bibliography&gt;</programlisting>
-</informalexample>
-
-<para>Note that it's perfectly acceptable to mix entries from your
-global bibliography with <quote>normal</quote> entries. You can use
-<tag>xref</tag> or other elements to cross-reference your
-bibliography entries in exactly the same way you do now.</para>
-
-<para>Finally, when you are ready to format your document, simply set the
-<parameter>bibliography.collection</parameter> parameter (in either a
-customization layer or directly through your processor's interface) to
-point to your global bibliography.</para>
-
-<para>A relative path in the parameter is interpreted in one
-of two ways:</para>
-<orderedlist numeration="loweralpha">
-  <listitem>
-    <para>If your document contains no links to empty bibliographic elements,
-    then the path is relative to the file containing
-    the first <tag>bibliomixed</tag> element in the document.</para>
-  </listitem>
-  <listitem>
-    <para>If your document does contain links to empty bibliographic elements,
-    then the path is relative to the file containing
-    the first such link element in the document.</para>
-  </listitem>
-</orderedlist>
-<para>Once the collection file is opened by the first instance described
-above, it stays open for the current document
-and the relative path is not reinterpreted again.</para>
-
-<para>The stylesheets will format the bibliography in your document as if
-all of the entries referenced appeared there literally.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="bibliography.numbered">
-<refmeta>
-<refentrytitle>bibliography.numbered</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>bibliography.numbered</refname>
-<refpurpose>Should bibliography entries be numbered?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="bibliography.numbered.frag">
-&lt;xsl:param name="bibliography.numbered" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero bibliography entries will be numbered</para>
-
-</refsection>
-</refentry>
-
-</reference><reference id="glossary" xml:base="../html/param.xml"><title>Glossary</title>
-<refentry version="5.0" id="glossterm.auto.link">
-<refmeta>
-<refentrytitle>glossterm.auto.link</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>glossterm.auto.link</refname>
-<refpurpose>Generate links from glossterm to glossentry automatically?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="glossterm.auto.link.frag">
-&lt;xsl:param name="glossterm.auto.link" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, links from inline <tag>glossterm</tag>s to the corresponding 
-<tag>glossentry</tag> elements in a <tag>glossary</tag> or <tag>glosslist</tag> 
-will be automatically generated. This is useful when your glossterms are consistent 
-and you don't want to add links manually.</para>
-
-<para>The automatic link generation feature is not used on <tag>glossterm</tag> elements
-that have a <tag class="attribute">linkend</tag> attribute.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="firstterm.only.link">
-<refmeta>
-<refentrytitle>firstterm.only.link</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>firstterm.only.link</refname>
-<refpurpose>Does automatic glossterm linking only apply to firstterms?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="firstterm.only.link.frag">
-&lt;xsl:param name="firstterm.only.link" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, only <tag>firstterm</tag>s will be automatically linked
-to the glossary. If glossary linking is not enabled, this parameter
-has no effect.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="glossary.collection">
-<refmeta>
-<refentrytitle>glossary.collection</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>glossary.collection</refname>
-<refpurpose>Name of the glossary collection file</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="glossary.collection.frag">
-&lt;xsl:param name="glossary.collection"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Glossaries maintained independently across a set of documents
-are likely to become inconsistent unless considerable effort is
-expended to keep them in sync. It makes much more sense, usually, to
-store all of the glossary entries in a single place and simply
-<quote>extract</quote> the ones you need in each document.</para>
-
-<para>That's the purpose of the
-<parameter>glossary.collection</parameter> parameter. To setup a global
-glossary <quote>database</quote>, follow these steps:</para>
-
-<refsection><info><title>Setting Up the Glossary Database</title></info>
-
-<para>First, create a stand-alone glossary document that contains all of
-the entries that you wish to reference. Make sure that each glossary
-entry has an ID.</para>
-
-<para>Here's an example glossary:</para>
-
-<informalexample>
-<programlisting>
-&lt;?xml version="1.0" encoding="utf-8"?&gt;
-&lt;!DOCTYPE glossary
-  PUBLIC "-//OASIS//DTD DocBook XML V4.1.2//EN"
-  "http://www.oasis-open.org/docbook/xml/4.1.2/docbookx.dtd"&gt;
-&lt;glossary&gt;
-&lt;glossaryinfo&gt;
-&lt;editor&gt;&lt;firstname&gt;Eric&lt;/firstname&gt;&lt;surname&gt;Raymond&lt;/surname&gt;&lt;/editor&gt;
-&lt;title&gt;Jargon File 4.2.3 (abridged)&lt;/title&gt;
-&lt;releaseinfo&gt;Just some test data&lt;/releaseinfo&gt;
-&lt;/glossaryinfo&gt;
-
-&lt;glossdiv&gt;&lt;title&gt;0&lt;/title&gt;
-
-&lt;glossentry&gt;
-&lt;glossterm&gt;0&lt;/glossterm&gt;
-&lt;glossdef&gt;
-&lt;para&gt;Numeric zero, as opposed to the letter `O' (the 15th letter of
-the English alphabet). In their unmodified forms they look a lot
-alike, and various kluges invented to make them visually distinct have
-compounded the confusion. If your zero is center-dotted and letter-O
-is not, or if letter-O looks almost rectangular but zero looks more
-like an American football stood on end (or the reverse), you're
-probably looking at a modern character display (though the dotted zero
-seems to have originated as an option on IBM 3270 controllers). If
-your zero is slashed but letter-O is not, you're probably looking at
-an old-style ASCII graphic set descended from the default typewheel on
-the venerable ASR-33 Teletype (Scandinavians, for whom /O is a letter,
-curse this arrangement). (Interestingly, the slashed zero long
-predates computers; Florian Cajori's monumental "A History of
-Mathematical Notations" notes that it was used in the twelfth and
-thirteenth centuries.) If letter-O has a slash across it and the zero
-does not, your display is tuned for a very old convention used at IBM
-and a few other early mainframe makers (Scandinavians curse &lt;emphasis&gt;this&lt;/emphasis&gt;
-arrangement even more, because it means two of their letters collide).
-Some Burroughs/Unisys equipment displays a zero with a &lt;emphasis&gt;reversed&lt;/emphasis&gt;
-slash. Old CDC computers rendered letter O as an unbroken oval and 0
-as an oval broken at upper right and lower left. And yet another
-convention common on early line printers left zero unornamented but
-added a tail or hook to the letter-O so that it resembled an inverted
-Q or cursive capital letter-O (this was endorsed by a draft ANSI
-standard for how to draw ASCII characters, but the final standard
-changed the distinguisher to a tick-mark in the upper-left corner).
-Are we sufficiently confused yet?&lt;/para&gt;
-&lt;/glossdef&gt;
-&lt;/glossentry&gt;
-
-&lt;glossentry&gt;
-&lt;glossterm&gt;1TBS&lt;/glossterm&gt;
-&lt;glossdef&gt;
-&lt;para role="accidence"&gt;
-&lt;phrase role="pronounce"&gt;&lt;/phrase&gt;
-&lt;phrase role="partsofspeach"&gt;n&lt;/phrase&gt;
-&lt;/para&gt;
-&lt;para&gt;The "One True Brace Style"&lt;/para&gt;
-&lt;glossseealso&gt;indent style&lt;/glossseealso&gt;
-&lt;/glossdef&gt;
-&lt;/glossentry&gt;
-
-&lt;!-- ... --&gt;
-
-&lt;/glossdiv&gt;
-
-&lt;!-- ... --&gt;
-
-&lt;/glossary&gt;</programlisting>
-</informalexample>
-
-</refsection>
-
-<refsection><info><title>Marking Up Glossary Terms</title></info>
-
-<para>That takes care of the glossary database, now you have to get the entries
-into your document. Unlike bibliography entries, which can be empty, creating
-<quote>placeholder</quote> glossary entries would be very tedious. So instead,
-support for <parameter>glossary.collection</parameter> relies on implicit linking.</para>
-
-<para>In your source document, simply use <tag>firstterm</tag> and
-<tag>glossterm</tag> to identify the terms you wish to have included
-in the glossary. The stylesheets assume that you will either set the
-<tag class="attribute">baseform</tag> attribute correctly, or that the
-content of the element exactly matches a term in your glossary.</para>
-
-<para>If you're using a <parameter>glossary.collection</parameter>, don't
-make explicit links on the terms in your document.</para>
-
-<para>So, in your document, you might write things like this:</para>
-
-<informalexample>
-<programlisting>&lt;para&gt;This is dummy text, without any real meaning.
-The point is simply to reference glossary terms like &lt;glossterm&gt;0&lt;/glossterm&gt;
-and the &lt;firstterm baseform="1TBS"&gt;One True Brace Style (1TBS)&lt;/firstterm&gt;.
-The &lt;glossterm&gt;1TBS&lt;/glossterm&gt;, as you can probably imagine, is a nearly
-religious issue.&lt;/para&gt;</programlisting>
-</informalexample>
-
-<para>If you set the <parameter>firstterm.only.link</parameter> parameter,
-only the terms marked with <tag>firstterm</tag> will be links.
-Otherwise, all the terms will be linked.</para>
-
-</refsection>
-
-<refsection><info><title>Marking Up the Glossary</title></info>
-
-<para>The glossary itself has to be identified for the stylesheets. For lack
-of a better choice, the <tag class="attribute">role</tag> is used.
-To identify the glossary as the target for automatic processing, set
-the role to <quote><literal>auto</literal></quote>. The title of this
-glossary (and any other information from the <tag>glossaryinfo</tag>
-that's rendered by your stylesheet) will be displayed, but the entries will
-come from the database.
-</para>
-
-<para>Unfortunately, the glossary can't be empty, so you must put in
-at least one <tag>glossentry</tag>. The content of this entry
-is irrelevant, it will not be rendered:</para>
-
-<informalexample>
-<programlisting>&lt;glossary role="auto"&gt;
-&lt;glossentry&gt;
-&lt;glossterm&gt;Irrelevant&lt;/glossterm&gt;
-&lt;glossdef&gt;
-&lt;para&gt;If you can see this, the document was processed incorrectly. Use
-the &lt;parameter&gt;glossary.collection&lt;/parameter&gt; parameter.&lt;/para&gt;
-&lt;/glossdef&gt;
-&lt;/glossentry&gt;
-&lt;/glossary&gt;</programlisting>
-</informalexample>
-
-<para>What about glossary divisions? If your glossary database has glossary
-divisions <emphasis>and</emphasis> your automatic glossary contains at least
-one <tag>glossdiv</tag>, the automic glossary will have divisions.
-If the <tag>glossdiv</tag> is missing from either location, no divisions
-will be rendered.</para>
-
-<para>Glossary entries (and divisions, if appropriate) in the glossary will
-occur in precisely the order they occur in your database.</para>
-
-</refsection>
-
-<refsection><info><title>Formatting the Document</title></info>
-
-<para>Finally, when you are ready to format your document, simply set the
-<parameter>glossary.collection</parameter> parameter (in either a
-customization layer or directly through your processor's interface) to
-point to your global glossary.</para>
-
-<para>A relative path in the parameter is interpreted in one
-of two ways:</para>
-<orderedlist numeration="loweralpha">
-  <listitem>
-    <para>If the parameter <literal>glossterm.auto.link</literal>
-    is set to zero, then the path is relative to the file containing
-    the empty <tag>glossary</tag> element in the document.</para>
-  </listitem>
-  <listitem>
-    <para>If the parameter <literal>glossterm.auto.link</literal>
-    is set to non-zero, then the path is relative to the file containing
-    the first inline <tag>glossterm</tag> or
-    <tag>firstterm</tag> in the document to be linked.</para>
-  </listitem>
-</orderedlist>
-<para>Once the collection file is opened by the first instance described
-above, it stays open for the current document
-and the relative path is not reinterpreted again.</para>
-
-<para>The stylesheets will format the glossary in your document as if
-all of the entries implicilty referenced appeared there literally.</para>
-</refsection>
-
-<refsection><info><title>Limitations</title></info>
-
-<para>Glossary cross-references <emphasis>within the glossary</emphasis> are
-not supported. For example, this <emphasis>will not</emphasis> work:</para>
-
-<informalexample>
-<programlisting>&lt;glossentry&gt;
-&lt;glossterm&gt;gloss-1&lt;/glossterm&gt;
-&lt;glossdef&gt;&lt;para&gt;A description that references &lt;glossterm&gt;gloss-2&lt;/glossterm&gt;.&lt;/para&gt;
-&lt;glossseealso&gt;gloss-2&lt;/glossseealso&gt;
-&lt;/glossdef&gt;
-&lt;/glossentry&gt;</programlisting>
-</informalexample>
-
-<para>If you put glossary cross-references in your glossary that way,
-you'll get the cryptic error: <computeroutput>Warning:
-glossary.collection specified, but there are 0 automatic
-glossaries</computeroutput>.</para>
-
-<para>Instead, you must do two things:</para>
-
-<orderedlist>
-<listitem>
-<para>Markup your glossary using <tag>glossseealso</tag>:</para>
-
-<informalexample>
-<programlisting>&lt;glossentry&gt;
-&lt;glossterm&gt;gloss-1&lt;/glossterm&gt;
-&lt;glossdef&gt;&lt;para&gt;A description that references &lt;glossterm&gt;gloss-2&lt;/glossterm&gt;.&lt;/para&gt;
-&lt;glossseealso&gt;gloss-2&lt;/glossseealso&gt;
-&lt;/glossdef&gt;
-&lt;/glossentry&gt;</programlisting>
-</informalexample>
-</listitem>
-
-<listitem>
-<para>Make sure there is at least one <tag>glossterm</tag> reference to
-<glossterm>gloss-2</glossterm> <emphasis>in your document</emphasis>. The
-easiest way to do that is probably within a <tag>remark</tag> in your
-automatic glossary:</para>
-
-<informalexample>
-<programlisting>&lt;glossary role="auto"&gt;
-&lt;remark&gt;Make sure there's a reference to &lt;glossterm&gt;gloss-2&lt;/glossterm&gt;.&lt;/remark&gt;
-&lt;glossentry&gt;
-&lt;glossterm&gt;Irrelevant&lt;/glossterm&gt;
-&lt;glossdef&gt;
-&lt;para&gt;If you can see this, the document was processed incorrectly. Use
-the &lt;parameter&gt;glossary.collection&lt;/parameter&gt; parameter.&lt;/para&gt;
-&lt;/glossdef&gt;
-&lt;/glossentry&gt;
-&lt;/glossary&gt;</programlisting>
-</informalexample>
-</listitem>
-</orderedlist>
-</refsection>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="glossary.sort">
-<refmeta>
-<refentrytitle>glossary.sort</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>glossary.sort</refname>
-<refpurpose>Sort glossentry elements?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="glossary.sort.frag">
-&lt;xsl:param name="glossary.sort" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, then the glossentry elements within a
-glossary, glossdiv, or glosslist are sorted on the glossterm, using
-the current lang setting.  If zero (the default), then
-glossentry elements are not sorted and are presented
-in document order.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="glossentry.show.acronym">
-<refmeta>
-<refentrytitle>glossentry.show.acronym</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">list</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">no</refmiscinfo> 
-<refmiscinfo class="other" otherclass="value">yes</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">primary</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>glossentry.show.acronym</refname>
-<refpurpose>Display <tag>glossentry</tag> acronyms?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="glossentry.show.acronym.frag">
-&lt;xsl:param name="glossentry.show.acronym"&gt;no&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>A setting of <quote>yes</quote> means they should be displayed;
-<quote>no</quote> means they shouldn't. If <quote>primary</quote> is used,
-then they are shown as the primary text for the entry.</para>
-
-<note>
-<para>This setting controls both <tag>acronym</tag> and
-<tag>abbrev</tag> elements in the <tag>glossentry</tag>.</para>
-</note>
-
-</refsection>
-</refentry>
-
-</reference><reference id="misc" xml:base="../html/param.xml"><title>Miscellaneous</title>
-<refentry version="5.0" id="formal.procedures">
-<refmeta>
-<refentrytitle>formal.procedures</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>formal.procedures</refname>
-<refpurpose>Selects formal or informal procedures</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="formal.procedures.frag">
-&lt;xsl:param name="formal.procedures" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Formal procedures are numbered and always have a title.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="formal.title.placement">
-<refmeta>
-<refentrytitle>formal.title.placement</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">table</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>formal.title.placement</refname>
-<refpurpose>Specifies where formal object titles should occur</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="formal.title.placement.frag">
-&lt;xsl:param name="formal.title.placement"&gt;
-figure before
-example before
-equation before
-table before
-procedure before
-task before
-&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Specifies where formal object titles should occur. For each formal object
-type (<tag>figure</tag>,
-<tag>example</tag>,
-<tag>equation</tag>,
-<tag>table</tag>, and <tag>procedure</tag>)
-you can specify either the keyword
-<quote><literal>before</literal></quote> or
-<quote><literal>after</literal></quote>.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="runinhead.default.title.end.punct">
-<refmeta>
-<refentrytitle>runinhead.default.title.end.punct</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>runinhead.default.title.end.punct</refname>
-<refpurpose>Default punctuation character on a run-in-head</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="runinhead.default.title.end.punct.frag">&lt;xsl:param name="runinhead.default.title.end.punct"&gt;.&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, For a <tag>formalpara</tag>, use the specified
-string as the separator between the title and following text. The period is the default value.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="runinhead.title.end.punct">
-<refmeta>
-<refentrytitle>runinhead.title.end.punct</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>runinhead.title.end.punct</refname>
-<refpurpose>Characters that count as punctuation on a run-in-head</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="runinhead.title.end.punct.frag">
-&lt;xsl:param name="runinhead.title.end.punct"&gt;.!?:&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Specify which characters are to be counted as punctuation. These
-characters are checked for a match with the last character of the
-title. If no match is found, the
-<parameter>runinhead.default.title.end.punct</parameter> contents are
-inserted. This is to avoid duplicated punctuation in the output.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="show.comments">
-<refmeta>
-<refentrytitle>show.comments</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>show.comments</refname>
-<refpurpose>Display <tag>remark</tag> elements?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="show.comments.frag">
-&lt;xsl:param name="show.comments" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, comments will be displayed, otherwise they
-are suppressed.  Comments here refers to the <tag>remark</tag> element
-(which was called <literal>comment</literal> prior to DocBook
-4.0), not XML comments (&lt;-- like this --&gt;) which are
-unavailable.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="show.revisionflag">
-<refmeta>
-<refentrytitle>show.revisionflag</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>show.revisionflag</refname>
-<refpurpose>Enable decoration of elements that have a revisionflag</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="show.revisionflag.frag">
-&lt;xsl:param name="show.revisionflag" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>
-If <parameter>show.revisionflag</parameter> is turned on, then the stylesheets
-may produce additional markup designed to allow a CSS stylesheet to
-highlight elements that have specific revisionflag settings.</para>
-
-<para>The markup inserted will be usually be either a &lt;span&gt; or
-&lt;div&gt; with an appropriate <literal>class</literal>
-attribute. (The value of the class attribute will be the same as the
-value of the revisionflag attribute). In some contexts, for example
-tables, where extra markup would be structurally illegal, the class
-attribute will be added to the appropriate container element.</para>
-
-<para>In general, the stylesheets only test for revisionflag in contexts
-where an importing stylesheet would have to redefine whole templates.
-Most of the revisionflag processing is expected to be done by another
-stylesheet, for example <filename>changebars.xsl</filename>.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="shade.verbatim">
-<refmeta>
-<refentrytitle>shade.verbatim</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>shade.verbatim</refname>
-<refpurpose>Should verbatim environments be shaded?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="shade.verbatim.frag">&lt;xsl:param name="shade.verbatim" select="0"&gt;&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>In the FO stylesheet, if this parameter is non-zero then the
-<property>shade.verbatim.style</property> properties will be applied
-to verbatim environments.</para>
-
-<para>In the HTML stylesheet, this parameter is now deprecated. Use
-CSS instead.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="shade.verbatim.style">
-<refmeta>
-<refentrytitle>shade.verbatim.style</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>shade.verbatim.style</refname>
-<refpurpose>Properties that specify the style of shaded verbatim listings</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="shade.verbatim.style.frag">
-&lt;xsl:attribute-set name="shade.verbatim.style"&gt;
-  &lt;xsl:attribute name="border"&gt;0&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="bgcolor"&gt;#E0E0E0&lt;/xsl:attribute&gt;
-&lt;/xsl:attribute-set&gt;
-
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Properties that specify the style of shaded verbatim listings. The
-parameters specified (the border and background color) are added to
-the styling of the xsl-fo output. A border might be specified as "thin
-black solid" for example. See <link xlink:href="http://www.w3.org/TR/2004/WD-xsl11-20041216/#border">xsl-fo</link></para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="punct.honorific">
-<refmeta>
-<refentrytitle>punct.honorific</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>punct.honorific</refname>
-<refpurpose>Punctuation after an honorific in a personal name.</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="punct.honorific.frag">
-&lt;xsl:param name="punct.honorific"&gt;.&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This parameter specifies the punctuation that should be added after an
-honorific in a personal name.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="tex.math.in.alt">
-<refmeta>
-<refentrytitle>tex.math.in.alt</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">list</refmiscinfo> 
-<refmiscinfo class="other" otherclass="value">plain</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">latex</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>tex.math.in.alt</refname>
-<refpurpose>TeX notation used for equations</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="tex.math.in.alt.frag">
-&lt;xsl:param name="tex.math.in.alt"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If you want type math directly in TeX notation in equations,
-this parameter specifies notation used. Currently are supported two
-values -- <literal>plain</literal> and <literal>latex</literal>. Empty
-value means that you are not using TeX math at all.</para>
-
-<para>Preferred way for including TeX alternative of math is inside of
-<tag>textobject</tag> element. Eg.:</para>
-
-<programlisting>&lt;inlineequation&gt;
-&lt;inlinemediaobject&gt;
-&lt;imageobject&gt;
-&lt;imagedata fileref="eq1.gif"/&gt;
-&lt;/imageobject&gt;
-&lt;textobject&gt;&lt;phrase&gt;E=mc squared&lt;/phrase&gt;&lt;/textobject&gt;
-&lt;textobject role="tex"&gt;&lt;phrase&gt;E=mc^2&lt;/phrase&gt;&lt;/textobject&gt;
-&lt;/inlinemediaobject&gt;
-&lt;/inlineequation&gt;</programlisting>
-
-<para>If you are using <tag>graphic</tag> element, you can
-store TeX inside <tag>alt</tag> element:</para>
-
-<programlisting>&lt;inlineequation&gt;
-&lt;alt role="tex"&gt;a^2+b^2=c^2&lt;/alt&gt;
-&lt;graphic fileref="a2b2c2.gif"/&gt;  
-&lt;/inlineequation&gt;</programlisting>
-
-<para>If you want use this feature, you should process your FO with
-PassiveTeX, which only supports TeX math notation. When calling
-stylsheet, don't forget to specify also
-passivetex.extensions=1.</para>
-
-<para>If you want equations in HTML, just process generated file
-<filename>tex-math-equations.tex</filename> by TeX or LaTeX. Then run
-dvi2bitmap program on result DVI file. You will get images for
-equations in your document.</para>
-
-<warning>
-  <para>This feature is useful for print/PDF output only if you
-    use the obsolete and now unsupported PassiveTeX XSL-FO
-    engine.</para>
-</warning>
-
-</refsection>
-
-<refsection><info><title>Related Parameters</title></info>
-  <para><parameter>tex.math.delims</parameter>,
-    <parameter>passivetex.extensions</parameter>,
-    <parameter>tex.math.file</parameter></para>
-</refsection>
-
-</refentry>
-
-<refentry version="5.0" id="tex.math.file">
-<refmeta>
-<refentrytitle>tex.math.file</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>tex.math.file</refname>
-<refpurpose>Name of temporary file for generating images from equations</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="tex.math.file.frag">
-&lt;xsl:param name="tex.math.file"&gt;tex-math-equations.tex&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Name of auxiliary file for TeX equations. This file can be
-processed by dvi2bitmap to get bitmap versions of equations for HTML
-output.</para>
-
-</refsection>
-<refsection><info><title>Related Parameters</title></info>
-  <para><parameter>tex.math.in.alt</parameter>,
-    <parameter>tex.math.delims</parameter>,
-  </para>
-</refsection>
-<refsection><info><title>More information</title></info>
-  <para>For how-to documentation on embedding TeX equations and
-    generating output from them, see
-    <link role="tcg" xlink:href="TexMath.html">DBTeXMath</link>.</para>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="tex.math.delims">
-<refmeta>
-<refentrytitle>tex.math.delims</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>tex.math.delims</refname>
-<refpurpose>Should equations output for processing by TeX be
-surrounded by math mode delimiters?</refpurpose>
-</refnamediv> 
-
-<refsynopsisdiv>
-<programlisting id="tex.math.delims.frag">
-&lt;xsl:param name="tex.math.delims" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>For compatibility with DSSSL based DBTeXMath from Allin Cottrell
-you should set this parameter to 0.</para>
-
-<warning>
-  <para>This feature is useful for print/PDF output only if you
-  use the obsolete and now unsupported PassiveTeX XSL-FO
-  engine.</para>
-</warning>
-
-</refsection>
-<refsection><info><title>Related Parameters</title></info>
-  <para><parameter>tex.math.in.alt</parameter>,
-    <parameter>passivetex.extensions</parameter></para>
-</refsection>
-
-<refsection><info><title>See Also</title></info>
-  <para>You can also use the <tag class="xmlpi">dbtex delims</tag> processing
-    instruction to control whether delimiters are output.</para>
-</refsection>
-
-
-</refentry>
-
-<refentry version="5.0" id="pixels.per.inch">
-<refmeta>
-<refentrytitle>pixels.per.inch</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">integer</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>pixels.per.inch</refname>
-<refpurpose>How many pixels are there per inch?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="pixels.per.inch.frag">
-&lt;xsl:param name="pixels.per.inch"&gt;90&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>When lengths are converted to pixels, this value is used to
-determine the size of a pixel. The default value is taken from the
-<link xlink:href="http://www.w3.org/TR/2004/WD-xsl11-20041216/">XSL
-Recommendation</link>.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="points.per.em">
-<refmeta>
-<refentrytitle>points.per.em</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">number</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>points.per.em</refname>
-<refpurpose>Specify the nominal size of an em-space in points</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="points.per.em.frag">
-&lt;xsl:param name="points.per.em"&gt;10&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The fixed value used for calculations based upon the size of a
-character. The assumption made is that ten point font is in use. This
-assumption may not be valid.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="use.svg">
-<refmeta>
-<refentrytitle>use.svg</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>use.svg</refname>
-<refpurpose>Allow SVG in the result tree?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="use.svg.frag">
-&lt;xsl:param name="use.svg" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, SVG will be considered an acceptable image format. SVG
-is passed through to the result tree, so correct rendering of the resulting
-diagram depends on the formatter (FO processor or web browser) that is used
-to process the output from the stylesheet.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="menuchoice.separator">
-<refmeta>
-<refentrytitle>menuchoice.separator</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>menuchoice.separator</refname>
-<refpurpose>Separator between items of a <tag>menuchoice</tag>
-other than <tag>guimenuitem</tag> and
-<tag>guisubmenu</tag></refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="menuchoice.separator.frag">
-&lt;xsl:param name="menuchoice.separator"&gt;+&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Separator used to connect items of a <tag>menuchoice</tag> other
-than <tag>guimenuitem</tag> and <tag>guisubmenu</tag>. The latter
-elements are linked with <parameter>menuchoice.menu.separator</parameter>.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="menuchoice.menu.separator">
-<refmeta>
-<refentrytitle>menuchoice.menu.separator</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>menuchoice.menu.separator</refname>
-<refpurpose>Separator between items of a <tag>menuchoice</tag>
-with <tag>guimenuitem</tag> or
-<tag>guisubmenu</tag></refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="menuchoice.menu.separator.frag">
-&lt;xsl:param name="menuchoice.menu.separator"&gt; &#8594; &lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Separator used to connect items of a <tag>menuchoice</tag> with
-<tag>guimenuitem</tag> or <tag>guisubmenu</tag>. Other elements
-are linked with <parameter>menuchoice.separator</parameter>.
-</para>
-<para>The default value is &amp;#x2192;, which is the
-&amp;rarr; (right arrow) character entity.  
-The current FOP (0.20.5) requires setting the font-family
-explicitly.
-</para>
-<para>The default value also includes spaces around the arrow,
-which will allow a line to break.  Replace the spaces with
-&amp;#xA0; (nonbreaking space) if you don't want those
-spaces to break.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="default.float.class">
-<refmeta>
-<refentrytitle>default.float.class</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>default.float.class</refname>
-<refpurpose>Specifies the default float class</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="default.float.class.frag">
-&lt;xsl:param name="default.float.class"&gt;
-  &lt;xsl:choose&gt;
-    &lt;xsl:when test="contains($stylesheet.result.type,'html')"&gt;left&lt;/xsl:when&gt;
-    &lt;xsl:otherwise&gt;before&lt;/xsl:otherwise&gt;
-  &lt;/xsl:choose&gt;
-&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Selects the direction in which a float should be placed. for
-xsl-fo this is before, for html it is left. For Western texts, the
-before direction is the top of the page.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="footnote.number.format">
-<refmeta>
-<refentrytitle>footnote.number.format</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">list</refmiscinfo> 
-<refmiscinfo class="other" otherclass="value">1<alt>1,2,3...</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">A<alt>A,B,C...</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">a<alt>a,b,c...</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">i<alt>i,ii,iii...</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">I<alt>I,II,III...</alt></refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>footnote.number.format</refname>
-<refpurpose>Identifies the format used for footnote numbers</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="footnote.number.format.frag">
-&lt;xsl:param name="footnote.number.format"&gt;1&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The <parameter>footnote.number.format</parameter> specifies the format
-to use for footnote numeration (1, i, I, a, or A).</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="table.footnote.number.format">
-<refmeta>
-<refentrytitle>table.footnote.number.format</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">list</refmiscinfo> 
-<refmiscinfo class="other" otherclass="value">1<alt>1,2,3...</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">A<alt>A,B,C...</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">a<alt>a,b,c...</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">i<alt>i,ii,iii...</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">I<alt>I,II,III...</alt></refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>table.footnote.number.format</refname>
-<refpurpose>Identifies the format used for footnote numbers in tables</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="table.footnote.number.format.frag">
-&lt;xsl:param name="table.footnote.number.format"&gt;a&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The <parameter>table.footnote.number.format</parameter> specifies the format
-to use for footnote numeration (1, i, I, a, or A) in tables.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="footnote.number.symbols">
-<refmeta>
-<refentrytitle>footnote.number.symbols</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype"/>
-</refmeta>
-<refnamediv>
-<refname>footnote.number.symbols</refname>
-<refpurpose>Special characters to use as footnote markers</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="footnote.number.symbols.frag">
-&lt;xsl:param name="footnote.number.symbols"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If <parameter>footnote.number.symbols</parameter> is not the empty string,
-footnotes will use the characters it contains as footnote symbols. For example,
-<quote>*&amp;#x2020;&amp;#x2021;&amp;#x25CA;&amp;#x2720;</quote> will identify
-footnotes with <quote>*</quote>, <quote>&#8224;</quote>, <quote>&#8225;</quote>,
-<quote>&#9674;</quote>, and <quote>&#10016;</quote>. If there are more footnotes
-than symbols, the stylesheets will fall back to numbered footnotes using
-<parameter>footnote.number.format</parameter>.</para>
-
-<para>The use of symbols for footnotes depends on the ability of your
-processor (or browser) to render the symbols you select. Not all systems are
-capable of displaying the full range of Unicode characters. If the quoted characters
-in the preceding paragraph are not displayed properly, that's a good indicator
-that you may have trouble using those symbols for footnotes.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="table.footnote.number.symbols">
-<refmeta>
-<refentrytitle>table.footnote.number.symbols</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>table.footnote.number.symbols</refname>
-<refpurpose>Special characters to use a footnote markers in tables</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="table.footnote.number.symbols.frag">
-&lt;xsl:param name="table.footnote.number.symbols"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If <parameter>table.footnote.number.symbols</parameter> is not the empty string,
-table footnotes will use the characters it contains as footnote symbols. For example,
-<quote>*&amp;#x2020;&amp;#x2021;&amp;#x25CA;&amp;#x2720;</quote> will identify
-footnotes with <quote>*</quote>, <quote>&#8224;</quote>, <quote>&#8225;</quote>,
-<quote>&#9674;</quote>, and <quote>&#10016;</quote>. If there are more footnotes
-than symbols, the stylesheets will fall back to numbered footnotes using
-<parameter>table.footnote.number.format</parameter>.</para>
-
-<para>The use of symbols for footnotes depends on the ability of your
-processor (or browser) to render the symbols you select. Not all systems are
-capable of displaying the full range of Unicode characters. If the quoted characters
-in the preceding paragraph are not displayed properly, that's a good indicator
-that you may have trouble using those symbols for footnotes.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="highlight.source">
-<refmeta>
-<refentrytitle>highlight.source</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>highlight.source</refname>
-<refpurpose>Should the content of <tag>programlisting</tag>
-be syntactically highlighted?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="highlight.source.frag">
-&lt;xsl:param name="highlight.source" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>When this parameter is non-zero, the stylesheets will try to do syntax highlighting of the 
-content of <tag>programlisting</tag> elements. You specify the language for each programlisting 
-by using the <tag class="attribute">language</tag> attribute. The <parameter>highlight.default.language</parameter> 
-parameter can be used to specify the language for programlistings without a <tag class="attribute">language</tag> 
-attribute. Syntax highlighting also works for <tag>screen</tag> and <tag>synopsis</tag> elements.</para>
-
-<para>The actual highlighting work is done by the XSLTHL extension module. This is an external Java library that has to be 
-downloaded separately (see below).</para>
-
-<itemizedlist>
-<para>In order to use this extension, you must</para> 
-
-<listitem><para>add <filename>xslthl-2.x.x.jar</filename> to your Java classpath. The latest version is available
-from <link xlink:href="http://sourceforge.net/projects/xslthl">the XSLT syntax highlighting project</link> 
-at SourceForge.</para>
-</listitem>
-<listitem>
-<para>use a customization layer in which you import one of the following stylesheet modules: 
-<itemizedlist>
-  <listitem>
-    <para><filename>html/highlight.xsl</filename>
-    </para>
-  </listitem>
-<listitem>
-    <para><filename>xhtml/highlight.xsl</filename>
-    </para>
-  </listitem>
-<listitem>
-    <para><filename>xhtml-1_1/highlight.xsl</filename>
-    </para>
-  </listitem>
-<listitem>
-    <para><filename>fo/highlight.xsl</filename>
-    </para>
-</listitem>
-</itemizedlist>
-</para>
-</listitem>
-<listitem><para>let either the <literal>xslthl.config</literal> Java system property or the
-<parameter>highlight.xslthl.config</parameter> parameter point to the configuration file for syntax 
-highlighting (using URL syntax). DocBook XSL comes with a ready-to-use configuration file, 
-<filename>highlighting/xslthl-config.xml</filename>.</para>
-</listitem>
-</itemizedlist>
-
-<para>The extension works with Saxon 6.5.x and Xalan-J. (Saxon 8.5 or later is also supported, but since it is 
-an XSLT 2.0 processor it is not guaranteed to work with DocBook XSL in all circumstances.)</para>
-
-<para>The following is an example of a Saxon 6 command adapted for syntax highlighting, to be used on Windows:</para>
-
-<informalexample>
-<para><command>java -cp c:/Java/saxon.jar;c:/Java/xslthl-2.0.1.jar 
--Dxslthl.config=file:///c:/docbook-xsl/highlighting/xslthl-config.xml com.icl.saxon.StyleSheet 
--o test.html test.xml myhtml.xsl</command></para>
-</informalexample>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="highlight.xslthl.config">
-<refmeta>
-<refentrytitle>highlight.xslthl.config</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">uri</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>highlight.xslthl.config</refname>
-<refpurpose>Location of XSLTHL configuration file</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="highlight.xslthl.config.frag">
-&lt;xsl:param name="highlight.xslthl.config"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This location has precedence over the corresponding Java property.</para>
-
-<para>Please note that usually you have to specify location as URL not
-just as a simple path on the local
-filesystem. E.g. <filename>file:///home/user/xslthl/my-xslthl-config.xml</filename>.</para>
-
-
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="highlight.default.language">
-<refmeta>
-<refentrytitle>highlight.default.language</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>highlight.default.language</refname>
-<refpurpose>Default language of programlisting</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="highlight.default.language.frag">
-&lt;xsl:param name="highlight.default.language"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This language is used when there is no language attribute on programlisting.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="email.delimiters.enabled">
-<refmeta>
-<refentrytitle>email.delimiters.enabled</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>email.delimiters.enabled</refname>
-<refpurpose>Generate delimiters around email addresses?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="email.delimiters.enabled.frag">
-&lt;xsl:param name="email.delimiters.enabled" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, delimiters
-
-<footnote><para>For delimiters, the
-stylesheets are currently hard-coded to output angle
-brackets.</para></footnote> 
-
-are generated around e-mail addresses
-(the output of the <tag>email</tag> element).</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="exsl.node.set.available">
-<refmeta>
-<refentrytitle>exsl.node.set.available</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>exsl.node.set.available</refname>
-<refpurpose>Is the test function-available('exsl:node-set') true?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="exsl.node.set.available.frag">&lt;xsl:param name="exsl.node.set.available"&gt; 
-  &lt;xsl:choose&gt;
-    &lt;xsl:when exsl:foo="" test="function-available('exsl:node-set') or                        contains(system-property('xsl:vendor'),                          'Apache Software Foundation')"&gt;1&lt;/xsl:when&gt;
-    &lt;xsl:otherwise&gt;0&lt;/xsl:otherwise&gt;
-  &lt;/xsl:choose&gt;
-&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero,
-then the exsl:node-set() function is available to be used in
-the stylesheet.
-If zero, then the function is not available.
-This param automatically detects the presence of
-the function and does not normally need to be set manually.</para>
-
-<para>This param was created to handle a long-standing
-bug in the Xalan processor that fails to detect the
-function even though it is available.</para>
-
-</refsection>
-</refentry>
-
-</reference><reference id="annos" xml:base="../html/param.xml"><title>Annotations</title>
-<refentry version="5.0" id="annotation.support">
-<refmeta>
-<refentrytitle>annotation.support</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>annotation.support</refname>
-<refpurpose>Enable annotations?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="annotation.support.frag">
-&lt;xsl:param name="annotation.support" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, the stylesheets will attempt to support annotation
-elements in HTML by including some JavaScript (see
-<parameter>annotation.js</parameter>).</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="annotation.js">
-<refmeta>
-<refentrytitle>annotation.js</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>annotation.js</refname>
-<refpurpose>URIs identifying JavaScript files with support for annotation popups</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="annotation.js.frag">
-
-&lt;xsl:param name="annotation.js"&gt;
-&lt;xsl:text&gt;http://docbook.sourceforge.net/release/script/AnchorPosition.js http://docbook.sourceforge.net/release/script/PopupWindow.js&lt;/xsl:text&gt;&lt;/xsl:param&gt;
-
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If <property>annotation.support</property> is enabled and the
-document contains <tag>annotation</tag>s, then the URIs listed
-in this parameter will be included. These JavaScript files are required
-for popup annotation support.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="annotation.css">
-<refmeta>
-<refentrytitle>annotation.css</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>annotation.css</refname>
-<refpurpose>CSS rules for annotations</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="annotation.css.frag">
-&lt;xsl:param name="annotation.css"&gt;
-/* ======================================================================
-   Annotations
-*/
-
-div.annotation-list  { visibility: hidden;
-                     }
-
-div.annotation-nocss { position: absolute;
-                       visibility: hidden;
-                     }
-
-div.annotation-popup { position: absolute;
-                       z-index: 4;
-                       visibility: hidden;
-                       padding: 0px;
-                       margin: 2px;
-                       border-style: solid;
-                       border-width: 1px;
-                       width: 200px;
-		       background-color: white;
-                     }
-
-div.annotation-title { padding: 1px;
-                       font-weight: bold;
-                       border-bottom-style: solid;
-                       border-bottom-width: 1px;
-		       color: white;
-		       background-color: black;
-                     }
-
-div.annotation-body  { padding: 2px;
-                     }
-
-div.annotation-body p { margin-top: 0px;
-                        padding-top: 0px;
-                      }
-
-div.annotation-close { position: absolute;
-                       top: 2px;
-                       right: 2px;
-                     }
-&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If <parameter>annotation.support</parameter> is enabled and the
-document contains <tag>annotation</tag>s, then the CSS in this
-parameter will be included in the document.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="annotation.graphic.open">
-<refmeta>
-<refentrytitle>annotation.graphic.open</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">uri</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>annotation.graphic.open</refname>
-<refpurpose>Image for identifying a link that opens an annotation popup</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="annotation.graphic.open.frag">
-&lt;xsl:param name="annotation.graphic.open"&gt;http://docbook.sourceforge.net/release/images/annot-open.png&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This image is used inline to identify the location of
-annotations. It may be replaced by a user provided graphic. The size should be approximately 10x10 pixels.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="annotation.graphic.close">
-<refmeta>
-<refentrytitle>annotation.graphic.close</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">uri</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>annotation.graphic.close</refname>
-<refpurpose>Image for identifying a link that closes an annotation popup</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="annotation.graphic.close.frag">
-&lt;xsl:param name="annotation.graphic.close"&gt;
-http://docbook.sourceforge.net/release/images/annot-close.png&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This image is used on popup annotations as the &#8220;x&#8221; that the
-user can click to dismiss the popup.</para>
-<para>This image is used on popup annotations as the &#8220;x&#8221; that the user can
-click to dismiss the popup. It may be replaced by a user provided graphic. The size should be approximately 10x10 pixels.</para>
-
-</refsection>
-</refentry>
-
-</reference><reference id="graphics" xml:base="../html/param.xml"><title>Graphics</title>
-<refentry version="5.0" id="img.src.path">
-<refmeta>
-<refentrytitle>img.src.path</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>img.src.path</refname>
-<refpurpose>Path to HTML/FO image files</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="img.src.path.frag">&lt;xsl:param name="img.src.path"&gt;&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Add a path prefix to the value of the <tag class="attribute">fileref</tag> 
-attribute of <tag>graphic</tag>, <tag>inlinegraphic</tag>, and <tag>imagedata</tag> elements. The resulting 
-compound path is used in the output as the value of the <tag class="attribute">src</tag> 
-attribute of <tag class="element">img</tag> (HTML) or <tag class="element">external-graphic</tag> (FO).
-</para>
-
-<para>
-The path given by <literal>img.src.path</literal> could be relative to the directory where the HTML/FO
-files are created, or it could be an absolute URI.
-The default value is empty.
-Be sure to include a trailing slash if needed.
-</para>
-
-<para>This prefix is not applied to any filerefs that start
-with "/" or contain "//:".
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="keep.relative.image.uris">
-<refmeta>
-<refentrytitle>keep.relative.image.uris</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>keep.relative.image.uris</refname>
-<refpurpose>Should image URIs be resolved against xml:base?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="keep.relative.image.uris.frag">
-&lt;xsl:param name="keep.relative.image.uris" select="1"&gt;&lt;/xsl:param&gt;
-
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, relative URIs (in, for example
-<literal>fileref</literal> attributes) will be used in the generated
-output. Otherwise, the URIs will be made absolute with respect to the
-base URI.</para>
-
-<para>Note that the stylesheets calculate (and use) the absolute form
-for some purposes, this only applies to the resulting output.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="graphic.default.extension">
-<refmeta>
-<refentrytitle>graphic.default.extension</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>graphic.default.extension</refname>
-<refpurpose>Default extension for graphic filenames</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="graphic.default.extension.frag">&lt;xsl:param name="graphic.default.extension"&gt;&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If a <tag>graphic</tag> or <tag>mediaobject</tag>
-includes a reference to a filename that does not include an extension,
-and the <tag class="attribute">format</tag> attribute is
-<emphasis>unspecified</emphasis>, the default extension will be used.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="default.image.width">
-<refmeta>
-<refentrytitle>default.image.width</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">length</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>default.image.width</refname>
-<refpurpose>The default width of images</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="default.image.width.frag">
-&lt;xsl:param name="default.image.width"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If specified, this value will be used for the
-<tag class="attribute">width</tag> attribute on images that do not specify any 
-<emphasis xlink:title="DocBook 5: The Definitive Guide" xlink:href="http://docbook.org/tdg5/en/html/imagedata.html#viewport.area">viewport dimensions</emphasis>.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="nominal.image.width">
-<refmeta>
-<refentrytitle>nominal.image.width</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">length</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>nominal.image.width</refname>
-<refpurpose>The nominal image width</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="nominal.image.width.frag">
-&lt;xsl:param name="nominal.image.width" select="6 * $pixels.per.inch"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Graphic widths expressed as a percentage are problematic. In the
-following discussion, we speak of width and contentwidth, but
-the same issues apply to depth and contentdepth.</para>
-
-<para>A width of 50% means "half of the available space for the image."
-That's fine. But note that in HTML, this is a dynamic property and
-the image size will vary if the browser window is resized.</para>
-
-<para>A contentwidth of 50% means "half of the actual image width".
-But what does that mean if the stylesheets cannot assess the image's
-actual size? Treating this as a width of 50% is one possibility, but
-it produces behavior (dynamic scaling) that seems entirely out of
-character with the meaning.</para>
-
-<para>Instead, the stylesheets define a
-<parameter>nominal.image.width</parameter> and convert percentages to
-actual values based on that nominal size.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="nominal.image.depth">
-<refmeta>
-<refentrytitle>nominal.image.depth</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">length</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>nominal.image.depth</refname>
-<refpurpose>Nominal image depth</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="nominal.image.depth.frag">
-&lt;xsl:param name="nominal.image.depth" select="4 * $pixels.per.inch"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>See <parameter>nominal.image.width</parameter>.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="use.embed.for.svg">
-<refmeta>
-<refentrytitle>use.embed.for.svg</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>use.embed.for.svg</refname>
-<refpurpose>Use HTML <tag>embed</tag> for SVG?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="use.embed.for.svg.frag">
-&lt;xsl:param name="use.embed.for.svg" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, an <tag>embed</tag> element will be created for
-SVG figures. An <tag>object</tag> is <emphasis>always</emphasis> created,
-this parameter merely controls whether or not an additional <tag>embed</tag>
-is generated inside the <tag>object</tag>.</para>
-
-<para>On the plus side, this may be more portable among browsers and plug-ins.
-On the minus side, it isn't valid HTML.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="make.graphic.viewport">
-<refmeta>
-<refentrytitle>make.graphic.viewport</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>make.graphic.viewport</refname>
-<refpurpose>Use tables in HTML to make viewports for graphics</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="make.graphic.viewport.frag">
-&lt;xsl:param name="make.graphic.viewport" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The HTML <tag>img</tag> element only supports the notion
-of content-area scaling; it doesn't support the distinction between a
-content-area and a viewport-area, so we have to make some compromises.</para>
-
-<para>If <parameter>make.graphic.viewport</parameter> is non-zero, a table
-will be used to frame the image. This creates an effective viewport-area.
-</para>
-
-<para>Tables and alignment don't work together, so this parameter is ignored
-if alignment is specified on an image.</para>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="preferred.mediaobject.role">
-<refmeta>
-<refentrytitle>preferred.mediaobject.role</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>preferred.mediaobject.role</refname>
-<refpurpose>Select which mediaobject to use based on
-this value of an object's <tag class="attribute">role</tag> attribute.
-</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="preferred.mediaobject.role.frag">
-&lt;xsl:param name="preferred.mediaobject.role"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>A mediaobject may contain several objects such as imageobjects.
-If the parameter <parameter>use.role.for.mediaobject</parameter> is
-non-zero, then the <literal>role</literal> attribute on
-<tag>imageobject</tag>s and other objects within a
-<tag>mediaobject</tag> container will be used to select which object
-will be used.  If one of the objects has a role value that matches the
-<parameter>preferred.mediaobject.role</parameter> parameter, then it
-has first priority for selection.  If more than one has such a role
-value, the first one is used.
-</para>
-<para>
-See the <parameter>use.role.for.mediaobject</parameter> parameter
-for the sequence of selection.</para>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="use.role.for.mediaobject">
-<refmeta>
-<refentrytitle>use.role.for.mediaobject</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>use.role.for.mediaobject</refname>
-<refpurpose>Use <tag class="attribute">role</tag> attribute 
-value for selecting which of several objects within a mediaobject to use.
-</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="use.role.for.mediaobject.frag">
-&lt;xsl:param name="use.role.for.mediaobject" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, the <tag class="attribute">role</tag> attribute on
-<tag>imageobject</tag>s or other objects within a <tag>mediaobject</tag> container will be used to select which object will be
-used.
-</para>
-<para>
-The order of selection when then parameter is non-zero is:
-</para>
-<orderedlist>
-<listitem>
-    <para>If the stylesheet parameter <parameter>preferred.mediaobject.role</parameter> has a value, then the object whose role equals that value is selected.</para>
-</listitem>
-<listitem>
-<para>Else if an object's role attribute has a value of
-<literal>html</literal> for HTML processing or
-<literal>fo</literal> for FO output, then the first
-of such objects is selected.
-</para>
-</listitem>
-<listitem>
-<para>Else the first suitable object is selected.</para>
-</listitem>
-</orderedlist>
-<para>
-If the value of 
-<parameter>use.role.for.mediaobject</parameter>
-is zero, then role attributes are not considered
-and the first suitable object
-with or without a role value is used.
-</para>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="ignore.image.scaling">
-<refmeta>
-<refentrytitle>ignore.image.scaling</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>ignore.image.scaling</refname>
-<refpurpose>Tell the stylesheets to ignore the author's image scaling attributes</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="ignore.image.scaling.frag">
-&lt;xsl:param name="ignore.image.scaling" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, the scaling attributes on graphics and media objects are
-ignored.</para>
-
-</refsection>
-</refentry>
-
-</reference><reference id="chunking" xml:base="../html/param.xml"><title>Chunking</title>
-<refentry version="5.0" id="chunker.output.cdata-section-elements">
-<refmeta>
-<refentrytitle>chunker.output.cdata-section-elements</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>chunker.output.cdata-section-elements</refname>
-<refpurpose>List of elements to escape with CDATA sections</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-<programlisting id="chunker.output.cdata-section-elements.frag">
-&lt;xsl:param name="chunker.output.cdata-section-elements"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-<refsection><info><title>Description</title></info>
-<para>This parameter specifies the list of elements that should be escaped
-as CDATA sections by the chunking stylesheet.  Not all processors support
-specification of this parameter.
-</para>
-<note>
-<para>This parameter is documented here, but the declaration is actually
-in the <filename>chunker.xsl</filename> stylesheet module.</para>
-</note>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="chunker.output.doctype-public">
-<refmeta>
-<refentrytitle>chunker.output.doctype-public</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>chunker.output.doctype-public</refname>
-<refpurpose>Public identifer to use in the document type of generated pages</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-<programlisting id="chunker.output.doctype-public.frag">
-&lt;xsl:param name="chunker.output.doctype-public"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-<refsection><info><title>Description</title></info>
-<para>This parameter specifies the public identifier that should be used by
-the chunking stylesheet in the document type declaration of chunked pages.
-Not all processors support specification of
-this parameter.
-</para>
-<note>
-<para>This parameter is documented here, but the declaration is actually
-in the <filename>chunker.xsl</filename> stylesheet module.</para>
-</note>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="chunker.output.doctype-system">
-<refmeta>
-<refentrytitle>chunker.output.doctype-system</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">uri</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>chunker.output.doctype-system</refname>
-<refpurpose>System identifier to use for the document type in generated pages</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-<programlisting id="chunker.output.doctype-system.frag">
-&lt;xsl:param name="chunker.output.doctype-system"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-<refsection><info><title>Description</title></info>
-<para>This parameter specifies the system identifier that should be used by
-the chunking stylesheet in the document type declaration of chunked pages.
-Not all processors support specification of
-this parameter.
-</para>
-<note>
-<para>This parameter is documented here, but the declaration is actually
-in the <filename>chunker.xsl</filename> stylesheet module.</para>
-</note>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="chunker.output.encoding">
-<refmeta>
-<refentrytitle>chunker.output.encoding</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>chunker.output.encoding</refname>
-<refpurpose>Encoding used in generated pages</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-<programlisting id="chunker.output.encoding.frag">
-&lt;xsl:param name="chunker.output.encoding"&gt;ISO-8859-1&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-<refsection><info><title>Description</title></info>
-<para>This parameter specifies the encoding to be used in files
-generated by the chunking stylesheet. Not all processors support
-specification of this parameter.
-</para>
-<para>This parameter used to be named <literal>default.encoding</literal>.</para>
-<note>
-<para>This parameter is documented here, but the declaration is actually
-in the <filename>chunker.xsl</filename> stylesheet module.</para>
-</note>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="chunker.output.indent">
-<refmeta>
-<refentrytitle>chunker.output.indent</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>chunker.output.indent</refname>
-<refpurpose>Specification of indentation on generated pages</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-<programlisting id="chunker.output.indent.frag">
-&lt;xsl:param name="chunker.output.indent"&gt;no&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-<refsection><info><title>Description</title></info>
-<para>This parameter specifies the value of the indent
-specification for generated pages. Not all processors support
-specification of this parameter.
-</para>
-<note>
-<para>This parameter is documented here, but the declaration is actually
-in the <filename>chunker.xsl</filename> stylesheet module.</para>
-</note>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="chunker.output.media-type">
-<refmeta>
-<refentrytitle>chunker.output.media-type</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>chunker.output.media-type</refname>
-<refpurpose>Media type to use in generated pages</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-<programlisting id="chunker.output.media-type.frag">
-&lt;xsl:param name="chunker.output.media-type"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-<refsection><info><title>Description</title></info>
-<para>This parameter specifies the media type that should be used by
-the chunking stylesheet. Not all processors support specification of
-this parameter.
-</para>
-<para>This parameter specifies the media type that should be used by the
-chunking stylesheet. This should be one from those defined in
-<link xlink:href="http://www.ietf.org/rfc/rfc2045.txt">[RFC2045]</link>  and
- <link xlink:href="http://www.ietf.org/rfc/rfc2046.txt">[RFC2046]</link> </para>
-<note>
-<para>This parameter is documented here, but the declaration is actually
-in the <filename>chunker.xsl</filename> stylesheet module.</para>
-<para>It must be one from html, xml or text</para>
-</note>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="chunker.output.method">
-<refmeta>
-<refentrytitle>chunker.output.method</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">list</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">html</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">xml</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>chunker.output.method</refname>
-<refpurpose>Method used in generated pages</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-<programlisting id="chunker.output.method.frag">
-&lt;xsl:param name="chunker.output.method"&gt;html&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-<refsection><info><title>Description</title></info>
-<para>This parameter specifies the output method to be used in files
-generated by the chunking stylesheet.
-</para>
-<para>This parameter used to be named <literal>output.method</literal>.</para>
-<note>
-<para>This parameter is documented here, but the declaration is actually
-in the <filename>chunker.xsl</filename> stylesheet module.</para>
-</note>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="chunker.output.omit-xml-declaration">
-<refmeta>
-<refentrytitle>chunker.output.omit-xml-declaration</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>chunker.output.omit-xml-declaration</refname>
-<refpurpose>Omit-xml-declaration for generated pages</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-<programlisting id="chunker.output.omit-xml-declaration.frag">
-&lt;xsl:param name="chunker.output.omit-xml-declaration"&gt;no&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-<refsection><info><title>Description</title></info>
-<para>This parameter specifies the value of the omit-xml-declaration
-specification for generated pages. Not all processors support
-specification of this parameter.
-</para>
-<note>
-<para>This parameter is documented here, but the declaration is actually
-in the <filename>chunker.xsl</filename> stylesheet module.</para>
-</note>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="chunker.output.standalone">
-<refmeta>
-<refentrytitle>chunker.output.standalone</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>chunker.output.standalone</refname>
-<refpurpose>Standalone declaration for generated pages</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-<programlisting id="chunker.output.standalone.frag">
-&lt;xsl:param name="chunker.output.standalone"&gt;no&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-<refsection><info><title>Description</title></info>
-<para>This parameter specifies the value of the standalone
-  specification for generated pages. It must be either
-  <literal>yes</literal> or <literal>no</literal>. Not all
-  processors support specification of this parameter.
-</para>
-<note>
-<para>This parameter is documented here, but the declaration is actually
-in the <filename>chunker.xsl</filename> stylesheet module.</para>
-</note>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="saxon.character.representation">
-<refmeta>
-<refentrytitle>saxon.character.representation</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>saxon.character.representation</refname>
-<refpurpose>Saxon character representation used in generated HTML pages</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-  <programlisting id="saxon.character.representation.frag">&lt;xsl:param name="saxon.character.representation" select="'entity;decimal'"&gt;&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This parameter has effect only when Saxon 6 is used (version 6.4.2 or later). 
-It sets the character representation in files generated by the chunking stylesheets. 
-If you want to suppress entity references for characters with direct representations in 
-<parameter>chunker.output.encoding</parameter>, set the parameter value to <literal>native</literal>. 
-</para>
-
-<para> For more information, see <link role="tcg" xlink:href="OutputEncoding.html#SaxonCharacter">Saxon output character representation</link>.</para>
-
-<note>
-<para>This parameter is documented here, but the declaration is actually
-in the <filename>chunker.xsl</filename> stylesheet module.</para>
-</note>
-
-</refsection>
-
-</refentry>
-
-<refentry version="5.0" id="html.ext">
-<refmeta>
-<refentrytitle>html.ext</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>html.ext</refname>
-<refpurpose>Identifies the extension of generated HTML files</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="html.ext.frag">
-&lt;xsl:param name="html.ext"&gt;.html&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The extension identified by <parameter>html.ext</parameter> will
-be used as the filename extension for chunks created by this
-stylesheet. </para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="use.id.as.filename">
-<refmeta>
-<refentrytitle>use.id.as.filename</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>use.id.as.filename</refname>
-<refpurpose>Use ID value of chunk elements as the filename?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="use.id.as.filename.frag">
-&lt;xsl:param name="use.id.as.filename" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If <parameter>use.id.as.filename</parameter>
-is non-zero, the filename of chunk elements that have IDs will be
-derived from the ID value.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="html.extra.head.links">
-<refmeta>
-<refentrytitle>html.extra.head.links</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>html.extra.head.links</refname>
-<refpurpose>Toggle extra HTML head link information</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="html.extra.head.links.frag">
-&lt;xsl:param name="html.extra.head.links" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, extra <tag>link</tag> elements will be
-generated in the <tag>head</tag> of chunked HTML files. These
-extra links point to chapters, appendixes, sections, etc. as supported
-by the <quote>Site Navigation Bar</quote> in Mozilla 1.0 (as of CR1, at least).
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="root.filename">
-<refmeta>
-<refentrytitle>root.filename</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">uri</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>root.filename</refname>
-<refpurpose>Identifies the name of the root HTML file when chunking</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="root.filename.frag">
-&lt;xsl:param name="root.filename"&gt;index&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The <parameter>root.filename</parameter> is the base filename for
-the chunk created for the root of each document processed.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="base.dir">
-<refmeta>
-<refentrytitle>base.dir</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">uri</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>base.dir</refname>
-<refpurpose>The base directory of chunks</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="base.dir.frag">
-&lt;xsl:param name="base.dir"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If specified, the <parameter>base.dir</parameter> parameter identifies
-the output directory for chunks. (If not specified, the output directory
-is system dependent.)</para>
-
-<para>Starting with version 1.77 of the stylesheets, 
-the param's value will have a trailing slash added if it does
-not already have one.</para>
-
-<caution><para>Do not use <parameter>base.dir</parameter>
-to add a filename prefix string to chunked  files. 
-Instead, use the <parameter>chunked.filename.prefix</parameter>
-parameter.</para></caution>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="chunked.filename.prefix">
-<refmeta>
-<refentrytitle>chunked.filename.prefix</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>chunked.filename.prefix</refname>
-<refpurpose>Filename prefix for chunked files</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="chunked.filename.prefix.frag">
-&lt;xsl:param name="chunked.filename.prefix"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If specified, the <parameter>chunked.filename.prefix</parameter> 
-parameter specifies a prefix string to add to each generated chunk filename.
-For example:</para>
-<programlisting>&lt;xsl:param name="chunked.filename.prefix"&gt;admin-&lt;xsl:param&gt;</programlisting>
-<para>will produce chunked filenames like:</para>
-<programlisting>admin-index.html
-admin-ch01.html
-admin-ch01s01.html
-...
-</programlisting>
-
-<caution><para>Trying to use the <parameter>base.dir</parameter>
-parameter to add a string prefix (by omitting the trailing slash)
-no longer works (it never worked completely anyway). That parameter
-value should contain only a directory path, and
-now gets a trailing slash appended if it was omitted from the param.</para></caution>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="generate.manifest">
-  <refmeta>
-    <refentrytitle>generate.manifest</refentrytitle>
-    <refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-  </refmeta>
-  <refnamediv>
-    <refname>generate.manifest</refname>
-    <refpurpose>Generate a manifest file?</refpurpose>
-  </refnamediv>
-
-  <refsynopsisdiv>
-    <programlisting id="generate.manifest.frag">&lt;xsl:param name="generate.manifest" select="0"&gt;&lt;/xsl:param&gt;</programlisting>
-  </refsynopsisdiv>
-
-  <refsection><info><title>Description</title></info>
-
-    <para>If non-zero, a list of HTML files generated by the
-      stylesheet transformation is written to the file named by
-      the <parameter>manifest</parameter> parameter.</para>
-
-  </refsection>
-</refentry>
-
-<refentry version="5.0" id="manifest">
-  <refmeta>
-    <refentrytitle>manifest</refentrytitle>
-    <refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-  </refmeta>
-  <refnamediv>
-    <refname>manifest</refname>
-    <refpurpose>Name of manifest file</refpurpose>
-  </refnamediv>
-
-  <refsynopsisdiv>
-    <programlisting id="manifest.frag">
-    &lt;xsl:param name="manifest"&gt;HTML.manifest&lt;/xsl:param&gt;
-    </programlisting>
-  </refsynopsisdiv>
-
-  <refsection><info><title>Description</title></info>
-
-    <para>The name of the file to which a manifest is written (if the
-      value of the <parameter>generate.manifest</parameter> parameter
-      is non-zero).</para>
-
-  </refsection>
-</refentry>
-
-<refentry version="5.0" id="manifest.in.base.dir">
-<refmeta>
-<refentrytitle>manifest.in.base.dir</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>manifest.in.base.dir</refname>
-<refpurpose>Should the manifest file be written into <parameter>base.dir</parameter>?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="manifest.in.base.dir.frag">
-&lt;xsl:param name="manifest.in.base.dir" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, the manifest file as well as project files for HTML Help and
-Eclipse Help are written into <parameter>base.dir</parameter> instead
-of the current directory.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="chunk.toc">
-<refmeta>
-<refentrytitle>chunk.toc</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>chunk.toc</refname>
-<refpurpose>An explicit TOC to be used for chunking</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="chunk.toc.frag">
-&lt;xsl:param name="chunk.toc"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The <parameter>chunk.toc</parameter> identifies an explicit TOC that
-will be used for chunking. This parameter is only used by the
-<filename>chunktoc.xsl</filename> stylesheet (and customization layers built
-from it).</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="chunk.tocs.and.lots">
-<refmeta>
-<refentrytitle>chunk.tocs.and.lots</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>chunk.tocs.and.lots</refname>
-<refpurpose>Should ToC and LoTs be in separate chunks?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="chunk.tocs.and.lots.frag">
-&lt;xsl:param name="chunk.tocs.and.lots" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, ToC and LoT (List of Examples, List of Figures, etc.)
-will be put in a separate chunk. At the moment, this chunk is not in the
-normal forward/backward navigation list. Instead, a new link is added to the
-navigation footer.</para>
-
-<para>This feature is still somewhat experimental. Feedback welcome.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="chunk.separate.lots">
-<refmeta>
-<refentrytitle>chunk.separate.lots</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>chunk.separate.lots</refname>
-<refpurpose>Should each LoT be in its own separate chunk?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="chunk.separate.lots.frag">
-&lt;xsl:param name="chunk.separate.lots" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, each of the ToC and LoTs
-(List of Examples, List of Figures, etc.)
-will be put in its own separate chunk.
-The title page includes generated links to each of the separate files.
-</para>
-<para>
-This feature depends on the
-<parameter>chunk.tocs.and.lots</parameter>
-parameter also being non-zero. 
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="chunk.tocs.and.lots.has.title">
-<refmeta>
-<refentrytitle>chunk.tocs.and.lots.has.title</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>chunk.tocs.and.lots.has.title</refname>
-<refpurpose>Should ToC and LoTs in a separate chunks have title?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="chunk.tocs.and.lots.has.title.frag">
-&lt;xsl:param name="chunk.tocs.and.lots.has.title" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero title of document is shown before ToC/LoT in
-separate chunk.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="chunk.section.depth">
-<refmeta>
-<refentrytitle>chunk.section.depth</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">integer</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>chunk.section.depth</refname>
-<refpurpose>Depth to which sections should be chunked</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="chunk.section.depth.frag">
-&lt;xsl:param name="chunk.section.depth" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This parameter sets the depth of section chunking.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="chunk.first.sections">
-<refmeta>
-<refentrytitle>chunk.first.sections</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>chunk.first.sections</refname>
-<refpurpose>Chunk the first top-level section?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="chunk.first.sections.frag">
-&lt;xsl:param name="chunk.first.sections" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, a chunk will be created for the first top-level
-<tag>sect1</tag> or <tag>section</tag> elements in
-each component. Otherwise, that section will be part of the chunk for
-its parent.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="chunk.quietly">
-<refmeta>
-<refentrytitle>chunk.quietly</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>chunk.quietly</refname>
-<refpurpose>Omit the chunked filename messages.</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="chunk.quietly.frag">
-&lt;xsl:param name="chunk.quietly" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If zero (the default), the XSL processor emits a message naming
-each separate chunk filename as it is being output.
-If nonzero, then the messages are suppressed.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="chunk.append">
-<refmeta>
-<refentrytitle>chunk.append</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>chunk.append</refname>
-<refpurpose>Specifies content to append to chunked HTML output</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="chunk.append.frag">&lt;xsl:param name="chunk.append"&gt;&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Specifies content to append to the end of HTML files output by
-the <filename>html/chunk.xsl</filename> stylesheet, after the closing
-<code>&lt;html&gt;</code> tag. You probably don&#8217;t want to set any value
-for this parameter; but if you do, the only value it should ever be
-set to is a newline character: <code>&amp;#x0a;</code> or
-<code>&amp;#10;</code></para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="navig.graphics">
-<refmeta>
-<refentrytitle>navig.graphics</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>navig.graphics</refname>
-<refpurpose>Use graphics in navigational headers and footers?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="navig.graphics.frag">
-&lt;xsl:param name="navig.graphics" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, the navigational headers and footers in chunked
-HTML are presented in an alternate style that uses graphical icons for
-Next, Previous, Up, and Home.  Default graphics are provided in the
-distribution. If zero, text is used instead of graphics.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="navig.graphics.extension">
-<refmeta>
-<refentrytitle>navig.graphics.extension</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>navig.graphics.extension</refname>
-<refpurpose>Extension for navigational graphics</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="navig.graphics.extension.frag">
-&lt;xsl:param name="navig.graphics.extension"&gt;.gif&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Sets the filename extension to use on navigational graphics used
-in the headers and footers of chunked HTML.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="navig.graphics.path">
-<refmeta>
-<refentrytitle>navig.graphics.path</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>navig.graphics.path</refname>
-<refpurpose>Path to navigational graphics</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="navig.graphics.path.frag">
-&lt;xsl:param name="navig.graphics.path"&gt;images/&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Sets the path, probably relative to the directory where the HTML
-files are created, to the navigational graphics used in the
-headers and footers of chunked HTML.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="navig.showtitles">
-<refmeta>
-<refentrytitle>navig.showtitles</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>navig.showtitles</refname>
-<refpurpose>Display titles in HTML headers and footers?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="navig.showtitles.frag">&lt;xsl:param name="navig.showtitles"&gt;1&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero,
-the headers and footers of chunked HTML
-display the titles of the next and previous chunks,
-along with the words 'Next' and 'Previous' (or the
-equivalent graphical icons if navig.graphics is true).
-If false (zero), then only the words 'Next' and 'Previous'
-(or the icons) are displayed.
-</para>
-
-</refsection>
-</refentry>
-
-</reference><reference id="profiling" xml:base="../html/param.xml"><title>Profiling</title>
-<partintro id="partintro">
-<para>The following parameters can be used for attribute-based
-profiling of your document. For more information about profiling, see 
-<link role="tcg" xlink:href="Profiling.html">Profiling (conditional text)</link>.</para>
-</partintro>
-<refentry version="5.0" id="profile.arch">
-<refmeta>
-<refentrytitle>profile.arch</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>profile.arch</refname>
-<refpurpose>Target profile for <tag class="attribute">arch</tag>
-attribute</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="profile.arch.frag">
-&lt;xsl:param name="profile.arch"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-
-<refsection><info><title>Description</title></info>
-
-<para>The value of this parameter specifies profiles which should be
-included in the output. You can specify multiple profiles by
-separating them by semicolon. You can change separator character by
-<parameter>profile.separator</parameter>
-parameter.</para>
-
-<para>This parameter has effect only when you are using profiling
-stylesheets (<filename>profile-docbook.xsl</filename>,
-<filename>profile-chunk.xsl</filename>, &#8230;) instead of normal
-ones (<filename>docbook.xsl</filename>,
-<filename>chunk.xsl</filename>, &#8230;).</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="profile.audience">
-<refmeta>
-<refentrytitle>profile.audience</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>profile.audience</refname>
-<refpurpose>Target profile for <tag class="attribute">audience</tag>
-attribute</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="profile.audience.frag">
-&lt;xsl:param name="profile.audience"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Value of this parameter specifies profiles which should be
-included in the output. You can specify multiple profiles by
-separating them by semicolon. You can change separator character by
-<parameter>profile.separator</parameter>
-parameter.</para>
-
-<para>This parameter has effect only when you are using profiling
-stylesheets (<filename>profile-docbook.xsl</filename>,
-<filename>profile-chunk.xsl</filename>, &#8230;) instead of normal
-ones (<filename>docbook.xsl</filename>,
-<filename>chunk.xsl</filename>, &#8230;).</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="profile.condition">
-<refmeta>
-<refentrytitle>profile.condition</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>profile.condition</refname>
-<refpurpose>Target profile for <tag class="attribute">condition</tag>
-attribute</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="profile.condition.frag">
-&lt;xsl:param name="profile.condition"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The value of this parameter specifies profiles which should be
-included in the output. You can specify multiple profiles by
-separating them by semicolon. You can change separator character by
-<parameter>profile.separator</parameter>
-parameter.</para>
-
-<para>This parameter has effect only when you are using profiling
-stylesheets (<filename>profile-docbook.xsl</filename>,
-<filename>profile-chunk.xsl</filename>, &#8230;) instead of normal
-ones (<filename>docbook.xsl</filename>,
-<filename>chunk.xsl</filename>, &#8230;).</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="profile.conformance">
-<refmeta>
-<refentrytitle>profile.conformance</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>profile.conformance</refname>
-<refpurpose>Target profile for <tag class="attribute">conformance</tag>
-attribute</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="profile.conformance.frag">
-&lt;xsl:param name="profile.conformance"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The value of this parameter specifies profiles which should be
-included in the output. You can specify multiple profiles by
-separating them by semicolon. You can change separator character by
-<parameter>profile.separator</parameter>
-parameter.</para>
-
-<para>This parameter has effect only when you are using profiling
-stylesheets (<filename>profile-docbook.xsl</filename>,
-<filename>profile-chunk.xsl</filename>, &#8230;) instead of normal
-ones (<filename>docbook.xsl</filename>,
-<filename>chunk.xsl</filename>, &#8230;).</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="profile.lang">
-<refmeta>
-<refentrytitle>profile.lang</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>profile.lang</refname>
-<refpurpose>Target profile for <tag class="attribute">lang</tag>
-attribute</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="profile.lang.frag">
-&lt;xsl:param name="profile.lang"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The value of this parameter specifies profiles which should be
-included in the output. You can specify multiple profiles by
-separating them by semicolon. You can change separator character by
-<parameter>profile.separator</parameter>
-parameter.</para>
-
-<para>This parameter has effect only when you are using profiling
-stylesheets (<filename>profile-docbook.xsl</filename>,
-<filename>profile-chunk.xsl</filename>, &#8230;) instead of normal
-ones (<filename>docbook.xsl</filename>,
-<filename>chunk.xsl</filename>, &#8230;).</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="profile.os">
-<refmeta>
-<refentrytitle>profile.os</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>profile.os</refname>
-<refpurpose>Target profile for <tag class="attribute">os</tag>
-attribute</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="profile.os.frag">
-&lt;xsl:param name="profile.os"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The value of this parameter specifies profiles which should be
-included in the output. You can specify multiple profiles by
-separating them by semicolon. You can change separator character by
-<parameter>profile.separator</parameter>
-parameter.</para>
-
-<para>This parameter has effect only when you are using profiling
-stylesheets (<filename>profile-docbook.xsl</filename>,
-<filename>profile-chunk.xsl</filename>, &#8230;) instead of normal
-ones (<filename>docbook.xsl</filename>,
-<filename>chunk.xsl</filename>, &#8230;).</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="profile.revision">
-<refmeta>
-<refentrytitle>profile.revision</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>profile.revision</refname>
-<refpurpose>Target profile for <tag class="attribute">revision</tag>
-attribute</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="profile.revision.frag">
-&lt;xsl:param name="profile.revision"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The value of this parameter specifies profiles which should be
-included in the output. You can specify multiple profiles by
-separating them by semicolon. You can change separator character by
-<parameter>profile.separator</parameter>
-parameter.</para>
-
-<para>This parameter has effect only when you are using profiling
-stylesheets (<filename>profile-docbook.xsl</filename>,
-<filename>profile-chunk.xsl</filename>, &#8230;) instead of normal
-ones (<filename>docbook.xsl</filename>,
-<filename>chunk.xsl</filename>, &#8230;).</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="profile.revisionflag">
-<refmeta>
-<refentrytitle>profile.revisionflag</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>profile.revisionflag</refname>
-<refpurpose>Target profile for <tag class="attribute">revisionflag</tag>
-attribute</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="profile.revisionflag.frag">
-&lt;xsl:param name="profile.revisionflag"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The value of this parameter specifies profiles which should be
-included in the output. You can specify multiple profiles by
-separating them by semicolon. You can change separator character by
-<parameter>profile.separator</parameter>
-parameter.</para>
-
-<para>This parameter has effect only when you are using profiling
-stylesheets (<filename>profile-docbook.xsl</filename>,
-<filename>profile-chunk.xsl</filename>, &#8230;) instead of normal
-ones (<filename>docbook.xsl</filename>,
-<filename>chunk.xsl</filename>, &#8230;).</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="profile.role">
-<refmeta>
-<refentrytitle>profile.role</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>profile.role</refname>
-<refpurpose>Target profile for <tag class="attribute">role</tag>
-attribute</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="profile.role.frag">
-&lt;xsl:param name="profile.role"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The value of this parameter specifies profiles which should be
-included in the output. You can specify multiple profiles by
-separating them by semicolon. You can change separator character by
-<parameter>profile.separator</parameter>
-parameter.</para>
-
-<para>This parameter has effect only when you are using profiling
-stylesheets (<filename>profile-docbook.xsl</filename>,
-<filename>profile-chunk.xsl</filename>, &#8230;) instead of normal
-ones (<filename>docbook.xsl</filename>,
-<filename>chunk.xsl</filename>, &#8230;).</para>
-
-<warning>
-<para>Note that <tag class="attribute">role</tag> is often
-used for other purposes than profiling. For example it is commonly
-used to get emphasize in bold font:</para>
-
-<programlisting>&lt;emphasis role="bold"&gt;very important&lt;/emphasis&gt;</programlisting>
-
-<para>If you are using <tag class="attribute">role</tag> for
-these purposes do not forget to add values like <literal>bold</literal> to
-value of this parameter. If you forgot you will get document with
-small pieces missing which are very hard to track.</para>
-
-<para>For this reason it is not recommended to use <tag class="attribute">role</tag> attribute for profiling. You should
-rather use profiling specific attributes like <tag class="attribute">userlevel</tag>, <tag class="attribute">os</tag>, <tag class="attribute">arch</tag>, <tag class="attribute">condition</tag>, etc.</para>
-</warning>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="profile.security">
-<refmeta>
-<refentrytitle>profile.security</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>profile.security</refname>
-<refpurpose>Target profile for <tag class="attribute">security</tag>
-attribute</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="profile.security.frag">
-&lt;xsl:param name="profile.security"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The value of this parameter specifies profiles which should be
-included in the output. You can specify multiple profiles by
-separating them by semicolon. You can change separator character by
-<parameter>profile.separator</parameter>
-parameter.</para>
-
-<para>This parameter has effect only when you are using profiling
-stylesheets (<filename>profile-docbook.xsl</filename>,
-<filename>profile-chunk.xsl</filename>, &#8230;) instead of normal
-ones (<filename>docbook.xsl</filename>,
-<filename>chunk.xsl</filename>, &#8230;).</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="profile.status">
-<refmeta>
-<refentrytitle>profile.status</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>profile.status</refname>
-<refpurpose>Target profile for <tag class="attribute">status</tag>
-attribute</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="profile.status.frag">
-&lt;xsl:param name="profile.status"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The value of this parameter specifies profiles which should be
-included in the output. You can specify multiple profiles by
-separating them by semicolon. You can change separator character by
-<parameter>profile.separator</parameter>
-parameter.</para>
-
-<para>This parameter has effect only when you are using profiling
-stylesheets (<filename>profile-docbook.xsl</filename>,
-<filename>profile-chunk.xsl</filename>, &#8230;) instead of normal
-ones (<filename>docbook.xsl</filename>,
-<filename>chunk.xsl</filename>, &#8230;).</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="profile.userlevel">
-<refmeta>
-<refentrytitle>profile.userlevel</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>profile.userlevel</refname>
-<refpurpose>Target profile for <tag class="attribute">userlevel</tag>
-attribute</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="profile.userlevel.frag">
-&lt;xsl:param name="profile.userlevel"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The value of this parameter specifies profiles which should be
-included in the output. You can specify multiple profiles by
-separating them by semicolon. You can change separator character by
-<parameter>profile.separator</parameter>
-parameter.</para>
-
-<para>This parameter has effect only when you are using profiling
-stylesheets (<filename>profile-docbook.xsl</filename>,
-<filename>profile-chunk.xsl</filename>, &#8230;) instead of normal
-ones (<filename>docbook.xsl</filename>,
-<filename>chunk.xsl</filename>, &#8230;).</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="profile.vendor">
-<refmeta>
-<refentrytitle>profile.vendor</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>profile.vendor</refname>
-<refpurpose>Target profile for <tag class="attribute">vendor</tag>
-attribute</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="profile.vendor.frag">
-&lt;xsl:param name="profile.vendor"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The value of this parameter specifies profiles which should be
-included in the output. You can specify multiple profiles by
-separating them by semicolon. You can change separator character by
-<parameter>profile.separator</parameter>
-parameter.</para>
-
-<para>This parameter has effect only when you are using profiling
-stylesheets (<filename>profile-docbook.xsl</filename>,
-<filename>profile-chunk.xsl</filename>, &#8230;) instead of normal
-ones (<filename>docbook.xsl</filename>,
-<filename>chunk.xsl</filename>, &#8230;).</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="profile.wordsize">
-<refmeta>
-<refentrytitle>profile.wordsize</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>profile.wordsize</refname>
-<refpurpose>Target profile for <tag class="attribute">wordsize</tag>
-attribute</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="profile.wordsize.frag">
-&lt;xsl:param name="profile.wordsize"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The value of this parameter specifies profiles which should be
-included in the output. You can specify multiple profiles by
-separating them by semicolon. You can change separator character by
-<parameter>profile.separator</parameter>
-parameter.</para>
-
-<para>This parameter has effect only when you are using profiling
-stylesheets (<filename>profile-docbook.xsl</filename>,
-<filename>profile-chunk.xsl</filename>, &#8230;) instead of normal
-ones (<filename>docbook.xsl</filename>,
-<filename>chunk.xsl</filename>, &#8230;).</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="profile.attribute">
-<refmeta>
-<refentrytitle>profile.attribute</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>profile.attribute</refname>
-<refpurpose>Name of user-specified profiling attribute</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="profile.attribute.frag">
-&lt;xsl:param name="profile.attribute"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This parameter is used in conjuction with
-<parameter>profile.value</parameter>.</para>
-
-<para>This parameter has effect only when you are using profiling
-stylesheets (<filename>profile-docbook.xsl</filename>,
-<filename>profile-chunk.xsl</filename>, &#8230;) instead of normal
-ones (<filename>docbook.xsl</filename>,
-<filename>chunk.xsl</filename>, &#8230;).</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="profile.value">
-<refmeta>
-<refentrytitle>profile.value</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>profile.value</refname>
-<refpurpose>Target profile for user-specified attribute</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="profile.value.frag">
-&lt;xsl:param name="profile.value"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>When you are using this parameter you must also specify name of
-profiling attribute with parameter
-<parameter>profile.attribute</parameter>.</para>
-
-<para>The value of this parameter specifies profiles which should be
-included in the output. You can specify multiple profiles by
-separating them by semicolon. You can change separator character by
-<parameter>profile.separator</parameter>
-parameter.</para>
-
-<para>This parameter has effect only when you are using profiling
-stylesheets (<filename>profile-docbook.xsl</filename>,
-<filename>profile-chunk.xsl</filename>, &#8230;) instead of normal
-ones (<filename>docbook.xsl</filename>,
-<filename>chunk.xsl</filename>, &#8230;).</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="profile.separator">
-<refmeta>
-<refentrytitle>profile.separator</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>profile.separator</refname>
-<refpurpose>Separator character for compound profile values</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="profile.separator.frag">
-&lt;xsl:param name="profile.separator"&gt;;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Separator character used for compound profile values. See <parameter>profile.arch</parameter></para>
-
-</refsection>
-</refentry>
-
-</reference><reference id="htmlhelp" xml:base="../html/param.xml"><title>HTML Help</title>
-<refentry version="5.0" id="htmlhelp.encoding">
-<refmeta>
-<refentrytitle>htmlhelp.encoding</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>htmlhelp.encoding</refname>
-<refpurpose>Character encoding to use in files for HTML Help compiler.</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="htmlhelp.encoding.frag">
-&lt;xsl:param name="htmlhelp.encoding"&gt;iso-8859-1&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The HTML Help Compiler is not UTF-8 aware, so you should always use an
-appropriate single-byte encoding here. See also <link xlink:href="HtmlHelp.html#HelpProcOptions" role="tcg">Processing options</link>.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="htmlhelp.autolabel">
-<refmeta>
-<refentrytitle>htmlhelp.autolabel</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>htmlhelp.autolabel</refname>
-<refpurpose>Should tree-like ToC use autonumbering feature?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="htmlhelp.autolabel.frag">
-&lt;xsl:param name="htmlhelp.autolabel" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Set this to non-zero to include chapter and section numbers into ToC
-in the left panel.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="htmlhelp.chm">
-<refmeta>
-<refentrytitle>htmlhelp.chm</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>htmlhelp.chm</refname>
-<refpurpose>Filename of output HTML Help file.</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="htmlhelp.chm.frag">
-&lt;xsl:param name="htmlhelp.chm"&gt;htmlhelp.chm&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Set the  name of resulting CHM file</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="htmlhelp.default.topic">
-<refmeta>
-<refentrytitle>htmlhelp.default.topic</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>htmlhelp.default.topic</refname>
-<refpurpose>Name of file with default topic</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="htmlhelp.default.topic.frag">
-&lt;xsl:param name="htmlhelp.default.topic"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Normally first chunk of document is displayed when you open HTML
-Help file. If you want to display another topic, simply set its
-filename by this parameter.</para>
-
-<para>This is useful especially if you don't generate ToC in front of
-your document and you also hide root element in ToC. E.g.:</para>
-
-<programlisting>&lt;xsl:param name="generate.book.toc" select="0"/&gt;
-&lt;xsl:param name="htmlhelp.hhc.show.root" select="0"/&gt;
-&lt;xsl:param name="htmlhelp.default.topic"&gt;pr01.html&lt;/xsl:param&gt;
-</programlisting>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="htmlhelp.display.progress">
-<refmeta>
-<refentrytitle>htmlhelp.display.progress</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>htmlhelp.display.progress</refname>
-<refpurpose>Display compile progress?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="htmlhelp.display.progress.frag">
-&lt;xsl:param name="htmlhelp.display.progress" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Set to non-zero to to display compile progress
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="htmlhelp.hhp">
-<refmeta>
-<refentrytitle>htmlhelp.hhp</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>htmlhelp.hhp</refname>
-<refpurpose>Filename of project file.</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="htmlhelp.hhp.frag">
-&lt;xsl:param name="htmlhelp.hhp"&gt;htmlhelp.hhp&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Change this parameter if you want different name of project
-file than htmlhelp.hhp.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="htmlhelp.hhc">
-<refmeta>
-<refentrytitle>htmlhelp.hhc</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>htmlhelp.hhc</refname>
-<refpurpose>Filename of TOC file.</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="htmlhelp.hhc.frag">
-&lt;xsl:param name="htmlhelp.hhc"&gt;toc.hhc&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Set the name of the TOC file. The default is <filename>toc.hhc</filename>.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="htmlhelp.hhk">
-<refmeta>
-<refentrytitle>htmlhelp.hhk</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>htmlhelp.hhk</refname>
-<refpurpose>Filename of index file.</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="htmlhelp.hhk.frag">
-&lt;xsl:param name="htmlhelp.hhk"&gt;index.hhk&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>set the name of the index file. The default is <filename>index.hhk</filename>.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="htmlhelp.hhp.tail">
-<refmeta>
-<refentrytitle>htmlhelp.hhp.tail</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>htmlhelp.hhp.tail</refname>
-<refpurpose>Additional content for project file.</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="htmlhelp.hhp.tail.frag">
-&lt;xsl:param name="htmlhelp.hhp.tail"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If you want to include some additional parameters into project file,
-store appropriate part of project file into this parameter.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="htmlhelp.hhp.window">
-<refmeta>
-<refentrytitle>htmlhelp.hhp.window</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>htmlhelp.hhp.window</refname>
-<refpurpose>Name of default window.</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="htmlhelp.hhp.window.frag">
-&lt;xsl:param name="htmlhelp.hhp.window"&gt;Main&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Name of default window. If empty no [WINDOWS] section will be
-added to project file.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="htmlhelp.hhp.windows">
-<refmeta>
-<refentrytitle>htmlhelp.hhp.windows</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>htmlhelp.hhp.windows</refname>
-<refpurpose>Definition of additional windows</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="htmlhelp.hhp.windows.frag">
-&lt;xsl:param name="htmlhelp.hhp.windows"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Content of this parameter is placed at the end of [WINDOWS]
-section of project file. You can use it for defining your own
-addtional windows.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="htmlhelp.enhanced.decompilation">
-<refmeta>
-<refentrytitle>htmlhelp.enhanced.decompilation</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>htmlhelp.enhanced.decompilation</refname>
-<refpurpose>Allow enhanced decompilation of CHM?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="htmlhelp.enhanced.decompilation.frag">
-&lt;xsl:param name="htmlhelp.enhanced.decompilation" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>When non-zero this parameter enables enhanced decompilation of CHM.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="htmlhelp.enumerate.images">
-<refmeta>
-<refentrytitle>htmlhelp.enumerate.images</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>htmlhelp.enumerate.images</refname>
-<refpurpose>Should the paths to all used images be added to the project file?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="htmlhelp.enumerate.images.frag">
-&lt;xsl:param name="htmlhelp.enumerate.images" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Set to non-zero if you insert images into your documents as
-external binary entities or if you are using absolute image paths.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="htmlhelp.force.map.and.alias">
-<refmeta>
-<refentrytitle>htmlhelp.force.map.and.alias</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>htmlhelp.force.map.and.alias</refname>
-<refpurpose>Should [MAP] and [ALIAS] sections be added to the project file unconditionally?</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-<programlisting id="htmlhelp.force.map.and.alias.frag">
-&lt;xsl:param name="htmlhelp.force.map.and.alias" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-<refsection><info><title>Description</title></info>
-  <para>Set to non-zero if you have your own
-    <literal>alias.h</literal> and <literal>context.h</literal>
-    files and you want to include references to them in the project
-    file.</para>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="htmlhelp.map.file">
-<refmeta>
-<refentrytitle>htmlhelp.map.file</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>htmlhelp.map.file</refname>
-<refpurpose>Filename of map file.</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-<programlisting id="htmlhelp.map.file.frag">
-&lt;xsl:param name="htmlhelp.map.file"&gt;context.h&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-<refsection><info><title>Description</title></info>
-<para>Set the name of map file. The default is
-  <filename>context.h</filename>. (used for context-sensitive
-  help).</para>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="htmlhelp.alias.file">
-<refmeta>
-<refentrytitle>htmlhelp.alias.file</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>htmlhelp.alias.file</refname>
-<refpurpose>Filename of alias file.</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="htmlhelp.alias.file.frag">
-&lt;xsl:param name="htmlhelp.alias.file"&gt;alias.h&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Specifies the filename of the alias file (used for context-sensitive help).</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="htmlhelp.hhc.section.depth">
-<refmeta>
-<refentrytitle>htmlhelp.hhc.section.depth</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">integer</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>htmlhelp.hhc.section.depth</refname>
-<refpurpose>Depth of TOC for sections in a left pane.</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="htmlhelp.hhc.section.depth.frag">
-&lt;xsl:param name="htmlhelp.hhc.section.depth"&gt;5&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Set the section depth in the left pane of HTML Help viewer. </para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="htmlhelp.hhc.show.root">
-<refmeta>
-<refentrytitle>htmlhelp.hhc.show.root</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>htmlhelp.hhc.show.root</refname>
-<refpurpose>Should there be an entry for the root element in the ToC?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="htmlhelp.hhc.show.root.frag">
-&lt;xsl:param name="htmlhelp.hhc.show.root" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If set to zero, there will be no entry for the root element in the 
-ToC. This is useful when you want to provide the user with an expanded
-ToC as a default.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="htmlhelp.hhc.folders.instead.books">
-<refmeta>
-<refentrytitle>htmlhelp.hhc.folders.instead.books</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>htmlhelp.hhc.folders.instead.books</refname>
-<refpurpose>Use folder icons in ToC (instead of book icons)?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="htmlhelp.hhc.folders.instead.books.frag">
-&lt;xsl:param name="htmlhelp.hhc.folders.instead.books" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Set to non-zero for folder-like icons or zero for book-like icons in the ToC. 
-If you want to use folder-like icons, you must switch off the binary ToC using 
-<parameter>htmlhelp.hhc.binary</parameter>.
-
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="htmlhelp.hhc.binary">
-<refmeta>
-<refentrytitle>htmlhelp.hhc.binary</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>htmlhelp.hhc.binary</refname>
-<refpurpose>Generate binary ToC?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="htmlhelp.hhc.binary.frag">
-&lt;xsl:param name="htmlhelp.hhc.binary" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Set to non-zero to generate a binary TOC. You must create a binary TOC
-if you want to add Prev/Next buttons to toolbar (which is default
-behaviour). Files with binary TOC can't be merged.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="htmlhelp.hhc.width">
-<refmeta>
-<refentrytitle>htmlhelp.hhc.width</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">integer</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>htmlhelp.hhc.width</refname>
-<refpurpose>Width of navigation pane</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="htmlhelp.hhc.width.frag">
-&lt;xsl:param name="htmlhelp.hhc.width"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This parameter specifies the width of the navigation pane (containing TOC and
-other navigation tabs) in pixels.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="htmlhelp.title">
-<refmeta>
-<refentrytitle>htmlhelp.title</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>htmlhelp.title</refname>
-<refpurpose>Title of HTML Help</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="htmlhelp.title.frag">
-&lt;xsl:param name="htmlhelp.title"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Content of this parameter will be used as a title for generated
-HTML Help. If empty, title will be automatically taken from document.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="htmlhelp.show.menu">
-<refmeta>
-<refentrytitle>htmlhelp.show.menu</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>htmlhelp.show.menu</refname>
-<refpurpose>Should the menu bar be shown?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="htmlhelp.show.menu.frag">
-&lt;xsl:param name="htmlhelp.show.menu" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Set to non-zero to have an application menu bar in your HTML Help window.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="htmlhelp.show.toolbar.text">
-<refmeta>
-<refentrytitle>htmlhelp.show.toolbar.text</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>htmlhelp.show.toolbar.text</refname>
-<refpurpose>Show text under toolbar buttons?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="htmlhelp.show.toolbar.text.frag">
-&lt;xsl:param name="htmlhelp.show.toolbar.text" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Set to non-zero to display texts under toolbar buttons, zero to switch
-off displays.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="htmlhelp.show.advanced.search">
-<refmeta>
-<refentrytitle>htmlhelp.show.advanced.search</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>htmlhelp.show.advanced.search</refname>
-<refpurpose>Should advanced search features be available?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="htmlhelp.show.advanced.search.frag">
-&lt;xsl:param name="htmlhelp.show.advanced.search" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If you want advanced search features in your help, turn this
-parameter to 1.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="htmlhelp.show.favorities">
-<refmeta>
-<refentrytitle>htmlhelp.show.favorities</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>htmlhelp.show.favorities</refname>
-<refpurpose>Should the Favorites tab be shown?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="htmlhelp.show.favorities.frag">
-&lt;xsl:param name="htmlhelp.show.favorities" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Set to non-zero to include a Favorites tab in the navigation pane 
-of the help window.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="htmlhelp.button.hideshow">
-<refmeta>
-<refentrytitle>htmlhelp.button.hideshow</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>htmlhelp.button.hideshow</refname>
-<refpurpose>Should the Hide/Show button be shown?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="htmlhelp.button.hideshow.frag">
-&lt;xsl:param name="htmlhelp.button.hideshow" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Set to non-zero to include the  Hide/Show button shown on toolbar</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="htmlhelp.button.back">
-<refmeta>
-<refentrytitle>htmlhelp.button.back</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>htmlhelp.button.back</refname>
-<refpurpose>Should the Back button be shown?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="htmlhelp.button.back.frag">
-&lt;xsl:param name="htmlhelp.button.back" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Set to non-zero to include the  Hide/Show button shown on toolbar</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="htmlhelp.button.forward">
-<refmeta>
-<refentrytitle>htmlhelp.button.forward</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>htmlhelp.button.forward</refname>
-<refpurpose>Should the Forward button be shown?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="htmlhelp.button.forward.frag">
-&lt;xsl:param name="htmlhelp.button.forward" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Set to non-zero to include the  Forward button  on the toolbar.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="htmlhelp.button.stop">
-<refmeta>
-<refentrytitle>htmlhelp.button.stop</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>htmlhelp.button.stop</refname>
-<refpurpose>Should the Stop button be shown?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="htmlhelp.button.stop.frag">
-&lt;xsl:param name="htmlhelp.button.stop" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If you want Stop button shown on toolbar, turn this
-parameter to 1.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="htmlhelp.button.refresh">
-<refmeta>
-<refentrytitle>htmlhelp.button.refresh</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>htmlhelp.button.refresh</refname>
-<refpurpose>Should the Refresh button be shown?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="htmlhelp.button.refresh.frag">
-&lt;xsl:param name="htmlhelp.button.refresh" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Set to non-zero to include the Stop button  on the toolbar.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="htmlhelp.button.home">
-<refmeta>
-<refentrytitle>htmlhelp.button.home</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>htmlhelp.button.home</refname>
-<refpurpose>Should the Home button be shown?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="htmlhelp.button.home.frag">
-&lt;xsl:param name="htmlhelp.button.home" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Set to non-zero to include the Home button  on the toolbar.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="htmlhelp.button.home.url">
-<refmeta>
-<refentrytitle>htmlhelp.button.home.url</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>htmlhelp.button.home.url</refname>
-<refpurpose>URL address of page accessible by Home button</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="htmlhelp.button.home.url.frag">
-&lt;xsl:param name="htmlhelp.button.home.url"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>URL address of page accessible by Home button.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="htmlhelp.button.options">
-<refmeta>
-<refentrytitle>htmlhelp.button.options</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>htmlhelp.button.options</refname>
-<refpurpose>Should the Options button be shown?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="htmlhelp.button.options.frag">
-&lt;xsl:param name="htmlhelp.button.options" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If you want Options button shown on toolbar, turn this
-parameter to 1.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="htmlhelp.button.print">
-<refmeta>
-<refentrytitle>htmlhelp.button.print</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>htmlhelp.button.print</refname>
-<refpurpose>Should the Print button be shown?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="htmlhelp.button.print.frag">
-&lt;xsl:param name="htmlhelp.button.print" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Set to non-zero to include the Print button  on the toolbar.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="htmlhelp.button.locate">
-<refmeta>
-<refentrytitle>htmlhelp.button.locate</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>htmlhelp.button.locate</refname>
-<refpurpose>Should the Locate button be shown?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="htmlhelp.button.locate.frag">
-&lt;xsl:param name="htmlhelp.button.locate" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If you want Locate button shown on toolbar, turn this
-parameter to 1.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="htmlhelp.button.jump1">
-<refmeta>
-<refentrytitle>htmlhelp.button.jump1</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>htmlhelp.button.jump1</refname>
-<refpurpose>Should the Jump1 button be shown?</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-<programlisting id="htmlhelp.button.jump1.frag">
-&lt;xsl:param name="htmlhelp.button.jump1" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-<refsection><info><title>Description</title></info>
-  <para>Set to non-zero to include the <literal>Jump1</literal> button on the toolbar.</para>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="htmlhelp.button.jump1.url">
-<refmeta>
-<refentrytitle>htmlhelp.button.jump1.url</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>htmlhelp.button.jump1.url</refname>
-<refpurpose>URL address of page accessible by Jump1 button</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="htmlhelp.button.jump1.url.frag">
-&lt;xsl:param name="htmlhelp.button.jump1.url"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>URL address of page accessible by Jump1 button.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="htmlhelp.button.jump1.title">
-<refmeta>
-<refentrytitle>htmlhelp.button.jump1.title</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>htmlhelp.button.jump1.title</refname>
-<refpurpose>Title of Jump1 button</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="htmlhelp.button.jump1.title.frag">
-&lt;xsl:param name="htmlhelp.button.jump1.title"&gt;User1&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Title of Jump1 button.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="htmlhelp.button.jump2">
-<refmeta>
-<refentrytitle>htmlhelp.button.jump2</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>htmlhelp.button.jump2</refname>
-<refpurpose>Should the Jump2 button be shown?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="htmlhelp.button.jump2.frag">
-&lt;xsl:param name="htmlhelp.button.jump2" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Set to non-zero to include the Jump2 button  on the toolbar.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="htmlhelp.button.jump2.url">
-<refmeta>
-<refentrytitle>htmlhelp.button.jump2.url</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>htmlhelp.button.jump2.url</refname>
-<refpurpose>URL address of page accessible by Jump2 button</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="htmlhelp.button.jump2.url.frag">
-&lt;xsl:param name="htmlhelp.button.jump2.url"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>URL address of page accessible by Jump2 button.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="htmlhelp.button.jump2.title">
-<refmeta>
-<refentrytitle>htmlhelp.button.jump2.title</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>htmlhelp.button.jump2.title</refname>
-<refpurpose>Title of Jump2 button</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="htmlhelp.button.jump2.title.frag">
-&lt;xsl:param name="htmlhelp.button.jump2.title"&gt;User2&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Title of Jump2 button.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="htmlhelp.button.next">
-<refmeta>
-<refentrytitle>htmlhelp.button.next</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>htmlhelp.button.next</refname>
-<refpurpose>Should the Next button be shown?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="htmlhelp.button.next.frag">
-&lt;xsl:param name="htmlhelp.button.next" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Set to non-zero to include the Next button  on the toolbar.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="htmlhelp.button.prev">
-<refmeta>
-<refentrytitle>htmlhelp.button.prev</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>htmlhelp.button.prev</refname>
-<refpurpose>Should the Prev button be shown?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="htmlhelp.button.prev.frag">
-&lt;xsl:param name="htmlhelp.button.prev" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Set to non-zero to include the Prev button  on the toolbar.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="htmlhelp.button.zoom">
-<refmeta>
-<refentrytitle>htmlhelp.button.zoom</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>htmlhelp.button.zoom</refname>
-<refpurpose>Should the Zoom button be shown?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="htmlhelp.button.zoom.frag">
-&lt;xsl:param name="htmlhelp.button.zoom" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Set to non-zero to include the Zoom button  on the toolbar.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="htmlhelp.remember.window.position">
-<refmeta>
-<refentrytitle>htmlhelp.remember.window.position</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>htmlhelp.remember.window.position</refname>
-<refpurpose>Remember help window position?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="htmlhelp.remember.window.position.frag">
-&lt;xsl:param name="htmlhelp.remember.window.position" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Set to non-zero to remember help window position between starts.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="htmlhelp.window.geometry">
-<refmeta>
-<refentrytitle>htmlhelp.window.geometry</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>htmlhelp.window.geometry</refname>
-<refpurpose>Set initial geometry of help window</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="htmlhelp.window.geometry.frag">
-&lt;xsl:param name="htmlhelp.window.geometry"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This parameter specifies initial position of help
-window. E.g.</para>
-
-<programlisting>&lt;xsl:param name="htmlhelp.window.geometry"&gt;[160,64,992,704]&lt;/xsl:param&gt;</programlisting>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="htmlhelp.use.hhk">
-<refmeta>
-<refentrytitle>htmlhelp.use.hhk</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>htmlhelp.use.hhk</refname>
-<refpurpose>Should the index be built using the HHK file?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="htmlhelp.use.hhk.frag">
-&lt;xsl:param name="htmlhelp.use.hhk" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, the index is created using the HHK file (instead of using <tag role="html">object</tag>
-elements in the HTML files). For more information, see <link role="tcg" xlink:href="HtmlHelp.html#HHGenIndex">Generating an index</link>.</para>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="htmlhelp.only">
-<refmeta>
-<refentrytitle>htmlhelp.only</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>htmlhelp.only</refname>
-<refpurpose>Should only project files be generated?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="htmlhelp.only.frag">
-&lt;xsl:param name="htmlhelp.only" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-
-<para>Set to non-zero if you want to play with various HTML Help parameters
-and you don't need to regenerate all HTML files. This setting will not
-process whole document, only project files (hhp, hhc, hhk,...) will be
-generated.</para>
-
-
-</refsection>
-</refentry>
-
-</reference><reference id="eclipse_help" xml:base="../html/param.xml"><title>Eclipse Help Platform</title>
-<refentry version="5.0" id="eclipse.autolabel">
-<refmeta>
-<refentrytitle>eclipse.autolabel</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>eclipse.autolabel</refname>
-<refpurpose>Should tree-like ToC use autonumbering feature?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="eclipse.autolabel.frag">
-&lt;xsl:param name="eclipse.autolabel" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If you want to include chapter and section numbers into ToC in
-the left panel, set this parameter to 1.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="eclipse.plugin.name">
-<refmeta>
-<refentrytitle>eclipse.plugin.name</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>eclipse.plugin.name</refname>
-<refpurpose>Eclipse Help plugin name</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="eclipse.plugin.name.frag">
-&lt;xsl:param name="eclipse.plugin.name"&gt;DocBook Online Help Sample&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Eclipse Help plugin name.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="eclipse.plugin.id">
-<refmeta>
-<refentrytitle>eclipse.plugin.id</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>eclipse.plugin.id</refname>
-<refpurpose>Eclipse Help plugin id</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="eclipse.plugin.id.frag">
-&lt;xsl:param name="eclipse.plugin.id"&gt;com.example.help&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Eclipse Help plugin id. You should change this id to something
-unique for each help.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="eclipse.plugin.provider">
-<refmeta>
-<refentrytitle>eclipse.plugin.provider</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>eclipse.plugin.provider</refname>
-<refpurpose>Eclipse Help plugin provider name</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="eclipse.plugin.provider.frag">
-&lt;xsl:param name="eclipse.plugin.provider"&gt;Example provider&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Eclipse Help plugin provider name.</para>
-
-</refsection>
-</refentry>
-
-</reference><reference id="webhelp" xml:base="../html/param.xml"><title>WebHelp</title>
-<refentry version="5.0" id="webhelp.autolabel">
-<refmeta>
-<refentrytitle>webhelp.autolabel</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>webhelp.autolabel</refname>
-<refpurpose>Should tree-like ToC use autonumbering feature?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="webhelp.autolabel.frag">
-&lt;xsl:param name="webhelp.autolabel"&gt;0&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-<para>To include chapter and section numbers the table of contents pane, set this parameter to 1.</para>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="webhelp.base.dir">
-<refmeta>
-<refentrytitle>webhelp.base.dir</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>webhelp.base.dir</refname>
-<refpurpose>The base directory for webhelp output.</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="webhelp.base.dir.frag">
-&lt;xsl:param name="webhelp.base.dir"&gt;docs&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-<para>If specified, the <parameter>webhelp.base.dir</parameter>
-parameter identifies the output directory for webhelp. (If not
-specified, the output directory is system dependent.) By default, this
-parameter is set to <filename>docs</filename>.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="webhelp.common.dir">
-<refmeta>
-<refentrytitle>webhelp.common.dir</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>webhelp.common.dir</refname>
-<refpurpose>Path to the directory for the common webhelp resources (JavaScript, css, common images, etc).</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="webhelp.common.dir.frag">
-&lt;xsl:param name="webhelp.common.dir"&gt;../common/&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-<para>By default, webhelp creates a common directory containing resources such as JavaScript files, css, common images, etc. In some cases you may prefer to store these files in a standard location on your site and point all webhelp documents to that location. You can use this parameter to control the urls written to these common resources. For example, you might set this parameter to <code>/common</code> and create a single common directory at the root of your web server.  </para>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="webhelp.default.topic">
-<refmeta>
-<refentrytitle>webhelp.default.topic</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>webhelp.default.topic</refname>
-<refpurpose>The name of the file to which the start file in the webhelp base directory redirects</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="webhelp.default.topic.frag">
-&lt;xsl:param name="webhelp.default.topic"&gt;index.html&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-<para>Currently webhelp creates a base directory and puts the output
-files in a <filename>content</filename> subdirectory. It creates a
-file in the base directory that redirects to a configured file in the
-<filename>content</filename> directory. The
-<parameter>webhelp.default.topic</parameter> parameter lets you
-configure the name of the file that is redirected to.
-<note>
-  <para>This parameter will be removed from a future version of
-  webhelp along with the <filename>content</filename>
-  directory.</para>
-</note>
-</para>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="webhelp.include.search.tab">
-<refmeta>
-<refentrytitle>webhelp.include.search.tab</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>webhelp.include.search.tab</refname>
-<refpurpose>Should the webhelp output include a Search tab?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="webhelp.include.search.tab.frag">
-&lt;xsl:param name="webhelp.include.search.tab"&gt;1&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-<para>Set this parameter to 0 to suppress the search tab from webhelp output.</para>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="webhelp.indexer.language">
-<refmeta>
-<refentrytitle>webhelp.indexer.language</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype"/>
-</refmeta>
-<refnamediv>
-<refname>webhelp.indexer.language</refname>
-<refpurpose>The language to use for creating the webhelp search index.</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="webhelp.indexer.language.frag">
-&lt;xsl:param name="webhelp.indexer.language"&gt;en&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-<para>To support stemming in the client-side webhelp stemmer, you must provide the language code. By default, the following languages are supported:
-<itemizedlist>
-  <listitem>
-    <para><code>en</code>: English</para>
-  </listitem>
-  <listitem>
-    <para><code>de</code>: German</para>
-  </listitem>
-  <listitem>
-    <para><code>fr</code>: French</para>
-  </listitem>
-  <listitem>
-    <para><code>zh</code>: Chinese</para>
-  </listitem>
-  <listitem>
-    <para><code>ja</code>: Japanese</para>
-  </listitem>
-  <listitem>
-    <para><code>ko</code>: Korean</para>
-  </listitem>
-</itemizedlist>
-See the webhelp documentation for information on adding support for additional languages.
-</para>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="webhelp.start.filename">
-<refmeta>
-<refentrytitle>webhelp.start.filename</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>webhelp.start.filename</refname>
-<refpurpose>The name of the start file in the webhelp base directory.</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="webhelp.start.filename.frag">
-&lt;xsl:param name="webhelp.start.filename"&gt;index.html&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-<para>Currently webhelp creates a base directory and puts the output
-files in a <filename>content</filename> subdirectory. It creates a
-file in the base directory that redirects to a configured file in the
-<filename>content</filename> directory. The <parameter>webhelp.start.filename</parameter> parameter lets you configure the name of the redirect file.
-<note>
-  <para>This parameter will be removed from a future version of
-  webhelp along with the <filename>content</filename>
-  directory.</para>
-</note>
-</para>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="webhelp.tree.cookie.id">
-<refmeta>
-<refentrytitle>webhelp.tree.cookie.id</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>webhelp.tree.cookie.id</refname>
-<refpurpose>Controls how the cookie that stores the webhelp toc state is named.</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="webhelp.tree.cookie.id.frag">
-&lt;xsl:param name="webhelp.tree.cookie.id" select="concat( 'treeview-', count(//node()) )"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-<para>The webhelp output does not use a frameset. Instead, the table of contents is a div on each page. To preserve the state of the table of contents as the user navigates from page to page, webhelp stores the state in a cookie and reads that cookie when you get to the next page. If you've published several webhelp documents on the same domain, it is important that each cookie have a unique id. In lieu of calling on a GUID generator, by default this parameter is just set to the number of nodes in the document on the assumption that it is unlikely that you will have more than one document with the exact number of nodes. A more optimal solution would be for the user to pass in some unique, stable identifier from the build system to use as the webhelp cookie id. For example, if you have safeguards in place to ensure that the xml:id of the root element of each document will be unique on your site, then you could set webhelptree.cookie.id as follows:
-<programlisting>
-  &lt;xsl:param name="webhelp.tree.cookie.id"&gt;
-    &lt;xsl:choose&gt;
-      &lt;xsl:when test="/*/@xml:id"&gt;
-	&lt;xsl:value-of select="concat('treeview-',/*/@xml:id)"/&gt;
-      &lt;/xsl:when&gt;
-      &lt;xsl:otherwise&gt;
-	&lt;xsl:value-of select="concat( 'treeview-', count(//node()) )"/&gt;
-      &lt;/xsl:otherwise&gt;
-    &lt;/xsl:choose&gt;
-  &lt;/xsl:param&gt;
-  </programlisting>
- </para>
-</refsection>
-</refentry>
-
-</reference><reference id="javahelp" xml:base="../html/param.xml"><title>JavaHelp</title>
-<refentry version="5.0" id="javahelp.encoding">
-<refmeta>
-<refentrytitle>javahelp.encoding</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>javahelp.encoding</refname>
-<refpurpose>Character encoding to use in control files for JavaHelp.</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="javahelp.encoding.frag">
-&lt;xsl:param name="javahelp.encoding"&gt;iso-8859-1&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-  
-<para>JavaHelp crashes on some characters when written as character
-references. In that case you can use this parameter to select an appropriate encoding.</para>
-  
-</refsection>
-</refentry>
-
-
-
-
-</reference><reference id="l10n" xml:base="../html/param.xml"><title>Localization</title>
-<refentry version="5.0" id="l10n.gentext.language">
-<refmeta>
-<refentrytitle>l10n.gentext.language</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>l10n.gentext.language</refname>
-<refpurpose>Sets the gentext language</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="l10n.gentext.language.frag">
-&lt;xsl:param name="l10n.gentext.language"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If this parameter is set to any value other than the empty string, its
-value will be used as the value for the language when generating text. Setting
-<parameter>l10n.gentext.language</parameter> overrides any settings within the
-document being formatted.</para>
-
-<para>It's much more likely that you might want to set the
-<parameter>l10n.gentext.default.language</parameter> parameter.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="l10n.gentext.default.language">
-  <refmeta>
-    <refentrytitle>l10n.gentext.default.language</refentrytitle>
-    <refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-  </refmeta>
-  <refnamediv>
-    <refname>l10n.gentext.default.language</refname>
-    <refpurpose>Sets the default language for generated text</refpurpose>
-  </refnamediv>
-
-  <refsynopsisdiv>
-<programlisting id="l10n.gentext.default.language.frag">
-&lt;xsl:param name="l10n.gentext.default.language"&gt;en&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The value of the <parameter>l10n.gentext.default.language</parameter>
-parameter is used as the language for generated text if no setting is provided
-in the source document.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="l10n.gentext.use.xref.language">
-<refmeta>
-<refentrytitle>l10n.gentext.use.xref.language</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>l10n.gentext.use.xref.language</refname>
-<refpurpose>Use the language of target when generating cross-reference text?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="l10n.gentext.use.xref.language.frag">
-&lt;xsl:param name="l10n.gentext.use.xref.language" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, the language of the target will be used when
-generating cross reference text. Usually, the <quote>current</quote>
-language is used when generating text (that is, the language of the
-element that contains the cross-reference element). But setting this parameter
-allows the language of the element <emphasis>pointed to</emphasis> to control
-the generated text.</para>
-
-<para>Consider the following example:</para>
-
-<informalexample>
-<programlisting>&lt;para lang="en"&gt;See also &lt;xref linkend="chap3"/&gt;.&lt;/para&gt;
-</programlisting>
-</informalexample>
-
-<para>Suppose that Chapter 3 happens to be written in German.
-If <parameter>l10n.gentext.use.xref.language</parameter> is non-zero, the
-resulting text will be something like this:</para>
-
-<blockquote>
-<para>See also Kapital 3.</para>
-</blockquote>
-
-<para>Where the more traditional rendering would be:</para>
-
-<blockquote>
-<para>See also Chapter 3.</para>
-</blockquote>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="l10n.lang.value.rfc.compliant">
-<refmeta>
-<refentrytitle>l10n.lang.value.rfc.compliant</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>l10n.lang.value.rfc.compliant</refname>
-<refpurpose>Make value of lang attribute RFC compliant?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="l10n.lang.value.rfc.compliant.frag">
-&lt;xsl:param name="l10n.lang.value.rfc.compliant" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, ensure that the values for all <tag class="attribute">lang</tag> attributes in HTML output are RFC
-compliant<footnote><para>Section 8.1.1, <link xlink:href="http://www.w3.org/TR/REC-html40/struct/dirlang.html#h-8.1.1">Language Codes</link>, in the HTML 4.0 Recommendation states that:
-
-<blockquote><para>[RFC1766] defines and explains the language codes
-that must be used in HTML documents.</para>
-<para>Briefly, language codes consist of a primary code and a possibly
-empty series of subcodes:
-
-<literallayout class="monospaced">language-code = primary-code ( "-" subcode )*</literallayout>
-</para>
-<para>And in RFC 1766, <link xlink:href="http://www.ietf.org/rfc/rfc1766.txt">Tags for the Identification
-of Languages</link>, the EBNF for "language tag" is given as:
-
-<literallayout class="monospaced">Language-Tag = Primary-tag *( "-" Subtag )
-Primary-tag = 1*8ALPHA
-Subtag = 1*8ALPHA</literallayout>
-</para>
-</blockquote>
-</para></footnote>.
-
-by taking any underscore characters in any <tag class="attribute">lang</tag> values found in source documents, and
-replacing them with hyphen characters in output HTML files. For
-example, <literal>zh_CN</literal> in a source document becomes
-<literal>zh-CN</literal> in the HTML output form that source.
-
-<note>
-<para>This parameter does not cause any case change in <tag class="attribute">lang</tag> values, because RFC 1766
-explicitly states that all "language tags" (as it calls them) "are
-to be treated as case insensitive".</para>
-</note>
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="writing.mode">
-<refmeta>
-<refentrytitle>writing.mode</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>writing.mode</refname>
-<refpurpose>Direction of text flow based on locale</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="writing.mode.frag">
-&lt;xsl:param name="writing.mode"&gt;
-  &lt;xsl:call-template name="gentext"&gt;
-    &lt;xsl:with-param name="key"&gt;writing-mode&lt;/xsl:with-param&gt;
-    &lt;xsl:with-param name="lang"&gt;
-      &lt;xsl:call-template name="l10n.language"&gt;
-        &lt;xsl:with-param name="target" select="/*[1]"&gt;&lt;/xsl:with-param&gt;
-      &lt;/xsl:call-template&gt;
-    &lt;/xsl:with-param&gt;
-  &lt;/xsl:call-template&gt;
-&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Sets direction of text flow and text alignment based on locale.
-The value is normally taken from the gentext file for the 
-lang attribute of the document's root element, using the 
-key name 'writing-mode' to look it up in the gentext file.
-But this param can also be
-set on the command line to override that gentext value.
-</para>
-<para>Accepted values are:
-<variablelist>
-  <varlistentry>
-    <term>lr-tb</term>
-    <listitem>
-      <para>Left-to-right text flow in each line, lines stack top to bottom.</para>
-    </listitem>
-  </varlistentry>
-  <varlistentry>
-    <term>rl-tb</term>
-    <listitem>
-      <para>Right-to-left text flow in each line, lines stack top to bottom.</para>
-    </listitem>
-  </varlistentry>
-  <varlistentry>
-    <term>tb-rl</term>
-    <listitem>
-      <para>Top-to-bottom text flow in each vertical line, lines stack right to left.
-      Supported by only a few XSL-FO processors. Not supported in HTML output.</para>
-    </listitem>
-  </varlistentry>
-  <varlistentry>
-    <term>lr</term>
-    <listitem>
-      <para>Shorthand for lr-tb.</para>
-    </listitem>
-  </varlistentry>
-  <varlistentry>
-    <term>rl</term>
-    <listitem>
-      <para>Shorthand for rl-tb.</para>
-    </listitem>
-  </varlistentry>
-  <varlistentry>
-    <term>tb</term>
-    <listitem>
-      <para>Shorthand for tb-rl.</para>
-    </listitem>
-  </varlistentry>
-</variablelist>
-</para>
-
-</refsection>
-</refentry>
-
-</reference>
-    </part>
-    <part id="fo">
-      <?dbhtml dir="fo"?>
-      <?dbhtml filename="index.html"?>
-      <title xml:base="../fo/param.xml">FO Parameter Reference</title>
-      <partintro id="fointro">
-        
-  <para xml:base="../fo/param.xml">This is reference documentation for all user-configurable
-  parameters in the DocBook XSL FO stylesheets (for generating
-  XSL-FO output destined for final print/PDF output).</para>
-
-      </partintro>
-      <reference id="admons" xml:base="../fo/param.xml"><title>Admonitions</title>
-<refentry version="5.0" id="admon.graphics">
-<refmeta>
-<refentrytitle>admon.graphics</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>admon.graphics</refname>
-<refpurpose>Use graphics in admonitions?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="admon.graphics.frag">
-&lt;xsl:param name="admon.graphics" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If true (non-zero), admonitions are presented in an alternate style that uses
-a graphic.  Default graphics are provided in the distribution.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="admon.graphics.extension">
-<refmeta>
-<refentrytitle>admon.graphics.extension</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>admon.graphics.extension</refname>
-<refpurpose>Filename extension for admonition graphics</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="admon.graphics.extension.frag">
-&lt;xsl:param name="admon.graphics.extension"&gt;.png&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Sets the filename extension to use on admonition graphics.</para>
-
-<itemizedlist>
-  <para>The DocBook XSL distribution provides admonition graphics in the following formats:</para>
-  <listitem><para>GIF (extension: <filename class="extension">.gif</filename>)</para></listitem>
-  <listitem><para>PNG (extension: <filename class="extension">.png</filename>)</para></listitem>
-  <listitem><para>SVG (extension: <filename class="extension">.svg</filename>)</para></listitem>
-  <listitem><para>TIFF (extension: <filename class="extension">.tif</filename>)</para></listitem>
-</itemizedlist>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="admon.graphics.path">
-<refmeta>
-<refentrytitle>admon.graphics.path</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>admon.graphics.path</refname>
-<refpurpose>Path to admonition graphics</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="admon.graphics.path.frag">&lt;xsl:param name="admon.graphics.path"&gt;images/&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Sets the path to the directory containing the admonition graphics
-(caution.png, important.png etc). This location is normally relative
-to the output html directory. See <parameter>base.dir</parameter></para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="admon.textlabel">
-<refmeta>
-<refentrytitle>admon.textlabel</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>admon.textlabel</refname>
-<refpurpose>Use text label in admonitions?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="admon.textlabel.frag">
-&lt;xsl:param name="admon.textlabel" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If true (non-zero), admonitions are presented with a generated
-text label such as Note or Warning in the appropriate language.
-If zero, such labels are turned off, but any title child
-of the admonition element are still output.
-The default value is 1.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="admonition.title.properties">
-
-<refmeta>
-  <refentrytitle>admonition.title.properties</refentrytitle>
-  <refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>admonition.title.properties</refname>
-<refpurpose>To set the style for admonitions titles.</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="admonition.title.properties.frag">
-&lt;xsl:attribute-set name="admonition.title.properties"&gt;
-  &lt;xsl:attribute name="font-size"&gt;14pt&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="font-weight"&gt;bold&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="hyphenate"&gt;false&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="keep-with-next.within-column"&gt;always&lt;/xsl:attribute&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-<refsection><info><title>Description</title></info>
-<para>How do you want admonitions titles styled? </para>
-<para>Set the font-size, weight etc to the style required.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="admonition.properties">
-<refmeta>
-  <refentrytitle>admonition.properties</refentrytitle>
-  <refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>  
-<refnamediv>
-<refname>admonition.properties</refname>
-<refpurpose>To set the style for admonitions.</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="admonition.properties.frag">&lt;xsl:attribute-set name="admonition.properties"&gt;&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-<refsection><info><title>Description</title></info>
-<para>How do you want admonitions styled? </para>
-<para>Set the font-size, weight, etc. to the style required</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="graphical.admonition.properties">
-<refmeta>
-<refentrytitle>graphical.admonition.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>graphical.admonition.properties</refname>
-<refpurpose>To add properties to the outer block of a graphical admonition.</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="graphical.admonition.properties.frag">&lt;xsl:attribute-set name="graphical.admonition.properties"&gt;
-  &lt;xsl:attribute name="space-before.optimum"&gt;1em&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="space-before.minimum"&gt;0.8em&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="space-before.maximum"&gt;1.2em&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="space-after.optimum"&gt;1em&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="space-after.minimum"&gt;0.8em&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="space-after.maximum"&gt;1.2em&lt;/xsl:attribute&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-<refsection><info><title>Description</title></info>
-<para>These properties are added to the outer block containing the
-entire graphical admonition, including its title.
-It is used when the parameter
-<parameter>admon.graphics</parameter> is set to nonzero.
-Use this attribute-set to set the space above and below,
-and any indent for the whole admonition.</para>
-
-<para>In addition to these properties, a graphical admonition
-also applies the <parameter>admonition.title.properties</parameter>
-attribute-set to the title, and applies the
-<parameter>admonition.properties</parameter> attribute-set
-to the rest of the content.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="nongraphical.admonition.properties">
-<refmeta>
-<refentrytitle>nongraphical.admonition.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>nongraphical.admonition.properties</refname>
-<refpurpose>To add properties to the outer block of a nongraphical admonition.</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="nongraphical.admonition.properties.frag">&lt;xsl:attribute-set name="nongraphical.admonition.properties"&gt;
-  &lt;xsl:attribute name="space-before.minimum"&gt;0.8em&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="space-before.optimum"&gt;1em&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="space-before.maximum"&gt;1.2em&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="margin-{$direction.align.start}"&gt;0.25in&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="margin-{$direction.align.end}"&gt;0.25in&lt;/xsl:attribute&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-<refsection><info><title>Description</title></info>
-<para>These properties are added to the outer block containing the
-entire nongraphical admonition, including its title.
-It is used when the parameter
-<parameter>admon.graphics</parameter> is set to zero.
-Use this attribute-set to set the space above and below,
-and any indent for the whole admonition.</para>
-
-<para>In addition to these properties, a nongraphical admonition
-also applies the <parameter>admonition.title.properties</parameter>
-attribute-set to the title, and the
-<parameter>admonition.properties</parameter> attribute-set
-to the rest of the content.</para>
-
-</refsection>
-</refentry>
-
-</reference><reference id="callouts" xml:base="../fo/param.xml"><title>Callouts</title>
-<refentry version="5.0" id="calloutlist.properties">
-<refmeta>
-<refentrytitle>calloutlist.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>calloutlist.properties</refname>
-<refpurpose>Properties that apply to each list-block generated by calloutlist.</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="calloutlist.properties.frag">&lt;xsl:attribute-set name="calloutlist.properties"&gt;
-  &lt;xsl:attribute name="space-before.optimum"&gt;1em&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="space-before.minimum"&gt;0.8em&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="space-before.maximum"&gt;1.2em&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="provisional-distance-between-starts"&gt;2.2em&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="provisional-label-separation"&gt;0.2em&lt;/xsl:attribute&gt;
-&lt;/xsl:attribute-set&gt;</programlisting>
-</refsynopsisdiv>
-<refsection><info><title>Description</title></info>
-<para>Properties that apply to the fo:list-block generated by calloutlist.
-Typically used to adjust spacing or margins of the entire list.
-Change the <literal>provisional-distance-between-starts</literal> attribute to
-change the indent of the list paragraphs relative to the
-callout numbers.</para>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="callout.properties">
-<refmeta>
-<refentrytitle>callout.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>callout.properties</refname>
-<refpurpose>Properties that apply to the list-item generated by each callout within a calloutlist.</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="callout.properties.frag">&lt;xsl:attribute-set name="callout.properties"&gt;
-&lt;/xsl:attribute-set&gt;</programlisting>
-</refsynopsisdiv>
-<refsection><info><title>Description</title></info>
-<para>Properties that apply to the fo:list-item generated by each callout within a calloutlist. Typically used to add spacing properties.</para>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="callout.defaultcolumn">
-<refmeta>
-<refentrytitle>callout.defaultcolumn</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">integer</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>callout.defaultcolumn</refname>
-<refpurpose>Indicates what column callouts appear in by default</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="callout.defaultcolumn.frag">
-&lt;xsl:param name="callout.defaultcolumn"&gt;60&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If a callout does not identify a column (for example, if it uses
-the <literal>linerange</literal> <tag class="attribute">unit</tag>),
-it will appear in the default column.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="callout.graphics">
-<refmeta>
-<refentrytitle>callout.graphics</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>callout.graphics</refname>
-<refpurpose>Use graphics for callouts?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="callout.graphics.frag">
-&lt;xsl:param name="callout.graphics" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, callouts are presented with graphics (e.g., reverse-video
-circled numbers instead of "(1)", "(2)", etc.).
-Default graphics are provided in the distribution.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="callout.graphics.extension">
-<refmeta>
-<refentrytitle>callout.graphics.extension</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>callout.graphics.extension</refname>
-<refpurpose>Filename extension for callout graphics</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="callout.graphics.extension.frag">
-
-&lt;xsl:param name="callout.graphics.extension"&gt;.svg&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-<para>Sets the filename extension to use on callout graphics. </para>
-
-<itemizedlist>
-<para>The Docbook XSL distribution provides callout graphics in the following formats:</para>
-<listitem><para>SVG (extension: <filename class="extension">.svg</filename>)</para></listitem>
-<listitem><para>PNG (extension: <filename class="extension">.png</filename>)</para></listitem>
-<listitem><para>GIF (extension: <filename class="extension">.gif</filename>)</para></listitem>
-</itemizedlist>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="callout.graphics.number.limit">
-<refmeta>
-<refentrytitle>callout.graphics.number.limit</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">integer</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>callout.graphics.number.limit</refname>
-<refpurpose>Number of the largest callout graphic</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="callout.graphics.number.limit.frag">
-
-&lt;xsl:param name="callout.graphics.number.limit"&gt;30&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If <parameter>callout.graphics</parameter> is non-zero, graphics
-are used to represent callout numbers instead of plain text. The value
-of <parameter>callout.graphics.number.limit</parameter> is the largest
-number for which a graphic exists. If the callout number exceeds this
-limit, the default presentation "(plain text instead of a graphic)"
-will  be used.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="callout.graphics.path">
-<refmeta>
-<refentrytitle>callout.graphics.path</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>callout.graphics.path</refname>
-<refpurpose>Path to callout graphics</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="callout.graphics.path.frag">
-&lt;xsl:param name="callout.graphics.path"&gt;images/callouts/&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Sets the path to the directory holding the callout graphics. his
-location is normally relative to the output html directory. see
-base.dir. Always terminate the directory with / since the graphic file
-is appended to this string, hence needs the separator.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="callout.icon.size">
-<refmeta>
-<refentrytitle>callout.icon.size</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">length</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>callout.icon.size</refname>
-<refpurpose>Specifies the size of callout marker icons</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="callout.icon.size.frag">
-&lt;xsl:param name="callout.icon.size"&gt;7pt&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Specifies the size of the callout marker icons.
-The default size is 7 points.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="callout.unicode">
-<refmeta>
-<refentrytitle>callout.unicode</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>callout.unicode</refname>
-<refpurpose>Use Unicode characters rather than images for callouts.</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="callout.unicode.frag">&lt;xsl:param name="callout.unicode" select="0"&gt;&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The stylesheets can use either an image of the numbers one to ten, or the single Unicode character which represents the numeral, in white on a black background. Use this to select the Unicode character option.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="callout.unicode.font">
-<refmeta>
-<refentrytitle>callout.unicode.font</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>callout.unicode.font</refname>
-<refpurpose>Specify a font for Unicode glyphs</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="callout.unicode.font.frag">
-&lt;xsl:param name="callout.unicode.font"&gt;ZapfDingbats&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The name of the font to specify around Unicode callout glyphs.
-If set to the empty string, no font change will occur.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="callout.unicode.number.limit">
-<refmeta>
-<refentrytitle>callout.unicode.number.limit</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">integer</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>callout.unicode.number.limit</refname>
-<refpurpose>Number of the largest unicode callout character</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="callout.unicode.number.limit.frag">
-&lt;xsl:param name="callout.unicode.number.limit"&gt;10&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If <parameter>callout.unicode</parameter>
-is non-zero, unicode characters are used to represent
-callout numbers. The value of
-<parameter>callout.unicode.number.limit</parameter>
-is
-the largest number for which a unicode character exists. If the callout number
-exceeds this limit, the default presentation "(nnn)" will always
-be used.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="callout.unicode.start.character">
-<refmeta>
-<refentrytitle>callout.unicode.start.character</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">integer</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>callout.unicode.start.character</refname>
-<refpurpose>First Unicode character to use, decimal value.</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="callout.unicode.start.character.frag">
-&lt;xsl:param name="callout.unicode.start.character"&gt;10102&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If <parameter>callout.graphics</parameter> is zero and <parameter>callout.unicode</parameter>
-is non-zero, unicode characters are used to represent
-callout numbers. The value of
-<parameter>callout.unicode.start.character</parameter>
-is the decimal unicode value used for callout number one. Currently, 
-only values 9312 and 10102 are supported in the stylesheets for this parameter. 
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="callouts.extension">
-<refmeta>
-<refentrytitle>callouts.extension</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>callouts.extension</refname>
-<refpurpose>Enable the callout extension</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="callouts.extension.frag">
-&lt;xsl:param name="callouts.extension" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The callouts extension processes <tag>areaset</tag>
-elements in <tag>programlistingco</tag> and other text-based
-callout elements.
-</para>
-
-</refsection>
-</refentry>
-
-</reference><reference id="toc_index" xml:base="../fo/param.xml"><title>ToC/LoT/Index Generation</title>
-<refentry version="5.0" id="autotoc.label.separator">
-<refmeta>
-<refentrytitle>autotoc.label.separator</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>autotoc.label.separator</refname>
-<refpurpose>Separator between labels and titles in the ToC</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="autotoc.label.separator.frag">
-&lt;xsl:param name="autotoc.label.separator"&gt;. &lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>String used to separate labels and titles in a table of contents.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="process.empty.source.toc">
-<refmeta>
-<refentrytitle>process.empty.source.toc</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>process.empty.source.toc</refname>
-<refpurpose>Generate automated TOC if <tag>toc</tag> element occurs in a source document?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="process.empty.source.toc.frag">&lt;xsl:param name="process.empty.source.toc" select="0"&gt;&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Specifies that if an empty <tag>toc</tag> element is found in a
-source document, an automated TOC is generated at this point in the
-document.
-<note>
-  <para>Depending on what the value of the
-  <parameter>generate.toc</parameter> parameter is, setting this
-  parameter to <literal>1</literal> could result in generation of
-  duplicate automated TOCs. So the
-  <parameter>process.empty.source.toc</parameter> is primarily useful
-  as an "override": by placing an empty <tag>toc</tag> in your
-  document and setting this parameter to <literal>1</literal>, you can
-  force a TOC to be generated even if <tag>generate.toc</tag>
-  says not to.</para>
-</note>
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="process.source.toc">
-<refmeta>
-<refentrytitle>process.source.toc</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>process.source.toc</refname>
-<refpurpose>Process a non-empty <tag>toc</tag> element if it occurs in a source document?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="process.source.toc.frag">&lt;xsl:param name="process.source.toc" select="0"&gt;&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Specifies that the contents of a non-empty "hard-coded"
-<tag>toc</tag> element in a source document are processed to
-generate a TOC in output.
-<note>
-  <para>This parameter has no effect on automated generation of
-  TOCs. An automated TOC may still be generated along with the
-  "hard-coded" TOC. To suppress automated TOC generation, adjust the
-  value of the <parameter>generate.toc</parameter> paramameter.</para>
-
-  <para>The <tag>process.source.toc</tag> parameter also has
-  no effect if the <tag>toc</tag> element is empty; handling
-  for empty <tag>toc</tag> is controlled by the
-  <parameter>process.empty.source.toc</parameter> parameter.</para>
-</note>
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="generate.toc">
-<refmeta>
-<refentrytitle>generate.toc</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">table</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>generate.toc</refname>
-<refpurpose>Control generation of ToCs and LoTs</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="generate.toc.frag">
-
-&lt;xsl:param name="generate.toc"&gt;
-/appendix toc,title
-article/appendix  nop
-/article  toc,title
-book      toc,title,figure,table,example,equation
-/chapter  toc,title
-part      toc,title
-/preface  toc,title
-reference toc,title
-/sect1    toc
-/sect2    toc
-/sect3    toc
-/sect4    toc
-/sect5    toc
-/section  toc
-set       toc,title
-&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This parameter has a structured value. It is a table of space-delimited
-path/value pairs. Each path identifies some element in the source document
-using a restricted subset of XPath (only the implicit child axis, no wildcards,
-no predicates). Paths can be either relative or absolute.</para>
-
-<para>When processing a particular element, the stylesheets consult this table to
-determine if a ToC (or LoT(s)) should be generated.</para>
-
-<para>For example, consider the entry:</para>
-
-<screen>book toc,figure</screen>
-
-<para>This indicates that whenever a <tag>book</tag> is formatted, a
-Table Of Contents and a List of Figures should be generated. Similarly,</para>
-
-<screen>/chapter toc</screen>
-
-<para>indicates that whenever a document <emphasis>that has a root
-of</emphasis> <tag>chapter</tag> is formatted, a Table of
-Contents should be generated. The entry <literal>chapter</literal> would match
-all chapters, but <literal>/chapter</literal> matches only <tag>chapter</tag>
-document elements.</para>
-
-<para>Generally, the longest match wins. So, for example, if you want to distinguish
-articles in books from articles in parts, you could use these two entries:</para>
-
-<screen>book/article toc,figure
-part/article toc</screen>
-
-<para>Note that an article in a part can never match a <literal>book/article</literal>,
-so if you want nothing to be generated for articles in parts, you can simply leave
-that rule out.</para>
-
-<para>If you want to leave the rule in, to make it explicit that you're turning
-something off, use the value <quote>nop</quote>. For example, the following
-entry disables ToCs and LoTs for articles:</para>
-
-<screen>article nop</screen>
-
-<para>Do not simply leave the word <quote>article</quote> in the file
-without a matching value. That'd be just begging the silly little
-path/value parser to get confused.</para>
-
-<para>Section ToCs are further controlled by the
-<parameter>generate.section.toc.level</parameter> parameter.
-For a given section level to have a ToC, it must have both an entry in 
-<parameter>generate.toc</parameter> and be within the range enabled by
-<parameter>generate.section.toc.level</parameter>.</para>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="generate.index">
-<refmeta>
-<refentrytitle>generate.index</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>generate.index</refname>
-<refpurpose>Do you want an index?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="generate.index.frag">&lt;xsl:param name="generate.index" select="1"&gt;&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Specify if an index should be generated. </para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="make.index.markup">
-<refmeta>
-<refentrytitle>make.index.markup</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>make.index.markup</refname>
-<refpurpose>Generate XML index markup in the index?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="make.index.markup.frag">
-&lt;xsl:param name="make.index.markup" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This parameter enables a very neat trick for getting properly
-merged, collated back-of-the-book indexes. G. Ken Holman suggested
-this trick at Extreme Markup Languages 2002 and I'm indebted to him
-for it.</para>
-
-<para>Jeni Tennison's excellent code in
-<filename>autoidx.xsl</filename> does a great job of merging and
-sorting <tag>indexterm</tag>s in the document and building a
-back-of-the-book index. However, there's one thing that it cannot
-reasonably be expected to do: merge page numbers into ranges. (I would
-not have thought that it could collate and suppress duplicate page
-numbers, but in fact it appears to manage that task somehow.)</para>
-
-<para>Ken's trick is to produce a document in which the index at the
-back of the book is <quote>displayed</quote> in XML. Because the index
-is generated by the FO processor, all of the page numbers have been resolved.
-It's a bit hard to explain, but what it boils down to is that instead of having
-an index at the back of the book that looks like this:</para>
-
-<blockquote>
-<formalpara><info><title>A</title></info>
-<para>ap1, 1, 2, 3</para>
-</formalpara>
-</blockquote>
-
-<para>you get one that looks like this:</para>
-
-<blockquote>
-<programlisting>&lt;indexdiv&gt;A&lt;/indexdiv&gt;
-&lt;indexentry&gt;
-&lt;primaryie&gt;ap1&lt;/primaryie&gt;,
-&lt;phrase role="pageno"&gt;1&lt;/phrase&gt;,
-&lt;phrase role="pageno"&gt;2&lt;/phrase&gt;,
-&lt;phrase role="pageno"&gt;3&lt;/phrase&gt;
-&lt;/indexentry&gt;</programlisting>
-</blockquote>
-
-<para>After building a PDF file with this sort of odd-looking index, you can
-extract the text from the PDF file and the result is a proper index expressed in
-XML.</para>
-
-<para>Now you have data that's amenable to processing and a simple Perl script
-(such as <filename>fo/pdf2index</filename>) can
-merge page ranges and generate a proper index.</para>
-
-<para>Finally, reformat your original document using this literal index instead of
-an automatically generated one and <quote>bingo</quote>!</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="index.method">
-<refmeta>
-<refentrytitle>index.method</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">list</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">basic</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">kosek</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">kimber</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>index.method</refname>
-<refpurpose>Select method used to group index entries in an index</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="index.method.frag">
-&lt;xsl:param name="index.method"&gt;basic&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This parameter lets you select which method to use for sorting and grouping
- index entries in an index.
-Indexes in Latin-based languages that have accented characters typically
-sort together accented words and unaccented words.
-Thus <quote>&#193;</quote> (U+00C1 LATIN CAPITAL LETTER A WITH ACUTE) would sort together
-with <quote>A</quote> (U+0041 LATIN CAPITAL LETTER A), so both would appear in the <quote>A</quote>
-section of the index.
-Languages using other alphabets (such as Russian,  which is written in the Cyrillic alphabet)
-and languages using ideographic chararacters (such as Japanese)
-require grouping specific to the languages and alphabets.
-</para>
-
-<para>The default indexing method is limited.
-It can group accented characters in Latin-based languages only.
-It cannot handle non-Latin alphabets or ideographic languages.
-The other indexing methods require extensions of one type or
-another, and do not work with
-all XSLT processors, which is why they are not used by default.</para>
-
-<para>The three choices for indexing method are:</para>
-<variablelist>
-<varlistentry>
-<term><literal>basic</literal></term>
-<listitem>
-<para>
-(default)  Sort and groups words based only on the Latin alphabet.
-Words with accented Latin letters will group and sort with
-their respective primary letter, but
-words in non-Latin alphabets will be
-put in the <quote>Symbols</quote> section of the index.
-</para>
-</listitem>
-</varlistentry>
-<varlistentry>
-<term><literal>kosek</literal></term>
-<listitem>
-<para>
-This method sorts and groups words based on letter groups configured in
-the DocBook locale file for the given language.
-See, for example, the French locale file <filename>common/fr.xml</filename>.
-This method requires that the XSLT processor
-supports the EXSLT extensions (most do).
-It also requires support for using 
-user-defined functions in xsl:key (xsltproc does not).
-</para>
-<para>This method is suitable for any language for which you can
-list all the individual characters that should appear
-in each letter group in an index.
-It is probably not practical to use it for ideographic languages
-such as Chinese that have hundreds or thousands of characters.
-</para>
-
-<para>To use the kosek method, you must:</para>
-
-<orderedlist>
-<listitem>
-<para>Use a processor that supports its extensions, such as
-Saxon 6 or Xalan (xsltproc and Saxon 8 do not).
-</para>
-</listitem>
-<listitem>
-<para>Set the index.method parameter's value to <quote>kosek</quote>.
-</para>
-</listitem>
-<listitem>
-<para>Import the appropriate index extensions stylesheet module
-<filename>fo/autoidx-kosek.xsl</filename> or 
-<filename>html/autoidx-kosek.xsl</filename> into your
-customization.
-</para>
-</listitem>
-</orderedlist>
-
-</listitem>
-</varlistentry>
-<varlistentry>
-<term><literal>kimber</literal></term>
-<listitem>
-<para>
-This method uses extensions to the Saxon processor to implement
-sophisticated indexing processes. It uses its own 
-configuration file, which can include information for any number of
-languages. Each language's configuration can group
-words using one of two processes. In the
-enumerated process similar to that used in the kosek method,
-you indicate the groupings character-by-character.
-In the between-key process, you specify the
-break-points in the sort order that should start a new group.
-The latter configuration is useful for ideographic languages
-such as Chinese, Japanese, and Korean.
-You can also define your own collation algorithms and how you
-want mixed Latin-alphabet words sorted.</para>
-<itemizedlist>
-<listitem>
-<para>For a whitepaper describing the extensions, see:
-<link xlink:href="http://www.innodata-isogen.com/knowledge_center/white_papers/back_of_book_for_xsl_fo.pdf">http://www.innodata-isogen.com/knowledge_center/white_papers/back_of_book_for_xsl_fo.pdf</link>.
-</para>
-</listitem>
-<listitem>
-<para>To download the extension library, see
-<link xlink:href="http://www.innodata-isogen.com/knowledge_center/tools_downloads/i18nsupport">http://www.innodata-isogen.com/knowledge_center/tools_downloads/i18nsupport</link>.
-</para>
-</listitem>
-</itemizedlist>
-
-<para>To use the kimber method, you must:</para>
-
-<orderedlist>
-<listitem>
-<para>Use Saxon (version 6 or 8) as your XSLT processor.
-</para>
-</listitem>
-<listitem>
-<para>Install and configure the Innodata Isogen library, using
-the documentation that comes with it.
-</para>
-</listitem>
-<listitem>
-<para>Set the index.method parameter's value to <quote>kimber</quote>.
-</para>
-</listitem>
-<listitem>
-<para>Import the appropriate index extensions stylesheet module
-<filename>fo/autoidx-kimber.xsl</filename> or 
-<filename>html/autoidx-kimber.xsl</filename> into your
-customization.
-</para>
-</listitem>
-</orderedlist>
-
-</listitem>
-</varlistentry>
-</variablelist>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="index.on.type">
-<refmeta>
-<refentrytitle>index.on.type</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>index.on.type</refname>
-<refpurpose>Select indexterms based on <tag class="attribute">type</tag>
-attribute value</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="index.on.type.frag">
-&lt;xsl:param name="index.on.type" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>
-If non-zero, 
-then an <tag>index</tag> element that has a
-<tag class="attribute">type</tag> attribute
-value will contain only those <tag>indexterm</tag>
-elements with a matching <tag class="attribute">type</tag> attribute value.
-If an <tag>index</tag> has no <tag class="attribute">type</tag>
-attribute or it is blank, then the index will contain
-all <tag>indexterm</tag>s in the current scope.
-</para>
-
-<para>
-If <literal>index.on.type</literal> is zero, then the
-<tag class="attribute">type</tag> attribute has no effect
-on selecting indexterms for an index.
-</para>
-
-<para>For those using DocBook version 4.2 or earlier,
-the <tag class="attribute">type</tag> attribute is not available
-for index terms.  However, you can achieve the same
-effect by using the <tag class="attribute">role</tag> attribute
-in the same manner on <tag>indexterm</tag>
-and <tag>index</tag>, and setting the stylesheet parameter 
-<parameter>index.on.role</parameter> to a nonzero value.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="index.on.role">
-<refmeta>
-<refentrytitle>index.on.role</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>index.on.role</refname>
-<refpurpose>Select indexterms based on <tag class="attribute">role</tag> value</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="index.on.role.frag">
-&lt;xsl:param name="index.on.role" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>
-If non-zero, 
-then an <tag>index</tag> element that has a
-<tag class="attribute">role</tag> attribute
-value will contain only those <tag>indexterm</tag>
-elements with a matching role value.
-If an <tag>index</tag> has no <tag class="attribute">role</tag>
-attribute or it is blank, then the index will contain
-all <tag>indexterm</tag>s in the current scope.
-</para>
-<para>
-If <literal>index.on.role</literal> is zero, then the
-<tag class="attribute">role</tag> attribute has no effect
-on selecting indexterms for an index.
-</para>
-
-<para>If you are using DocBook version 4.3 or later, you should
-use the <tag class="attribute">type</tag> attribute instead of <tag class="attribute">role</tag>
-on <tag>indexterm</tag> and <tag>index</tag>,
-and set the <parameter>index.on.type</parameter> to a nonzero
-value.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="index.preferred.page.properties">
-<refmeta>
-<refentrytitle>index.preferred.page.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>index.preferred.page.properties</refname>
-<refpurpose>Properties used to emphasize page number references for
-significant index terms</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="index.preferred.page.properties.frag">
-&lt;xsl:attribute-set name="index.preferred.page.properties"&gt;
-  &lt;xsl:attribute name="font-weight"&gt;bold&lt;/xsl:attribute&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Properties used to emphasize page number references for
-significant index terms (<tag class="attribute">significance</tag>=<tag class="attvalue">preferred</tag>). Currently works only with
-XEP.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="index.entry.properties">
-<refmeta>
-<refentrytitle>index.entry.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>index.entry.properties</refname>
-<refpurpose>Properties applied to the formatted entries
-in an index</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="index.entry.properties.frag">
-&lt;xsl:attribute-set name="index.entry.properties"&gt;
-  &lt;xsl:attribute name="start-indent"&gt;0pt&lt;/xsl:attribute&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This attribute set is applied to the block containing
-the entries in a letter division in an index.  It can be used to set the
-font-size, font-family, and other inheritable properties that will be
-applied to all index entries.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="index.div.title.properties">
-<refmeta>
-<refentrytitle>index.div.title.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>index.div.title.properties</refname>
-<refpurpose>Properties associated with the letter headings in an
-index</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="index.div.title.properties.frag">
-&lt;xsl:attribute-set name="index.div.title.properties"&gt;
-  &lt;xsl:attribute name="margin-{$direction.align.start}"&gt;0pt&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="font-size"&gt;14.4pt&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="font-family"&gt;&lt;xsl:value-of select="$title.fontset"&gt;&lt;/xsl:value-of&gt;&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="font-weight"&gt;bold&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="keep-with-next.within-column"&gt;always&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="space-before.optimum"&gt;&lt;xsl:value-of select="concat($body.font.master,'pt')"&gt;&lt;/xsl:value-of&gt;&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="space-before.minimum"&gt;&lt;xsl:value-of select="concat($body.font.master,'pt * 0.8')"&gt;&lt;/xsl:value-of&gt;&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="space-before.maximum"&gt;&lt;xsl:value-of select="concat($body.font.master,'pt * 1.2')"&gt;&lt;/xsl:value-of&gt;&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="start-indent"&gt;0pt&lt;/xsl:attribute&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This attribute set is used on the letter headings that separate
-the divisions in an index.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="index.number.separator">
-<refmeta>
-<refentrytitle>index.number.separator</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>index.number.separator</refname>
-<refpurpose>Override for punctuation separating page numbers in index</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="index.number.separator.frag">
-&lt;xsl:param name="index.number.separator"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This parameter permits you to override the text to insert between
-page references in a formatted index entry.  Typically 
-that would be a comma and a space.
-</para>
-
-<para>Because this text may be locale dependent,
-this parameter's value is normally taken from a gentext
-template named 'number-separator' in the
-context 'index' in the stylesheet
-locale file for the language
-of the current document.
-This parameter can be used to override the gentext string,
-and would typically be used on the command line.
-This parameter would apply to all languages.
-</para>
-
-<para>So this text string can be customized in two ways.
-You can reset the default gentext string using
-the <parameter>local.l10n.xml</parameter> parameter, or you can
-override the gentext with the content of this parameter.
-The content can be a simple string, or it can be
-something more complex such as a call-template.
-</para>
-
-<para>In HTML index output, section title references are used instead of
-page number references.  This punctuation appears between
-such section titles in an HTML index.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="index.range.separator">
-<refmeta>
-<refentrytitle>index.range.separator</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>index.range.separator</refname>
-<refpurpose>Override for punctuation separating the two numbers
-in a page range in index</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="index.range.separator.frag">
-&lt;xsl:param name="index.range.separator"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This parameter permits you
-to override the text to insert between
-the two numbers of a page range in an index.
-This parameter is only used by those XSL-FO processors
-that support an extension for generating such page ranges
-(such as XEP).</para>
-
-<para>Because this text may be locale dependent,
-this parameter's value is normally taken from a gentext
-template named 'range-separator' in the
-context 'index' in the stylesheet
-locale file for the language
-of the current document.
-This parameter can be used to override the gentext string,
-and would typically be used on the command line.
-This parameter would apply to all languages.
-</para>
-
-<para>So this text string can be customized in two ways.
-You can reset the default gentext string using
-the <parameter>local.l10n.xml</parameter> parameter, or you can
-override the gentext with the content of this parameter.
-The content can be a simple string, or it can be
-something more complex such as a call-template.
-</para>
-
-<para>In HTML index output, section title references are used instead of
-page number references. So there are no page ranges
-and this parameter has no effect.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="index.term.separator">
-<refmeta>
-<refentrytitle>index.term.separator</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>index.term.separator</refname>
-<refpurpose>Override for punctuation separating an index term 
-from its list of page references in an index</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="index.term.separator.frag">
-&lt;xsl:param name="index.term.separator"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This parameter permits you to override
-the text to insert between
-the end of an index term and its list of page references.
-Typically that might be a comma and a space.
-</para>
-
-<para>Because this text may be locale dependent,
-this parameter's value is normally taken from a gentext
-template named 'term-separator' in the
-context 'index' in the stylesheet
-locale file for the language
-of the current document.
-This parameter can be used to override the gentext string,
-and would typically be used on the command line.
-This parameter would apply to all languages.
-</para>
-
-<para>So this text string can be customized in two ways.
-You can reset the default gentext string using
-the <parameter>local.l10n.xml</parameter> parameter, or you can
-fill in the content for this normally empty 
-override parameter.
-The content can be a simple string, or it can be
-something more complex such as a call-template.
-For fo output, it could be an <tag>fo:leader</tag>
-element to provide space of a specific length, or a dot leader.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="xep.index.item.properties">
-<refmeta>
-<refentrytitle>xep.index.item.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>xep.index.item.properties</refname>
-<refpurpose>Properties associated with XEP index-items</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="xep.index.item.properties.frag">
-&lt;xsl:attribute-set name="xep.index.item.properties" use-attribute-sets="index.page.number.properties"&gt;
-  &lt;xsl:attribute name="merge-subsequent-page-numbers"&gt;true&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="link-back"&gt;true&lt;/xsl:attribute&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Properties associated with XEP index-items, which generate
-page numbers in an index processed by XEP. For more info see
-the XEP documentation section "Indexes" in
-<uri xlink:href="http://www.renderx.com/reference.html#Indexes">http://www.renderx.com/reference.html#Indexes</uri>.</para>
-
-<para>This attribute-set also adds by default any properties from the
-<tag class="attribute">index.page.number.properties</tag>
-attribute-set.</para>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="toc.section.depth">
-<refmeta>
-<refentrytitle>toc.section.depth</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">integer</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>toc.section.depth</refname>
-<refpurpose>How deep should recursive <tag>section</tag>s appear
-in the TOC?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="toc.section.depth.frag">&lt;xsl:param name="toc.section.depth"&gt;2&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Specifies the depth to which recursive sections should appear in the
-TOC.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="toc.max.depth">
-<refmeta>
-<refentrytitle>toc.max.depth</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">integer</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>toc.max.depth</refname>
-<refpurpose>How many levels should be created for each TOC?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="toc.max.depth.frag">&lt;xsl:param name="toc.max.depth"&gt;8&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Specifies the maximal depth of TOC on all levels.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="toc.indent.width">
-<refmeta>
-<refentrytitle>toc.indent.width</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">float</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>toc.indent.width</refname>
-<refpurpose>Amount of indentation for TOC entries</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="toc.indent.width.frag">
-&lt;xsl:param name="toc.indent.width"&gt;24&lt;/xsl:param&gt;
-&lt;!-- inconsistant point specification? --&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Specifies, in points, the distance by which each level of the
-TOC is indented from its parent.</para>
-
-<para>This value is expressed in points, without
-a unit (in other words, it is a bare number). Using a bare number allows the stylesheet
-to perform calculations that would otherwise have to be performed by the FO processor
-because not all processors support expressions.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="toc.line.properties">
-<refmeta>
-<refentrytitle>toc.line.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>toc.line.properties</refname>
-<refpurpose>Properties for lines in ToCs and LoTs</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="toc.line.properties.frag">
-&lt;xsl:attribute-set name="toc.line.properties"&gt;
-  &lt;xsl:attribute name="text-align-last"&gt;justify&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="text-align"&gt;start&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="end-indent"&gt;&lt;xsl:value-of select="concat($toc.indent.width, 'pt')"&gt;&lt;/xsl:value-of&gt;&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="last-line-end-indent"&gt;&lt;xsl:value-of select="concat('-', $toc.indent.width, 'pt')"&gt;&lt;/xsl:value-of&gt;&lt;/xsl:attribute&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Properties which are applied to every line in ToC (or LoT). You can
-modify them in order to change appearance of all, or some lines. For
-example, in order to make lines for chapters bold, specify the
-following in your customization layer:</para>
-
-<programlisting>&lt;xsl:attribute-set name="toc.line.properties"&gt;
-  &lt;xsl:attribute name="font-weight"&gt;
-   &lt;xsl:choose&gt;
-    &lt;xsl:when test="self::chapter"&gt;bold&lt;/xsl:when&gt;
-    &lt;xsl:otherwise&gt;normal&lt;/xsl:otherwise&gt;
-   &lt;/xsl:choose&gt;
-  &lt;/xsl:attribute&gt;
-&lt;/xsl:attribute-set&gt;</programlisting>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="toc.margin.properties">
-<refmeta>
-<refentrytitle>toc.margin.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>toc.margin.properties</refname>
-<refpurpose>Margin properties used on Tables of Contents</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="toc.margin.properties.frag">
-&lt;xsl:attribute-set name="toc.margin.properties"&gt;
-  &lt;xsl:attribute name="space-before.minimum"&gt;0.5em&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="space-before.optimum"&gt;1em&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="space-before.maximum"&gt;2em&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="space-after.minimum"&gt;0.5em&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="space-after.optimum"&gt;1em&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="space-after.maximum"&gt;2em&lt;/xsl:attribute&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-<para>This attribute set is used on Tables of Contents. These attributes are set
-on the wrapper that surrounds the ToC block, not on each individual lines.</para>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="bridgehead.in.toc">
-<refmeta>
-<refentrytitle>bridgehead.in.toc</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>bridgehead.in.toc</refname>
-<refpurpose>Should bridgehead elements appear in the TOC?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="bridgehead.in.toc.frag">&lt;xsl:param name="bridgehead.in.toc" select="0"&gt;&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, <tag>bridgehead</tag>s appear in the TOC. Note that
-this option is not fully supported and may be removed in a future
-version of the stylesheets.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="simplesect.in.toc">
-<refmeta>
-<refentrytitle>simplesect.in.toc</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>simplesect.in.toc</refname>
-<refpurpose>Should <tag>simplesect</tag> elements appear in the TOC?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="simplesect.in.toc.frag">&lt;xsl:param name="simplesect.in.toc" select="0"&gt;&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, <tag>simplesect</tag>s will be included in the TOC.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="generate.section.toc.level">
-<refmeta>
-<refentrytitle>generate.section.toc.level</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">integer</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>generate.section.toc.level</refname>
-<refpurpose>Control depth of TOC generation in sections</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="generate.section.toc.level.frag">
-&lt;xsl:param name="generate.section.toc.level" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The <parameter>generate.section.toc.level</parameter> parameter
-controls the depth of <tag>section</tag> in which TOCs will be generated. Note
-that this is related to, but not the same as
-<parameter>toc.section.depth</parameter>, which controls the depth to
-which TOC entries will be generated in a given TOC.</para>
-<para>If, for example, <parameter>generate.section.toc.level</parameter>
-is <literal>3</literal>, TOCs will be generated in first, second, and third
-level sections, but not in fourth level sections.
-</para>
-
-</refsection>
-</refentry>
-
-
-
-
-</reference><reference id="fo_ext" xml:base="../fo/param.xml"><title>Processor Extensions</title>
-<refentry version="5.0" id="arbortext.extensions">
-<refmeta>
-<refentrytitle>arbortext.extensions</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>arbortext.extensions</refname>
-<refpurpose>Enable Arbortext extensions?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="arbortext.extensions.frag">&lt;xsl:param name="arbortext.extensions" select="0"&gt;&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero,
-<link xlink:href="http://www.arbortext.com/">Arbortext</link>
-extensions will be used.
-</para>
-<para>This parameter can also affect which graphics file formats
-are supported</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="axf.extensions">
-<refmeta>
-<refentrytitle>axf.extensions</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>axf.extensions</refname>
-<refpurpose>Enable XSL Formatter extensions?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="axf.extensions.frag">
-&lt;xsl:param name="axf.extensions" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero,
-<link xlink:href="http://www.antennahouse.com/">XSL Formatter</link>
-extensions will be used. XSL Formatter extensions consists of PDF bookmarks,
-document information and better index processing.</para>
-
-<para>This parameter can also affect which graphics file formats
-are supported</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="fop.extensions">
-<refmeta>
-<refentrytitle>fop.extensions</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>fop.extensions</refname>
-<refpurpose>Enable extensions for FOP version 0.20.5 and earlier</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="fop.extensions.frag">&lt;xsl:param name="fop.extensions" select="0"&gt;&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, extensions intended for
-<link xlink:href="http://xml.apache.org/fop/">FOP</link>
-version 0.20.5 and earlier will be used.
-At present, this consists of PDF bookmarks.
-</para>
-
-<para>This parameter can also affect which graphics file formats
-are supported.</para>
-
-<para>If you are using a version of FOP beyond
-version 0.20.5, then use the <parameter>fop1.extensions</parameter> parameter
-instead.
-</para>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="fop1.extensions">
-<refmeta>
-<refentrytitle>fop1.extensions</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>fop1.extensions</refname>
-<refpurpose>Enable extensions for FOP version 0.90 and later</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="fop1.extensions.frag">&lt;xsl:param name="fop1.extensions" select="0"&gt;&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, extensions for 
-<link xlink:href="http://xml.apache.org/fop/">FOP</link>
-version 0.90 and later will be used.
-</para>
-
-<para>This parameter can also affect which graphics file formats
-are supported.</para>
-
-<para>The original <parameter>fop.extensions</parameter> parameter
-should still be used for FOP version 0.20.5 and earlier.
-</para>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="passivetex.extensions">
-<refmeta>
-<refentrytitle>passivetex.extensions</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>passivetex.extensions</refname>
-<refpurpose>Enable PassiveTeX extensions?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="passivetex.extensions.frag">&lt;xsl:param name="passivetex.extensions" select="0"&gt;&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<important><para>The PassiveTeX XSL-FO processor is
-no longer supported by DocBook XSL, beginning with version 1.78.</para></important>
-
-<para>PassiveTeX was never a complete implementation of
-XSL-FO, and development has ceased. Setting this parameter will
-have no effect on the output.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="tex.math.in.alt">
-<refmeta>
-<refentrytitle>tex.math.in.alt</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">list</refmiscinfo> 
-<refmiscinfo class="other" otherclass="value">plain</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">latex</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>tex.math.in.alt</refname>
-<refpurpose>TeX notation used for equations</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="tex.math.in.alt.frag">
-&lt;xsl:param name="tex.math.in.alt"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If you want type math directly in TeX notation in equations,
-this parameter specifies notation used. Currently are supported two
-values -- <literal>plain</literal> and <literal>latex</literal>. Empty
-value means that you are not using TeX math at all.</para>
-
-<para>Preferred way for including TeX alternative of math is inside of
-<tag>textobject</tag> element. Eg.:</para>
-
-<programlisting>&lt;inlineequation&gt;
-&lt;inlinemediaobject&gt;
-&lt;imageobject&gt;
-&lt;imagedata fileref="eq1.gif"/&gt;
-&lt;/imageobject&gt;
-&lt;textobject&gt;&lt;phrase&gt;E=mc squared&lt;/phrase&gt;&lt;/textobject&gt;
-&lt;textobject role="tex"&gt;&lt;phrase&gt;E=mc^2&lt;/phrase&gt;&lt;/textobject&gt;
-&lt;/inlinemediaobject&gt;
-&lt;/inlineequation&gt;</programlisting>
-
-<para>If you are using <tag>graphic</tag> element, you can
-store TeX inside <tag>alt</tag> element:</para>
-
-<programlisting>&lt;inlineequation&gt;
-&lt;alt role="tex"&gt;a^2+b^2=c^2&lt;/alt&gt;
-&lt;graphic fileref="a2b2c2.gif"/&gt;  
-&lt;/inlineequation&gt;</programlisting>
-
-<para>If you want use this feature, you should process your FO with
-PassiveTeX, which only supports TeX math notation. When calling
-stylsheet, don't forget to specify also
-passivetex.extensions=1.</para>
-
-<para>If you want equations in HTML, just process generated file
-<filename>tex-math-equations.tex</filename> by TeX or LaTeX. Then run
-dvi2bitmap program on result DVI file. You will get images for
-equations in your document.</para>
-
-<warning>
-  <para>This feature is useful for print/PDF output only if you
-    use the obsolete and now unsupported PassiveTeX XSL-FO
-    engine.</para>
-</warning>
-
-</refsection>
-
-<refsection><info><title>Related Parameters</title></info>
-  <para><parameter>tex.math.delims</parameter>,
-    <parameter>passivetex.extensions</parameter>,
-    <parameter>tex.math.file</parameter></para>
-</refsection>
-
-</refentry>
-
-<refentry version="5.0" id="tex.math.delims">
-<refmeta>
-<refentrytitle>tex.math.delims</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>tex.math.delims</refname>
-<refpurpose>Should equations output for processing by TeX be
-surrounded by math mode delimiters?</refpurpose>
-</refnamediv> 
-
-<refsynopsisdiv>
-<programlisting id="tex.math.delims.frag">
-&lt;xsl:param name="tex.math.delims" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>For compatibility with DSSSL based DBTeXMath from Allin Cottrell
-you should set this parameter to 0.</para>
-
-<warning>
-  <para>This feature is useful for print/PDF output only if you
-  use the obsolete and now unsupported PassiveTeX XSL-FO
-  engine.</para>
-</warning>
-
-</refsection>
-<refsection><info><title>Related Parameters</title></info>
-  <para><parameter>tex.math.in.alt</parameter>,
-    <parameter>passivetex.extensions</parameter></para>
-</refsection>
-
-<refsection><info><title>See Also</title></info>
-  <para>You can also use the <tag class="xmlpi">dbtex delims</tag> processing
-    instruction to control whether delimiters are output.</para>
-</refsection>
-
-
-</refentry>
-
-<refentry version="5.0" id="xep.extensions">
-<refmeta>
-<refentrytitle>xep.extensions</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>xep.extensions</refname>
-<refpurpose>Enable XEP extensions?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="xep.extensions.frag">&lt;xsl:param name="xep.extensions" select="0"&gt;&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero,
-<link xlink:href="http://www.renderx.com/">XEP</link>
-extensions will be used. XEP extensions consists of PDF bookmarks,
-document information and better index processing.
-</para>
-
-<para>This parameter can also affect which graphics file formats
-are supported</para>
-</refsection>
-</refentry>
-
-</reference><reference id="dbk_ext" xml:base="../fo/param.xml"><title>Stylesheet Extensions</title>
-<refentry version="5.0" id="linenumbering.everyNth">
-<refmeta>
-<refentrytitle>linenumbering.everyNth</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">integer</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>linenumbering.everyNth</refname>
-<refpurpose>Indicate which lines should be numbered</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="linenumbering.everyNth.frag">
-&lt;xsl:param name="linenumbering.everyNth"&gt;5&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If line numbering is enabled, everyNth line will be
-numbered. Note that numbering is one based, not zero based.
-</para>
-<para>See also <parameter>linenumbering.extension</parameter>,
-<parameter>linenumbering.separator</parameter>,
-<parameter>linenumbering.width</parameter> and
-<parameter>use.extensions</parameter></para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="linenumbering.extension">
-<refmeta>
-<refentrytitle>linenumbering.extension</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>linenumbering.extension</refname>
-<refpurpose>Enable the line numbering extension</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="linenumbering.extension.frag">
-&lt;xsl:param name="linenumbering.extension" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, verbatim environments (<tag>address</tag>, <tag>literallayout</tag>,
-<tag>programlisting</tag>, <tag>screen</tag>, <tag>synopsis</tag>) that specify line numbering will
-have line numbers.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="linenumbering.separator">
-<refmeta>
-<refentrytitle>linenumbering.separator</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>linenumbering.separator</refname>
-<refpurpose>Specify a separator between line numbers and lines</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="linenumbering.separator.frag">
-&lt;xsl:param name="linenumbering.separator"&gt;&lt;xsl:text&gt; &lt;/xsl:text&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The separator is inserted between line numbers and lines in the
-verbatim environment. The default value is a single white space.
- Note the interaction with <parameter>linenumbering.width</parameter>
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="linenumbering.width">
-<refmeta>
-<refentrytitle>linenumbering.width</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">integer</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>linenumbering.width</refname>
-<refpurpose>Indicates the width of line numbers</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="linenumbering.width.frag">
-&lt;xsl:param name="linenumbering.width"&gt;3&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If line numbering is enabled, line numbers will appear right
-justified in a field "width" characters wide.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="tablecolumns.extension">
-<refmeta>
-<refentrytitle>tablecolumns.extension</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>tablecolumns.extension</refname>
-<refpurpose>Enable the table columns extension function</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="tablecolumns.extension.frag">
-&lt;xsl:param name="tablecolumns.extension" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The table columns extension function adjusts the widths of table
-columns in the HTML result to more accurately reflect the specifications
-in the CALS table.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="textinsert.extension">
-  <refmeta>
-    <refentrytitle>textinsert.extension</refentrytitle>
-    <refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-  </refmeta>
-  <refnamediv>
-    <refname>textinsert.extension</refname>
-    <refpurpose>Enables the textinsert extension element</refpurpose>
-  </refnamediv>
-  <refsynopsisdiv>
-    <programlisting id="textinsert.extension.frag">
-  &lt;xsl:param name="textinsert.extension" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-  </refsynopsisdiv>
-  <refsection><info><title>Description</title></info>
-    <para>The textinsert extension element inserts the contents of
-      a file into the result tree (as text).</para>
-    <note>
-      <para>To use the textinsert extension element, you must use
-        either Saxon or Xalan as your XSLT processor (it doesn&#8217;t
-        work with xsltproc), along with either the DocBook Saxon
-        extensions or DocBook Xalan extensions (for more
-        information about those extensions, see <link role="tcg" xlink:href="InstallingAProcessor.html#SaxonExtensions">DocBook Saxon Extensions</link> and <link role="tcg" xlink:href="InstallingAProcessor.html#XalanExtensions">DocBook Xalan Extensions</link>), and you must set both
-        the <parameter>use.extensions</parameter> and
-        <parameter>textinsert.extension</parameter> parameters to
-        <literal>1</literal>.</para>
-      <para>As an alternative to using the textinsert element,
-        consider using an Xinclude element with the
-        <literal>parse="text"</literal> attribute and value
-        specified, as detailed in <link role="tcg" xlink:href="ExternalCode.html#XIncludeCode">Using XInclude for text inclusions</link>.</para>
-    </note>
-  </refsection>
-  <refsection><info><title>See Also</title></info>
-    <para>You can also use the <tag class="xmlpi">dbhtml-include&#160;href</tag> processing
-      instruction to insert external files &#8212; both files containing
-      plain text and files with markup content (including HTML
-      content).</para>
-  </refsection>
-  <refsection><info><title>More information</title></info>
-    <para>For how-to documentation on inserting contents of
-      external code files and other text files into output, see
-      <link role="tcg" xlink:href="ExternalCode.html">External code files</link>.</para>
-    <para>For guidelines on inserting contents of
-      HTML files into output, see <link role="tcg" xlink:href="InsertExtHtml.html">Inserting external HTML code</link>.</para>
-  </refsection>
-</refentry>
-
-<refentry version="5.0" id="textdata.default.encoding">
-<refmeta>
-<refentrytitle>textdata.default.encoding</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>textdata.default.encoding</refname>
-<refpurpose>Default encoding of external text files which are included
-using textdata element</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="textdata.default.encoding.frag">
-&lt;xsl:param name="textdata.default.encoding"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Specifies the encoding of any external text files included using
-<tag>textdata</tag> element. This value is used only when you do
-not specify encoding by the appropriate attribute 
-directly on textdata. An empty string is interpreted as the system
-default encoding.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="use.extensions">
-<refmeta>
-<refentrytitle>use.extensions</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>use.extensions</refname>
-<refpurpose>Enable extensions</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="use.extensions.frag">
-&lt;xsl:param name="use.extensions" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, extensions may be used. Each extension is
-further controlled by its own parameter. But if
-<parameter>use.extensions</parameter> is zero, no extensions will
-be used.
-</para>
-
-</refsection>
-</refentry>
-
-</reference><reference id="labels" xml:base="../fo/param.xml"><title>Automatic labelling</title>
-<refentry version="5.0" id="appendix.autolabel">
-<refmeta>
-<refentrytitle>appendix.autolabel</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">list</refmiscinfo> 
-<refmiscinfo class="other" otherclass="value">0<alt>none</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">1<alt>1,2,3...</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">A<alt>A,B,C...</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">a<alt>a,b,c...</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">i<alt>i,ii,iii...</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">I<alt>I,II,III...</alt></refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>appendix.autolabel</refname>
-<refpurpose>Specifies the labeling format for Appendix titles</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="appendix.autolabel.frag">
-&lt;xsl:param name="appendix.autolabel"&gt;A&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, then appendices will be numbered using the
-parameter value as the number format if the value matches one of the
-following:
-</para>
-
-<variablelist>
-  <varlistentry>
-    <term>1 or arabic</term>
-    <listitem>
-      <para>Arabic numeration (1, 2, 3 ...).</para>
-    </listitem>
-  </varlistentry>
-  <varlistentry>
-    <term>A or upperalpha</term>
-    <listitem>
-      <para>Uppercase letter numeration (A, B, C ...).</para>
-    </listitem>
-  </varlistentry>
-  <varlistentry>
-    <term>a or loweralpha</term>
-    <listitem>
-      <para>Lowercase letter numeration (a, b, c ...).</para>
-    </listitem>
-  </varlistentry>
-  <varlistentry>
-    <term>I or upperroman</term>
-    <listitem>
-      <para>Uppercase roman numeration (I, II, III ...).</para>
-    </listitem>
-  </varlistentry>
-  <varlistentry>
-    <term>i or lowerroman</term>
-    <listitem>
-      <para>Lowercase roman letter numeration (i, ii, iii ...).</para>
-    </listitem>
-  </varlistentry>
-</variablelist>
-
-<para>Any nonzero value other than the above will generate
-the default number format (upperalpha).
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="chapter.autolabel">
-<refmeta>
-<refentrytitle>chapter.autolabel</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">list</refmiscinfo> 
-<refmiscinfo class="other" otherclass="value">0<alt>none</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">1<alt>1,2,3...</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">A<alt>A,B,C...</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">a<alt>a,b,c...</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">i<alt>i,ii,iii...</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">I<alt>I,II,III...</alt></refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>chapter.autolabel</refname>
-<refpurpose>Specifies the labeling format for Chapter titles</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="chapter.autolabel.frag">
-&lt;xsl:param name="chapter.autolabel" select="1"&gt;&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, then chapters will be numbered using the parameter
-value as the number format if the value matches one of the following:
-</para>
-
-<variablelist>
-  <varlistentry>
-    <term>1 or arabic</term>
-    <listitem>
-      <para>Arabic numeration (1, 2, 3 ...).</para>
-    </listitem>
-  </varlistentry>
-  <varlistentry>
-    <term>A or upperalpha</term>
-    <listitem>
-      <para>Uppercase letter numeration (A, B, C ...).</para>
-    </listitem>
-  </varlistentry>
-  <varlistentry>
-    <term>a or loweralpha</term>
-    <listitem>
-      <para>Lowercase letter numeration (a, b, c ...).</para>
-    </listitem>
-  </varlistentry>
-  <varlistentry>
-    <term>I or upperroman</term>
-    <listitem>
-      <para>Uppercase roman numeration (I, II, III ...).</para>
-    </listitem>
-  </varlistentry>
-  <varlistentry>
-    <term>i or lowerroman</term>
-    <listitem>
-      <para>Lowercase roman letter numeration (i, ii, iii ...).</para>
-    </listitem>
-  </varlistentry>
-</variablelist>
-
-<para>Any nonzero value other than the above will generate
-the default number format (arabic).
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="part.autolabel">
-<refmeta>
-<refentrytitle>part.autolabel</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">list</refmiscinfo> 
-<refmiscinfo class="other" otherclass="value">0<alt>none</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">1<alt>1,2,3...</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">A<alt>A,B,C...</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">a<alt>a,b,c...</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">i<alt>i,ii,iii...</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">I<alt>I,II,III...</alt></refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>part.autolabel</refname>
-<refpurpose>Specifies the labeling format for Part titles</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="part.autolabel.frag">
-&lt;xsl:param name="part.autolabel"&gt;I&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, then parts will be numbered using the parameter
-value as the number format if the value matches one of the following:
-</para>
-
-<variablelist>
-  <varlistentry>
-    <term>1 or arabic</term>
-    <listitem>
-      <para>Arabic numeration (1, 2, 3 ...).</para>
-    </listitem>
-  </varlistentry>
-  <varlistentry>
-    <term>A or upperalpha</term>
-    <listitem>
-      <para>Uppercase letter numeration (A, B, C ...).</para>
-    </listitem>
-  </varlistentry>
-  <varlistentry>
-    <term>a or loweralpha</term>
-    <listitem>
-      <para>Lowercase letter numeration (a, b, c ...).</para>
-    </listitem>
-  </varlistentry>
-  <varlistentry>
-    <term>I or upperroman</term>
-    <listitem>
-      <para>Uppercase roman numeration (I, II, III ...).</para>
-    </listitem>
-  </varlistentry>
-  <varlistentry>
-    <term>i or lowerroman</term>
-    <listitem>
-      <para>Lowercase roman letter numeration (i, ii, iii ...).</para>
-    </listitem>
-  </varlistentry>
-</variablelist>
-
-<para>Any nonzero value other than the above will generate
-the default number format (upperroman).
-</para>
-
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="reference.autolabel">
-<refmeta>
-<refentrytitle>reference.autolabel</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">list</refmiscinfo> 
-<refmiscinfo class="other" otherclass="value">0<alt>none</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">1<alt>1,2,3...</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">A<alt>A,B,C...</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">a<alt>a,b,c...</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">i<alt>i,ii,iii...</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">I<alt>I,II,III...</alt></refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>reference.autolabel</refname>
-<refpurpose>Specifies the labeling format for Reference titles</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-<programlisting id="reference.autolabel.frag">
-  &lt;xsl:param name="reference.autolabel"&gt;I&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-<refsection><info><title>Description</title></info>
-<para>If non-zero, references will be numbered using the parameter
-  value as the number format if the value matches one of the
-  following:
-</para>
-<variablelist>
-  <varlistentry>
-    <term>1 or arabic</term>
-    <listitem>
-      <para>Arabic numeration (1, 2, 3 ...).</para>
-    </listitem>
-  </varlistentry>
-  <varlistentry>
-    <term>A or upperalpha</term>
-    <listitem>
-      <para>Uppercase letter numeration (A, B, C ...).</para>
-    </listitem>
-  </varlistentry>
-  <varlistentry>
-    <term>a or loweralpha</term>
-    <listitem>
-      <para>Lowercase letter numeration (a, b, c ...).</para>
-    </listitem>
-  </varlistentry>
-  <varlistentry>
-    <term>I or upperroman</term>
-    <listitem>
-      <para>Uppercase roman numeration (I, II, III ...).</para>
-    </listitem>
-  </varlistentry>
-  <varlistentry>
-    <term>i or lowerroman</term>
-    <listitem>
-      <para>Lowercase roman letter numeration (i, ii, iii ...).</para>
-    </listitem>
-  </varlistentry>
-</variablelist>
-<para>Any non-zero value other than the above will generate
-the default number format (upperroman).
-</para>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="preface.autolabel">
-<refmeta>
-<refentrytitle>preface.autolabel</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">list</refmiscinfo> 
-<refmiscinfo class="other" otherclass="value">0<alt>none</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">1<alt>1,2,3...</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">A<alt>A,B,C...</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">a<alt>a,b,c...</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">i<alt>i,ii,iii...</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">I<alt>I,II,III...</alt></refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>preface.autolabel</refname>
-<refpurpose>Specifices the labeling format for Preface titles</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="preface.autolabel.frag">&lt;xsl:param name="preface.autolabel" select="0"&gt;&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero then prefaces will be numbered using the parameter
-value as the number format if the value matches one of the following:
-</para>
-
-<variablelist>
-  <varlistentry>
-    <term>1 or arabic</term>
-    <listitem>
-      <para>Arabic numeration (1, 2, 3 ...).</para>
-    </listitem>
-  </varlistentry>
-  <varlistentry>
-    <term>A or upperalpha</term>
-    <listitem>
-      <para>Uppercase letter numeration (A, B, C ...).</para>
-    </listitem>
-  </varlistentry>
-  <varlistentry>
-    <term>a or loweralpha</term>
-    <listitem>
-      <para>Lowercase letter numeration (a, b, c ...).</para>
-    </listitem>
-  </varlistentry>
-  <varlistentry>
-    <term>I or upperroman</term>
-    <listitem>
-      <para>Uppercase roman numeration (I, II, III ...).</para>
-    </listitem>
-  </varlistentry>
-  <varlistentry>
-    <term>i or lowerroman</term>
-    <listitem>
-      <para>Lowercase roman letter numeration (i, ii, iii ...).</para>
-    </listitem>
-  </varlistentry>
-</variablelist>
-
-<para>Any nonzero value other than the above will generate
-the default number format (arabic).
-</para>
-
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="section.autolabel">
-<refmeta>
-<refentrytitle>section.autolabel</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>section.autolabel</refname>
-<refpurpose>Are sections enumerated?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="section.autolabel.frag">&lt;xsl:param name="section.autolabel" select="0"&gt;&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If true (non-zero), unlabeled sections will be enumerated.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="section.autolabel.max.depth">
-<refmeta>
-<refentrytitle>section.autolabel.max.depth</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">integer</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>section.autolabel.max.depth</refname>
-<refpurpose>The deepest level of sections that are numbered.</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="section.autolabel.max.depth.frag">
-&lt;xsl:param name="section.autolabel.max.depth"&gt;8&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>When section numbering is turned on by the
-<parameter>section.autolabel</parameter> parameter, then this
-parameter controls the depth of <tag>section</tag> nesting that is
-numbered.  Sections nested to a level deeper than this value will not
-be numbered.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="section.label.includes.component.label">
-<refmeta>
-<refentrytitle>section.label.includes.component.label</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>section.label.includes.component.label</refname>
-<refpurpose>Do section labels include the component label?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="section.label.includes.component.label.frag">&lt;xsl:param name="section.label.includes.component.label" select="0"&gt;&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, section labels are prefixed with the label of the
-component that contains them.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="label.from.part">
-<refmeta>
-<refentrytitle>label.from.part</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>label.from.part</refname>
-<refpurpose>Renumber components in each part?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="label.from.part.frag">
-&lt;xsl:param name="label.from.part" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If <parameter>label.from.part</parameter> is non-zero, then
-  numbering of components &#8212; <tag>preface</tag>,
-  <tag>chapter</tag>, <tag>appendix</tag>, and
-  <tag>reference</tag> (when <tag>reference</tag> occurs at the
-  component level) &#8212; is re-started within each
-  <tag>part</tag>.</para>
-<para>If <parameter>label.from.part</parameter> is zero (the
-  default), numbering of components is <emphasis>not</emphasis>
-  re-started within each <tag>part</tag>; instead, components are
-  numbered sequentially throughout each <tag>book</tag>,
-  regardless of whether or not they occur within <tag>part</tag>
-  instances.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="component.label.includes.part.label">
-<refmeta>
-<refentrytitle>component.label.includes.part.label</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>component.label.includes.part.label</refname>
-<refpurpose>Do component labels include the part label?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="component.label.includes.part.label.frag">&lt;xsl:param name="component.label.includes.part.label" select="0"&gt;&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, number labels for <tag>chapter</tag>,
-<tag>appendix</tag>, and other component elements are prefixed with
-the label of the part element that contains them.  So you might see
-Chapter II.3 instead of Chapter 3.  Also, the labels for formal
-elements such as <tag>table</tag> and <tag>figure</tag> will include
-the part label.  If there is no part element container, then no prefix
-is generated.
-</para>
-<para>
-This feature is most useful when the
-<parameter>label.from.part</parameter> parameter is turned on.
-In that case, there would be more than one <tag>chapter</tag>
-<quote>1</quote>, and the extra part label prefix will identify
-each chapter unambiguously.
-</para>
-
-</refsection>
-</refentry>
-
-</reference><reference id="xslt" xml:base="../fo/param.xml"><title>XSLT Processing</title>
-<refentry version="5.0" id="rootid">
-<refmeta>
-<refentrytitle>rootid</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>rootid</refname>
-<refpurpose>Specify the root element to format</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="rootid.frag">
-&lt;xsl:param name="rootid"&gt;&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If <parameter>rootid</parameter> is not empty, it must be the
-value of an ID that occurs in the document being formatted. The entire
-document will be loaded and parsed, but formatting will begin at the
-element identified, rather than at the root. For example, this allows
-you to process only <tag>chapter</tag> 4 of a <tag>book</tag>.</para>
-<para>Because the entire document is available to the processor, automatic
-numbering, cross references, and other dependencies are correctly
-resolved.</para>
-
-</refsection>
-</refentry>
-
-</reference><reference id="meta" xml:base="../fo/param.xml"><title>Meta/*Info</title>
-<refentry version="5.0" id="make.single.year.ranges">
-<refmeta>
-<refentrytitle>make.single.year.ranges</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>make.single.year.ranges</refname>
-<refpurpose>Print single-year ranges (e.g., 1998-1999)</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="make.single.year.ranges.frag">
-&lt;xsl:param name="make.single.year.ranges" select="0"&gt;&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, year ranges that span a single year will be printed
-in range notation (1998-1999) instead of discrete notation
-(1998, 1999).</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="make.year.ranges">
-<refmeta>
-<refentrytitle>make.year.ranges</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>make.year.ranges</refname>
-<refpurpose>Collate copyright years into ranges?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="make.year.ranges.frag">&lt;xsl:param name="make.year.ranges" select="0"&gt;&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, multiple copyright <tag>year</tag> elements will be
-collated into ranges.
-This works only if each year number is put into a separate
-year element.  The copyright element permits multiple
-year elements. If a year element contains a dash or
-a comma, then that year element will not be merged into
-any range.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="author.othername.in.middle">
-<refmeta>
-<refentrytitle>author.othername.in.middle</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>author.othername.in.middle</refname>
-<refpurpose>Is <tag>othername</tag> in <tag>author</tag> a
-middle name?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="author.othername.in.middle.frag">
-&lt;xsl:param name="author.othername.in.middle" select="1"&gt;&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, the <tag>othername</tag> of an <tag>author</tag>
-appears between the <tag>firstname</tag> and
-<tag>surname</tag>.  Otherwise, <tag>othername</tag>
-is suppressed.
-</para>
-
-</refsection>
-</refentry>
-
-</reference><reference id="refentry" xml:base="../fo/param.xml"><title>Reference Pages</title>
-<refentry version="5.0" id="funcsynopsis.decoration">
-<refmeta>
-<refentrytitle>funcsynopsis.decoration</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>funcsynopsis.decoration</refname>
-<refpurpose>Decorate elements of a <tag>funcsynopsis</tag>?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="funcsynopsis.decoration.frag">
-&lt;xsl:param name="funcsynopsis.decoration" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, elements of the <tag>funcsynopsis</tag> will be
-decorated (e.g. rendered as bold or italic text). The decoration is controlled by
-templates that can be redefined in a customization layer.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="funcsynopsis.style">
-<refmeta>
-<refentrytitle>funcsynopsis.style</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">list</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">ansi</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">kr</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>funcsynopsis.style</refname>
-<refpurpose>What style of <tag>funcsynopsis</tag> should be generated?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="funcsynopsis.style.frag">&lt;xsl:param name="funcsynopsis.style"&gt;kr&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If <parameter>funcsynopsis.style</parameter> is <literal>ansi</literal>,
-ANSI-style function synopses are generated for a
-<tag>funcsynopsis</tag>, otherwise K&amp;R-style
-function synopses are generated.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="function.parens">
-<refmeta>
-<refentrytitle>function.parens</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>function.parens</refname>
-<refpurpose>Generate parens after a function?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="function.parens.frag">
-&lt;xsl:param name="function.parens" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, the formatting of a <tag>function</tag> element
-will include generated parentheses.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="refentry.generate.name">
-<refmeta>
-<refentrytitle>refentry.generate.name</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>refentry.generate.name</refname>
-<refpurpose>Output NAME header before <tag>refname</tag>s?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="refentry.generate.name.frag">
-&lt;xsl:param name="refentry.generate.name" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, a "NAME" section title is output before the list
-of <tag>refname</tag>s. This parameter and
-<parameter>refentry.generate.title</parameter> are mutually
-exclusive. This means that if you change this parameter to zero, you
-should set <parameter>refentry.generate.title</parameter> to non-zero unless
-you want get quite strange output.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="refentry.generate.title">
-<refmeta>
-<refentrytitle>refentry.generate.title</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>refentry.generate.title</refname>
-<refpurpose>Output title before <tag>refname</tag>s?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="refentry.generate.title.frag">
-&lt;xsl:param name="refentry.generate.title" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, the reference page title or first name is
-output before the list of <tag>refname</tag>s. This parameter and
-<parameter>refentry.generate.name</parameter> are mutually exclusive.
-This means that if you change this parameter to non-zero, you
-should set <parameter>refentry.generate.name</parameter> to zero unless
-you want get quite strange output.</para>
-
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="refentry.pagebreak">
-<refmeta>
-<refentrytitle>refentry.pagebreak</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>refentry.pagebreak</refname>
-<refpurpose>Start each refentry on a new page</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="refentry.pagebreak.frag">&lt;xsl:param name="refentry.pagebreak" select="1"&gt;&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero (the default), each <tag>refentry</tag>
-element will start on a new page.  If zero, a page
-break will not be generated between <tag>refentry</tag> elements.
-The exception is when the <tag>refentry</tag> elements are children of
-a <tag>part</tag> element, in which case the page breaks are always
-retained.  That is because a <tag>part</tag> element does not generate
-a page-sequence for its children, so each <tag>refentry</tag> must
-start its own page-sequence.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="refentry.title.properties">
-<refmeta>
-<refentrytitle>refentry.title.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>refentry.title.properties</refname>
-<refpurpose>Title properties for a refentry title</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="refentry.title.properties.frag">
-&lt;xsl:attribute-set name="refentry.title.properties"&gt;
-  &lt;xsl:attribute name="font-family"&gt;
-    &lt;xsl:value-of select="$title.fontset"&gt;&lt;/xsl:value-of&gt;
-  &lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="font-size"&gt;18pt&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="font-weight"&gt;bold&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="space-after"&gt;1em&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="hyphenate"&gt;false&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="keep-with-next.within-column"&gt;always&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="space-before.minimum"&gt;0.8em&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="space-before.optimum"&gt;1.0em&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="space-before.maximum"&gt;1.2em&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="space-after.optimum"&gt;0.5em&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="space-after.minimum"&gt;0.4em&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="space-after.maximum"&gt;0.6em&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="start-indent"&gt;&lt;xsl:value-of select="$title.margin.left"&gt;&lt;/xsl:value-of&gt;&lt;/xsl:attribute&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Formatting properties applied to the title generated for the
-<tag>refnamediv</tag> part of output for
-<tag>refentry</tag> when the value of the
-<parameter>refentry.generate.title</parameter> parameter is
-non-zero. The font size is supplied by the appropriate <parameter>section.level<replaceable>X</replaceable>.title.properties</parameter>
-attribute-set, computed from the location of the
-<tag>refentry</tag> in the section hierarchy.</para>
-
-<note>
-  <para>This parameter has no effect on the the title generated for
-  the <tag>refnamediv</tag> part of output for
-  <tag>refentry</tag> when the value of the
-  <parameter>refentry.generate.name</parameter> parameter is
-  non-zero. By default, that title is formatted with the same
-  properties as the titles for all other first-level children of
-  <tag>refentry</tag>.</para>
-</note>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="refentry.xref.manvolnum">
-<refmeta>
-<refentrytitle>refentry.xref.manvolnum</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>refentry.xref.manvolnum</refname>
-<refpurpose>Output <tag>manvolnum</tag> as part of 
-<tag>refentry</tag> cross-reference?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="refentry.xref.manvolnum.frag">
-&lt;xsl:param name="refentry.xref.manvolnum" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>if non-zero, the <tag>manvolnum</tag> is used when cross-referencing
-<tag>refentry</tag>s, either with <tag>xref</tag>
-or <tag>citerefentry</tag>.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="refclass.suppress">
-<refmeta>
-<refentrytitle>refclass.suppress</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>refclass.suppress</refname>
-<refpurpose>Suppress display of refclass contents?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="refclass.suppress.frag">
-&lt;xsl:param name="refclass.suppress" select="0"&gt;&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If the value of <parameter>refclass.suppress</parameter> is
-non-zero, then display of <tag>refclass</tag> contents is
-suppressed in output.</para>
-
-</refsection>
-</refentry>
-
-</reference><reference id="tables" xml:base="../fo/param.xml"><title>Tables</title>
-<refentry version="5.0" id="default.table.width">
-<refmeta>
-<refentrytitle>default.table.width</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">length</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>default.table.width</refname>
-<refpurpose>The default width of tables</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-<programlisting id="default.table.width.frag">
-&lt;xsl:param name="default.table.width"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-<refsection><info><title>Description</title></info>
-<para>If non-zero, this value will be used for the
-<literal>width</literal> attribute on <tag>table</tag>s that do not specify an
-alternate width (with the <tag class="xmlpi">dbhtml table-width</tag> or 
-<tag class="xmlpi">dbfo table-width</tag> processing instruction).</para>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="nominal.table.width">
-<refmeta>
-<refentrytitle>nominal.table.width</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">length</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>nominal.table.width</refname>
-<refpurpose>The (absolute) nominal width of tables</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="nominal.table.width.frag">
-&lt;xsl:param name="nominal.table.width"&gt;6in&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>In order to convert CALS column widths into HTML column widths, it
-is sometimes necessary to have an absolute table width to use for conversion
-of mixed absolute and relative widths. This value must be an absolute
-length (not a percentage).</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="default.table.frame">
-<refmeta>
-<refentrytitle>default.table.frame</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>default.table.frame</refname>
-<refpurpose>The default framing of tables</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="default.table.frame.frag">
-&lt;xsl:param name="default.table.frame"&gt;all&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This value will be used when there is no frame attribute on the
-table. </para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="default.table.rules">
-<refmeta>
-<refentrytitle>default.table.rules</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>default.table.rules</refname>
-<refpurpose>The default column and row rules for tables using HTML markup</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="default.table.rules.frag">
-&lt;xsl:param name="default.table.rules"&gt;none&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Tables using HTML markup elements can use an attribute
-named <tag class="attribute">rules</tag> on the <tag>table</tag> or
-<tag>informaltable</tag> element
-to specify whether column and row border rules should be 
-displayed. This parameter lets you specify a global default
-style for all HTML tables that don't otherwise have
-that attribute.</para>
-<para>These are the supported values:</para>
-
-<variablelist>
-<varlistentry><term>all</term>
-<listitem>
-<para>Rules will appear between all rows and columns.</para>
-</listitem>
-</varlistentry>
-
-<varlistentry><term>rows</term>
-<listitem>
-<para>Rules will appear between rows only.</para>
-</listitem>
-</varlistentry>
-
-<varlistentry><term>cols</term>
-<listitem>
-<para>Rules will appear between columns only.</para>
-</listitem>
-</varlistentry>
-
-<varlistentry><term>groups</term>
-<listitem>
-<para>Rules will appear between row groups (thead, tfoot, tbody).
-No support for rules between column groups yet.
-</para>
-</listitem>
-</varlistentry>
-
-<varlistentry><term>none</term>
-<listitem>
-<para>No rules.  This is the default value.
-</para>
-</listitem>
-</varlistentry>
-
-</variablelist>
-
-<para>The border after the last row and the border after
-the last column are not affected by
-this setting. Those borders are controlled by
-the <tag class="attribute">frame</tag> attribute on the table element.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="table.cell.padding">
-<refmeta>
-<refentrytitle>table.cell.padding</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>table.cell.padding</refname>
-<refpurpose>Specifies the padding of table cells</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="table.cell.padding.frag">
-&lt;xsl:attribute-set name="table.cell.padding"&gt;
-  &lt;xsl:attribute name="padding-start"&gt;2pt&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="padding-end"&gt;2pt&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="padding-top"&gt;2pt&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="padding-bottom"&gt;2pt&lt;/xsl:attribute&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Specifies the padding of table cells.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="table.frame.border.thickness">
-<refmeta>
-<refentrytitle>table.frame.border.thickness</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">length</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>table.frame.border.thickness</refname>
-<refpurpose>Specifies the thickness of the frame border</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="table.frame.border.thickness.frag">
-&lt;xsl:param name="table.frame.border.thickness"&gt;0.5pt&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Specifies the thickness of the border on the table's frame.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="table.frame.border.style">
-<refmeta>
-<refentrytitle>table.frame.border.style</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">list</refmiscinfo> 
-<refmiscinfo class="other" otherclass="value">none</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">solid</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">dotted</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">dashed</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">double</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">groove</refmiscinfo>                       
-<refmiscinfo class="other" otherclass="value">ridge</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">inset</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">outset</refmiscinfo>          
-<refmiscinfo class="other" otherclass="value">solid</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>table.frame.border.style</refname>
-<refpurpose>Specifies the border style of table frames</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="table.frame.border.style.frag">
-&lt;xsl:param name="table.frame.border.style"&gt;solid&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Specifies the border style of table frames.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="table.frame.border.color">
-<refmeta>
-<refentrytitle>table.frame.border.color</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">color</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>table.frame.border.color</refname>
-<refpurpose>Specifies the border color of table frames</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="table.frame.border.color.frag">
-
-&lt;xsl:param name="table.frame.border.color"&gt;black&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Specifies the border color of table frames.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="table.cell.border.thickness">
-<refmeta>
-<refentrytitle>table.cell.border.thickness</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">length</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>table.cell.border.thickness</refname>
-<refpurpose>Specifies the thickness of table cell borders</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="table.cell.border.thickness.frag">
-&lt;xsl:param name="table.cell.border.thickness"&gt;0.5pt&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, specifies the thickness of borders on table
-cells. The units are points. See <link xlink:href="http://www.w3.org/TR/CSS21/box.html#border-width-properties">
-CSS</link></para>
-
-<note>
-  <para>To control properties of cell borders in HTML output, you must also turn on the 
-  <parameter>table.borders.with.css</parameter> parameter.</para>
-</note>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="table.cell.border.style">
-<refmeta>
-<refentrytitle>table.cell.border.style</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">list</refmiscinfo> 
-<refmiscinfo class="other" otherclass="value">none</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">solid</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">dotted</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">dashed</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">double</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">groove</refmiscinfo>                       
-<refmiscinfo class="other" otherclass="value">ridge</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">inset</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">outset</refmiscinfo>          
-<refmiscinfo class="other" otherclass="value">solid</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>table.cell.border.style</refname>
-<refpurpose>Specifies the border style of table cells</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="table.cell.border.style.frag">
-&lt;xsl:param name="table.cell.border.style"&gt;solid&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Specifies the border style of table cells.</para>
-
-<note>
-  <para>To control properties of cell borders in HTML output, you must also turn on the 
-  <parameter>table.borders.with.css</parameter> parameter.</para>
-</note>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="table.cell.border.color">
-<refmeta>
-<refentrytitle>table.cell.border.color</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">color</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>table.cell.border.color</refname>
-<refpurpose>Specifies the border color of table cells</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="table.cell.border.color.frag">
-
-&lt;xsl:param name="table.cell.border.color"&gt;black&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Set the color of table cell borders. If non-zero, the value is used
-for the border coloration. See <link xlink:href="http://www.w3.org/TR/CSS21/syndata.html#value-def-color">CSS</link>. A
-<literal>color</literal> is either a keyword or a numerical RGB specification.
-Keywords are aqua, black, blue, fuchsia, gray, green, lime, maroon,
-navy, olive, orange, purple, red, silver, teal, white, and
-yellow.</para>
-
-<note>
-  <para>To control properties of cell borders in HTML output, you must also turn on the 
-  <parameter>table.borders.with.css</parameter> parameter.</para>
-</note>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="table.table.properties">
-<refmeta>
-<refentrytitle>table.table.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>table.table.properties</refname>
-<refpurpose>Properties associated with a table</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="table.table.properties.frag">
-&lt;xsl:attribute-set name="table.table.properties"&gt;
-  &lt;xsl:attribute name="border-before-width.conditionality"&gt;retain&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="border-collapse"&gt;collapse&lt;/xsl:attribute&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The styling for tables. This parameter should really
-have been called <literal>table.properties</literal>, but that parameter
-name was inadvertently established for the block-level properties
-of the table as a whole.
-</para>
-
-<para>See also <parameter>table.properties</parameter>.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="table.caption.properties">
-<refmeta>
-<refentrytitle>table.caption.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>table.caption.properties</refname>
-<refpurpose>Properties associated with a table caption</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="table.caption.properties.frag">
-&lt;xsl:attribute-set name="table.caption.properties"&gt;
-  &lt;xsl:attribute name="keep-together.within-column"&gt;always&lt;/xsl:attribute&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The styling for table caption element (not the table title).</para>
-
-<para>See also <parameter>table.properties</parameter>.</para>
-
-</refsection>
-</refentry>
-
-</reference><reference id="links" xml:base="../fo/param.xml"><title>Linking</title>
-<refentry version="5.0" id="current.docid"> 
-<refmeta> 
-<refentrytitle>current.docid</refentrytitle> 
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo> 
-</refmeta> 
-<refnamediv> 
-<refname>current.docid</refname> 
-<refpurpose>targetdoc identifier for the document being
-processed</refpurpose> 
-</refnamediv> 
-<refsynopsisdiv> <programlisting id="current.docid.frag">
-&lt;xsl:param name="current.docid"&gt;&lt;/xsl:param&gt;
-</programlisting> 
-</refsynopsisdiv> 
-<refsection><info><title>Description</title></info> 
- 
-<para>When olinks between documents are resolved for HTML output, the stylesheet can compute the relative path between the current document and the target document. The stylesheet needs to know the <literal>targetdoc</literal> identifiers for both documents, as they appear in the <parameter>target.database.document</parameter> database file. This parameter passes to the stylesheet
-the targetdoc identifier of the current document, since that
-identifier does not appear in the document itself. </para>
-<para>This parameter can also be used for print output. If an olink's  <literal>targetdoc</literal>  id differs from the <literal>current.docid</literal>, then the stylesheet can append the target document's title to the generated olink text. That identifies to the reader that the link is to a different document, not the current document. See also <parameter>olink.doctitle</parameter> to enable that feature.</para> 
-</refsection> 
-</refentry>
-
-<refentry version="5.0" id="activate.external.olinks">
-<refmeta>
-<refentrytitle>activate.external.olinks</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>activate.external.olinks</refname>
-<refpurpose>Make external olinks into active links</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="activate.external.olinks.frag">
-&lt;xsl:param name="activate.external.olinks" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If <parameter>activate.external.olinks</parameter> is nonzero
-(the default), then any olinks that reference another document
-become active links that can be clicked on to follow the link.
-If the parameter is set to zero, then external olinks
-will have the appropriate link text generated, but the link is
-not made active.  Olinks to destinations in
-the current document remain active.</para>
-
-<para>To make an external olink active for HTML
-outputs, the link text is wrapped in an <tag>a</tag>
-element with an <tag>href</tag> attribute. To
-make an external olink active for FO outputs, the link text is
-wrapped in an <tag>fo:basic-link</tag> element with an
-<tag>external-destination</tag> attribute.</para>
-
-<para>This parameter is useful when you need external olinks
-to resolve but not be clickable. For example, if documents
-in a collection are available independently of each other,
-then having active links between them could lead to
-unresolved links when a given target document is missing.</para>
-
-<para>The epub stylesheets set this parameter to zero by default
-because there is no standard linking mechanism between Epub documents.</para>
-
-<para>If external links are made inactive, you should
-consider setting the
-stylesheet parameter <parameter>olink.doctitle</parameter>
-to <literal>yes</literal>. That will append the external document's
-title to the link text, making it easier for the user to
-locate the other document.</para>
-
-<para>An olink is considered external when the
-<parameter>current.docid</parameter> stylesheet parameter
-is set to some value, and the olink's <tag>targetdoc</tag>
-attribute has a different value. If the two values
-match, then the link is considered internal.  If the
-<parameter>current.docid</parameter> parameter is blank, or
-the <tag>olink</tag> element does not have a <tag>targetdoc</tag> attribute,
-then the link is considered to be internal and will become
-an active link.</para>
-
-<para>See also <parameter>olink.doctitle</parameter>,
-<parameter>prefer.internal.olink</parameter>.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="collect.xref.targets"> 
-<refmeta> 
-<refentrytitle>collect.xref.targets</refentrytitle> 
-<refmiscinfo class="other" otherclass="datatype">list</refmiscinfo> 
-<refmiscinfo class="other" otherclass="value">no</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">yes</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">only</refmiscinfo>
-</refmeta> 
-<refnamediv> 
-<refname>collect.xref.targets</refname> 
-<refpurpose>Controls whether cross reference data is
-collected</refpurpose> 
-</refnamediv> 
-<refsynopsisdiv> <programlisting id="collect.xref.targets.frag">
-&lt;xsl:param name="collect.xref.targets"&gt;no&lt;/xsl:param&gt;
-</programlisting> 
-</refsynopsisdiv> 
-<refsection><info><title>Description</title></info> 
- 
-<para>
-In order to resolve olinks efficiently, the stylesheets can
-generate an external data file containing information about
-all potential cross reference endpoints in a document.
-This parameter determines whether the collection process is run when the document is processed by the stylesheet. The default value is  <literal>no</literal>, which means the data file is not generated during processing. The other choices are <literal>yes</literal>, which means the data file is created and the document is processed for output, and <literal>only</literal>, which means the data file is created but the document is not processed for output.
-See also <parameter>targets.filename</parameter>.
-</para> 
-</refsection> 
-</refentry>
-
-<refentry version="5.0" id="insert.olink.page.number">
-<refmeta>
-<refentrytitle>insert.olink.page.number</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">list</refmiscinfo> 
-<refmiscinfo class="other" otherclass="value">no</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">yes</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">maybe</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>insert.olink.page.number</refname>
-<refpurpose>Turns page numbers in olinks on and off</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="insert.olink.page.number.frag">
-&lt;xsl:param name="insert.olink.page.number"&gt;no&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The value of this parameter determines if
-cross references made between documents with
-<tag>olink</tag> will 
-include page number citations.
-In most cases this is only applicable to references in printed output.
-</para>
-<para>The parameter has three possible values.
-</para>
-<variablelist>
-<varlistentry>
-<term>no</term>
-<listitem><para>No page number references will be generated for olinks.
-</para></listitem>
-</varlistentry>
-<varlistentry>
-<term>yes</term>
-<listitem><para>Page number references will be generated
-for all <tag>olink</tag> references.
-The style of page reference may be changed
-if an <tag class="attribute">xrefstyle</tag>
-attribute is used.
-</para></listitem>
-</varlistentry>
-<varlistentry>
-<term>maybe</term>
-<listitem><para>Page number references will not be generated
-for an <tag>olink</tag> element unless 
-it has an
-<tag class="attribute">xrefstyle</tag>
-attribute whose value specifies a page reference.
-</para></listitem>
-</varlistentry>
-</variablelist>
-<para>Olinks that point to targets within the same document
-are treated as <tag>xref</tag>s, and controlled by
-the <parameter>insert.xref.page.number</parameter> parameter.
-</para>
-
-<para>Page number references for olinks to
-external documents can only be inserted if the 
-information exists in the olink database. 
-This means each olink target element 
-(<tag>div</tag> or <tag>obj</tag>)
-must have a <tag class="attribute">page</tag> attribute
-whose value is its page number in the target document.
-The XSL stylesheets are not able to extract that information
-during processing because pages have not yet been created in
-XSLT transformation.  Only the XSL-FO processor knows what
-page each element is placed on.
-Therefore some postprocessing must take place to populate
-page numbers in the olink database.
-</para>
-
-
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="insert.olink.pdf.frag">
-<refmeta>
-<refentrytitle>insert.olink.pdf.frag</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>insert.olink.pdf.frag</refname>
-<refpurpose>Add fragment identifiers for links into PDF files</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="insert.olink.pdf.frag.frag">
-&lt;xsl:param name="insert.olink.pdf.frag" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The value of this parameter determines whether
-the cross reference URIs to PDF documents made with
-<tag>olink</tag> will 
-include fragment identifiers.
-</para>
-
-<para>When forming a URI to link to a PDF document,
-a fragment identifier (typically a '#' followed by an
-id value) appended to the PDF filename can be used by
-the PDF viewer to open
-the PDF file to a location within the document instead of
-the first page.
-However, not all PDF files have id
-values embedded in them, and not all PDF viewers can
-handle fragment identifiers. 
-</para>
-
-<para>If <parameter>insert.olink.pdf.frag</parameter> is set
-to a non-zero value, then any olink targeting a
-PDF file will have the fragment identifier appended to the URI.
-The URI is formed by concatenating the value of the
-<parameter>olink.base.uri</parameter> parameter, the
-value of the <tag class="attribute">baseuri</tag>
-attribute from the <tag class="element">document</tag>
-element in the olink database with the matching
-<tag class="attribute">targetdoc</tag> value,
-and the value of the <tag class="attribute">href</tag>
-attribute for the targeted element in the olink database.
-The <tag class="attribute">href</tag> attribute
-contains the fragment identifier.
-</para>
-
-<para>If <parameter>insert.olink.pdf.frag</parameter> is set
-to zero (the default value), then 
-the <tag class="attribute">href</tag> attribute
-from the olink database
-is not appended to PDF olinks, so the fragment identifier is left off.
-A PDF olink is any olink for which the
-<tag class="attribute">baseuri</tag> attribute
-from the matching <tag class="element">document</tag>
-element in the olink database ends with '.pdf'.
-Any other olinks will still have the fragment identifier added.
-</para>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="olink.base.uri"> 
-<refmeta> 
-<refentrytitle>olink.base.uri</refentrytitle> 
-<refmiscinfo class="other" otherclass="datatype">uri</refmiscinfo> 
-</refmeta> 
-<refnamediv> 
-<refname>olink.base.uri</refname> 
-<refpurpose>Base URI used in olink hrefs</refpurpose> 
-</refnamediv> 
-<refsynopsisdiv> <programlisting id="olink.base.uri.frag">
-&lt;xsl:param name="olink.base.uri"&gt;&lt;/xsl:param&gt;
-</programlisting> 
-</refsynopsisdiv> 
-<refsection><info><title>Description</title></info> 
- 
-<para>When cross reference data is collected for resolving olinks, it
-may be necessary to prepend a base URI to each target's href. This
-parameter lets you set that base URI when cross reference data is
-collected. This feature is needed when you want to link to a document
-that is processed without chunking. The output filename for such a
-document is not known to the XSL stylesheet; the only target
-information consists of fragment identifiers such as
-<literal>#idref</literal>. To enable the resolution of olinks between
-documents, you should pass the name of the HTML output file as the
-value of this parameter. Then the hrefs recorded in the cross
-reference data collection look like
-<literal>outfile.html#idref</literal>, which can be reached as links
-from other documents.</para>
-</refsection> 
-</refentry>
-
-<refentry version="5.0" id="olink.debug">
-<refmeta>
-<refentrytitle>olink.debug</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>olink.debug</refname>
-<refpurpose>Turn on debugging messages for olinks</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="olink.debug.frag">
-&lt;xsl:param name="olink.debug" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, then each olink will generate several
-messages about how it is being resolved during processing.
-This is useful when an olink does not resolve properly
-and the standard error messages are not sufficient to
-find the problem. 
-</para>
-
-<para>You may need to read through the olink XSL templates
-to understand the context for some of the debug messages.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="olink.doctitle"> 
-<refmeta> 
-<refentrytitle>olink.doctitle</refentrytitle> 
-<refmiscinfo class="other" otherclass="datatype">list</refmiscinfo> 
-<refmiscinfo class="other" otherclass="value">no</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">yes</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">maybe</refmiscinfo>
-</refmeta> 
-<refnamediv> 
-<refname>olink.doctitle</refname> 
-<refpurpose>show the document title for external olinks?</refpurpose>
-
-</refnamediv> 
-<refsynopsisdiv> <programlisting id="olink.doctitle.frag">
-&lt;xsl:param name="olink.doctitle"&gt;no&lt;/xsl:param&gt; 
-</programlisting> 
-</refsynopsisdiv> 
-<refsection><info><title>Description</title></info> 
- 
-<para>When olinks between documents are resolved, the generated text
-may not make it clear that the reference is to another document.
-It is possible for the stylesheets to append the other document's
-title to external olinks. For this to happen, two parameters must
-be set.</para>
-<itemizedlist>
-<listitem>
-<para>This <parameter>olink.doctitle</parameter> parameter
-should be set to either <literal>yes</literal> or <literal>maybe</literal>
-to enable this feature.
-</para>
-</listitem>
-<listitem>
-<para>And you should also set the <parameter>current.docid</parameter>
-parameter to the document id for the  document currently
-being processed for output.
-</para>
-</listitem>
-</itemizedlist>
-
-<para>
-Then if an olink's  <literal>targetdoc</literal> id differs from
-the <literal>current.docid</literal> value, the stylesheet knows
-that it is a reference to another document and can
-append the target document's
-title to the generated olink text. </para> 
-
-<para>The text for the target document's title is copied from the
-olink database from the <tag>ttl</tag> element
-of the top-level <tag>div</tag> for that document.
-If that <tag>ttl</tag> element is missing or empty,
-no title is output.
-</para>
-
-<para>The supported values for <parameter>olink.doctitle</parameter> are:
-</para>
-<variablelist>
-<varlistentry>
-<term><literal>yes</literal></term>
-<listitem>
-<para>
-Always insert the title to the target document if it is not
-the current document.
-</para>
-</listitem>
-</varlistentry>
-<varlistentry>
-<term><literal>no</literal></term>
-<listitem>
-<para>
-Never insert the title to the target document, even if requested
-in an <tag class="attribute">xrefstyle</tag> attribute.
-</para>
-</listitem>
-</varlistentry>
-<varlistentry>
-<term><literal>maybe</literal></term>
-<listitem>
-<para>
-Only insert the title to the target document, if requested
-in an <tag class="attribute">xrefstyle</tag> attribute.
-</para>
-</listitem>
-</varlistentry>
-</variablelist>
-<para>An <tag class="attribute">xrefstyle</tag> attribute
-may override the global setting for individual olinks.
-The following values are supported in an
-<tag class="attribute">xrefstyle</tag>
-attribute using the <literal>select:</literal> syntax:
-</para>
-
-<variablelist>
-<varlistentry>
-<term><literal>docname</literal></term>
-<listitem>
-<para>
-Insert the target document name for this olink using the
-<literal>docname</literal> gentext template, but only
-if the value of <parameter>olink.doctitle</parameter>
-is not <literal>no</literal>.
-</para>
-</listitem>
-</varlistentry>
-<varlistentry>
-<term><literal>docnamelong</literal></term>
-<listitem>
-<para>
-Insert the target document name for this olink using the
-<literal>docnamelong</literal> gentext template, but only
-if the value of <parameter>olink.doctitle</parameter>
-is not <literal>no</literal>.
-</para>
-</listitem>
-</varlistentry>
-<varlistentry>
-<term><literal>nodocname</literal></term>
-<listitem>
-<para>
-Omit the target document name even if
-the value of <parameter>olink.doctitle</parameter>
-is <literal>yes</literal>.
-</para>
-</listitem>
-</varlistentry>
-</variablelist>
-<para>Another way of inserting the target document name 
-for a single olink is to employ an
-<tag class="attribute">xrefstyle</tag>
-attribute using the <literal>template:</literal> syntax.
-The <literal>%o</literal> placeholder (the letter o, not zero)
-in such a template
-will be filled in with the target document's title when it is processed.
-This will occur regardless of 
-the value of <parameter>olink.doctitle</parameter>.
-</para>
-<para>Note that prior to version 1.66 of the XSL stylesheets,
-the allowed values for this parameter were 0 and 1.  Those
-values are still supported and mapped to 'no' and 'yes', respectively.
-</para>
-</refsection> 
-</refentry>
-
-<refentry version="5.0" id="olink.lang.fallback.sequence"> 
-<refmeta> 
-<refentrytitle>olink.lang.fallback.sequence</refentrytitle> 
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo> 
-</refmeta> 
-<refnamediv> 
-<refname>olink.lang.fallback.sequence</refname> 
-<refpurpose>look up translated documents if olink not found?</refpurpose>
-
-</refnamediv> 
-<refsynopsisdiv> <programlisting id="olink.lang.fallback.sequence.frag">
-&lt;xsl:param name="olink.lang.fallback.sequence"&gt;&lt;/xsl:param&gt;
-</programlisting> 
-</refsynopsisdiv> 
-<refsection><info><title>Description</title></info> 
- 
-
-<para>This parameter defines a list of lang values
-to search among to resolve olinks.
-</para>
-
-<para>Normally an olink tries to resolve to a document in the same
-language as the olink itself.  The language of an olink
-is determined by its nearest ancestor element with a
-<tag class="attribute">lang</tag> attribute, otherwise the
-value of the <parameter>l10n.gentext.default.lang</parameter>
-parameter.
-</para>
-
-<para>An olink database can contain target data for the same
-document in multiple languages.  Each set of data has the
-same value for the <tag>targetdoc</tag> attribute in
-the <tag>document</tag> element in the database, but with a 
-different <tag>lang</tag> attribute value.
-</para>
-
-<para>When an olink is being resolved, the target is first
-sought in the document with the same language as the olink.
-If no match is found there, then this parameter is consulted
-for additional languages to try.</para>
-
-<para>The <parameter>olink.lang.fallback.sequence</parameter>
-must be a whitespace separated list of lang values to
-try.  The first one with a match in the olink database is used.
-The default value is empty.</para>
-
-<para>For example, a document might be written in German
-and contain an olink with
-<literal>targetdoc="adminguide"</literal>.
-When the document is processed, the processor
-first looks for a target dataset in the
-olink database starting with:</para>
-
-<literallayout><literal>&lt;document targetdoc="adminguide" lang="de"&gt;</literal>.
-</literallayout>
-
-<para>If there is no such element, then the
-<parameter>olink.lang.fallback.sequence</parameter> 
-parameter is consulted.
-If its value is, for example, <quote>fr en</quote>, then the processor next
-looks for <literal>targetdoc="adminguide" lang="fr"</literal>, and
-then for <literal>targetdoc="adminguide" lang="en"</literal>.
-If there is still no match, it looks for
-<literal>targetdoc="adminguide"</literal> with no
-lang attribute.
-</para>
-
-<para>This parameter is useful when a set of documents is only
-partially translated, or is in the process of being translated.  
-If a target of an olink has not yet been translated, then this
-parameter permits the processor to look for the document in
-other languages.  This assumes the reader would rather have
-a link to a document in a different language than to have
-a broken link.
-</para>
-
-</refsection> 
-</refentry>
-
-<refentry version="5.0" id="olink.properties">
-<refmeta>
-<refentrytitle>olink.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>olink.properties</refname>
-<refpurpose>Properties associated with the cross-reference 
-text of an olink.</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="olink.properties.frag">
-&lt;xsl:attribute-set name="olink.properties"&gt;
-  &lt;xsl:attribute name="show-destination"&gt;replace&lt;/xsl:attribute&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This <literal>attribute set</literal> is applied to the
-<literal>fo:basic-link</literal> element of an olink. It is not applied to the
-optional page number or optional title of the external
-document.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="prefer.internal.olink">
-<refmeta>
-<refentrytitle>prefer.internal.olink</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>prefer.internal.olink</refname>
-<refpurpose>Prefer a local olink reference to an external reference</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="prefer.internal.olink.frag">
-&lt;xsl:param name="prefer.internal.olink" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If you are re-using XML content modules in multiple documents,
-you may want to redirect some of your olinks.  This parameter
-permits you to redirect an olink to the current document.
-</para>
-
-<para>For example: you are writing documentation for a  product, 
-which includes 3 manuals: a little installation
-booklet (booklet.xml), a user 
-guide (user.xml), and a reference manual (reference.xml).
-All 3 documents begin with the same introduction section (intro.xml) that 
-contains a reference to the customization section (custom.xml) which is 
-included in both user.xml and reference.xml documents.
-</para>
-
-<para>How do you write the link to custom.xml in intro.xml
-so that it is interpreted correctly in all 3 documents?</para>
-<itemizedlist>
-<listitem><para>If you use xref, it will fail in user.xml.</para>
-</listitem>
-<listitem><para>If you use olink (pointing to reference.xml),
-the reference in user.xml  
-will point to the customization section of the reference manual, while it is 
-actually available in user.xml.</para>
-</listitem>
-</itemizedlist>
-
-<para>If you set the <parameter>prefer.internal.olink</parameter>
-parameter to a non-zero value, then the processor will
-first look in the olink database
-for the olink's <tag>targetptr</tag> attribute value
-in document matching the <parameter>current.docid</parameter>
-parameter value.  If it isn't found there, then
-it tries the document in the database
-with the <tag>targetdoc</tag>
-value that matches the olink's <tag>targetdoc</tag>
-attribute.
-</para>
-
-<para>This feature permits an olink reference to resolve to
-the current document if there is an element
-with an id matching the olink's <tag>targetptr</tag>
-value.  The current document's olink data must be
-included in the target database for this to work.</para>
-
-<caution>
-<para>There is a potential for incorrect links if
-the same <tag>id</tag> attribute value is used for different
-content in different documents.
-Some of your olinks may be redirected to the current document
-when they shouldn't be.  It is not possible to control
-individual olink instances.</para>
-</caution>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="target.database.document"> 
-<refmeta> 
-<refentrytitle>target.database.document</refentrytitle> 
-<refmiscinfo class="other" otherclass="datatype">uri</refmiscinfo> 
-</refmeta> 
-<refnamediv> 
-<refname>target.database.document</refname> 
-<refpurpose>Name of master database file for resolving
-olinks</refpurpose> 
-</refnamediv> 
-<refsynopsisdiv> 
-<programlisting id="target.database.document.frag">
- &lt;xsl:param name="target.database.document"&gt;olinkdb.xml&lt;/xsl:param&gt;
-</programlisting> 
-</refsynopsisdiv> 
-<refsection><info><title>Description</title></info>
- 
-<para>
-To resolve olinks between documents, the stylesheets use a master
-database document that identifies the target datafiles for all the
-documents within the scope of the olinks. This parameter value is the
-URI of the master document to be read during processing to resolve
-olinks.  The default value is <filename>olinkdb.xml</filename>.</para>
-
-<para>The data structure of the file is defined in the
-<filename>targetdatabase.dtd</filename> DTD.  The database file
-provides the high level elements to record the identifiers, locations,
-and relationships of documents. The cross reference data for
-individual documents is generally pulled into the database using
-system entity references or XIncludes. See also
-<parameter>targets.filename</parameter>.  </para> </refsection>
-</refentry>
-
-<refentry version="5.0" id="targets.filename"> 
-<refmeta> 
-<refentrytitle>targets.filename</refentrytitle> 
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo> 
-</refmeta> 
-<refnamediv> 
-<refname>targets.filename</refname> 
-<refpurpose>Name of cross reference targets data file</refpurpose> 
-</refnamediv> 
-<refsynopsisdiv> <programlisting id="targets.filename.frag">
-&lt;xsl:param name="targets.filename"&gt;target.db&lt;/xsl:param&gt;
-</programlisting> 
-</refsynopsisdiv> 
-<refsection><info><title>Description</title></info>
- 
-<para>
-In order to resolve olinks efficiently, the stylesheets can
-generate an external data file containing information about
-all potential cross reference endpoints in a document.
-This parameter lets you change the name of the generated
-file from the default name <filename>target.db</filename>.
-The name must agree with that used in the target database
-used to resolve olinks during processing.
-See also <parameter>target.database.document</parameter>.
-</para> 
-</refsection> 
-</refentry>
-
-<refentry version="5.0" id="use.local.olink.style"> 
-<refmeta> 
-<refentrytitle>use.local.olink.style</refentrytitle> 
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo> 
-</refmeta> 
-<refnamediv> 
-<refname>use.local.olink.style</refname> 
-<refpurpose>Process olinks using xref style of current
-document</refpurpose> 
-</refnamediv> 
-<refsynopsisdiv> <programlisting id="use.local.olink.style.frag">
-&lt;xsl:param name="use.local.olink.style" select="0"&gt;&lt;/xsl:param&gt; </programlisting> 
-</refsynopsisdiv> 
-<refsection><info><title>Description</title></info> 
- 
-<para>When cross reference data is collected for use by olinks, the data for each potential target includes one field containing a completely assembled cross reference string, as if it were an xref generated in that document. Other fields record the separate title, number, and element name of each target. When an olink is formed to a target from another document, the olink resolves to that preassembled string by default. If the <parameter>use.local.olink.style</parameter> parameter is set to non-zero, then instead the cross
-reference string is formed again from the target title, number, and
-element name, using the stylesheet processing the targeting document.
-Then olinks will match the xref style in the targeting document
-rather than in the target document. If  both documents are processed
-with the same stylesheet, then the results will be the same.</para> 
-</refsection> 
-</refentry>
-
-</reference><reference id="xrefs" xml:base="../fo/param.xml"><title>Cross References</title>
-<refentry version="5.0" id="insert.xref.page.number">
-<refmeta>
-<refentrytitle>insert.xref.page.number</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">list</refmiscinfo> 
-<refmiscinfo class="other" otherclass="value">no</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">yes</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">maybe</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>insert.xref.page.number</refname>
-<refpurpose>Turns page numbers in xrefs on and off</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="insert.xref.page.number.frag">
-&lt;xsl:param name="insert.xref.page.number"&gt;no&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The value of this parameter determines if
-cross references (<tag>xref</tag>s) in
-printed output will
-include page number citations.
-It has three possible values.
-</para>
-<variablelist>
-<varlistentry>
-<term>no</term>
-<listitem><para>No page number references will be generated.
-</para></listitem>
-</varlistentry>
-<varlistentry>
-<term>yes</term>
-<listitem><para>Page number references will be generated
-for all <tag>xref</tag> elements.
-The style of page reference may be changed
-if an <tag class="attribute">xrefstyle</tag>
-attribute is used.
-</para></listitem>
-</varlistentry>
-<varlistentry>
-<term>maybe</term>
-<listitem><para>Page number references will not be generated
-for an <tag>xref</tag> element unless 
-it has an
-<tag class="attribute">xrefstyle</tag>
-attribute whose value specifies a page reference.
-</para></listitem>
-</varlistentry>
-</variablelist>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="xref.properties">
-<refmeta>
-<refentrytitle>xref.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>xref.properties</refname>
-<refpurpose>Properties associated with cross-reference text</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="xref.properties.frag">
-&lt;xsl:attribute-set name="xref.properties"&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This attribute set is used to set properties
-on cross reference text.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="xref.label-title.separator">
-<refmeta>
-<refentrytitle>xref.label-title.separator</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>xref.label-title.separator</refname>
-<refpurpose>Punctuation or space separating label from title in xref</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="xref.label-title.separator.frag">&lt;xsl:param name="xref.label-title.separator"&gt;: &lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>
-This parameter allows you to control the punctuation of certain
-types of generated cross reference text.
-When cross reference text is generated for an 
-<tag class="element">xref</tag> or 
-<tag class="element">olink</tag> element
-using an <tag class="attribute">xrefstyle</tag> attribute
-that makes use of the <literal>select:</literal> feature,
-and the selected components include both label and title,
-then the value of this parameter is inserted between
-label and title in the output.  
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="xref.label-page.separator">
-<refmeta>
-<refentrytitle>xref.label-page.separator</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>xref.label-page.separator</refname>
-<refpurpose>Punctuation or space separating label from page number in xref</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="xref.label-page.separator.frag">&lt;xsl:param name="xref.label-page.separator"&gt;&lt;xsl:text&gt; &lt;/xsl:text&gt;&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>
-This parameter allows you to control the punctuation of certain
-types of generated cross reference text.
-When cross reference text is generated for an 
-<tag class="element">xref</tag> or 
-<tag class="element">olink</tag> element
-using an <tag class="attribute">xrefstyle</tag> attribute
-that makes use of the <literal>select:</literal> feature,
-and the selected components include both label and page
-but no title,
-then the value of this parameter is inserted between
-label and page number in the output.  
-If a title is included, then other separators are used.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="xref.title-page.separator">
-<refmeta>
-<refentrytitle>xref.title-page.separator</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>xref.title-page.separator</refname>
-<refpurpose>Punctuation or space separating title from page number in xref</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="xref.title-page.separator.frag">&lt;xsl:param name="xref.title-page.separator"&gt;&lt;xsl:text&gt; &lt;/xsl:text&gt;&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>
-This parameter allows you to control the punctuation of certain
-types of generated cross reference text.
-When cross reference text is generated for an 
-<tag class="element">xref</tag> or 
-<tag class="element">olink</tag> element
-using an <tag class="attribute">xrefstyle</tag> attribute
-that makes use of the <literal>select:</literal> feature,
-and the selected components include both title and page number,
-then the value of this parameter is inserted between
-title and page number in the output.  
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="insert.link.page.number">
-<refmeta>
-<refentrytitle>insert.link.page.number</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">list</refmiscinfo> 
-<refmiscinfo class="other" otherclass="value">no</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">yes</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">maybe</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>insert.link.page.number</refname>
-<refpurpose>Turns page numbers in link elements on and off</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="insert.link.page.number.frag">
-&lt;xsl:param name="insert.link.page.number"&gt;no&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The value of this parameter determines if
-cross references using the <tag>link</tag> element in
-printed output will
-include standard page number citations.
-It has three possible values.
-</para>
-<variablelist>
-<varlistentry>
-<term>no</term>
-<listitem><para>No page number references will be generated.
-</para></listitem>
-</varlistentry>
-<varlistentry>
-<term>yes</term>
-<listitem><para>Page number references will be generated
-for all <tag>link</tag> elements.
-The style of page reference may be changed
-if an <tag class="attribute">xrefstyle</tag>
-attribute is used.
-</para></listitem>
-</varlistentry>
-<varlistentry>
-<term>maybe</term>
-<listitem><para>Page number references will not be generated
-for a <tag>link</tag> element unless 
-it has an
-<tag class="attribute">xrefstyle</tag>
-attribute whose value specifies a page reference.
-</para></listitem>
-</varlistentry>
-</variablelist>
-
-<para>Although the <tag>xrefstyle</tag> attribute
-can be used to turn the page reference on or off, it cannot be
-used to control the formatting of the page number as it
-can in <tag>xref</tag>.
-In <tag>link</tag> it will always format with
-the style established by the
-gentext template with <literal>name="page.citation"</literal>
-in the <literal>l:context name="xref"</literal>.
-</para>
-</refsection>
-</refentry>
-
-</reference><reference id="lists" xml:base="../fo/param.xml"><title>Lists</title>
-<refentry version="5.0" id="compact.list.item.spacing">
-<refmeta>
-<refentrytitle>compact.list.item.spacing</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>  
-<refnamediv>
-<refname>compact.list.item.spacing</refname>
-<refpurpose>What space do you want between list items (when spacing="compact")?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="compact.list.item.spacing.frag">&lt;xsl:attribute-set name="compact.list.item.spacing"&gt;
-  &lt;xsl:attribute name="space-before.optimum"&gt;0em&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="space-before.minimum"&gt;0em&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="space-before.maximum"&gt;0.2em&lt;/xsl:attribute&gt;
-&lt;/xsl:attribute-set&gt;</programlisting>
-</refsynopsisdiv>
-<refsection><info><title>Description</title></info>
-<para>Specify what spacing you want between each list item when
-<tag class="attribute">spacing</tag> is
-<quote><literal>compact</literal></quote>.</para>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="itemizedlist.properties">
-<refmeta>
-<refentrytitle>itemizedlist.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>itemizedlist.properties</refname>
-<refpurpose>Properties that apply to each list-block generated by itemizedlist.</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="itemizedlist.properties.frag">&lt;xsl:attribute-set name="itemizedlist.properties" use-attribute-sets="list.block.properties"&gt;
-&lt;/xsl:attribute-set&gt;</programlisting>
-</refsynopsisdiv>
-<refsection><info><title>Description</title></info>
-<para>Properties that apply to each fo:list-block generated by itemizedlist.</para>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="itemizedlist.label.properties">
-<refmeta>
-<refentrytitle>itemizedlist.label.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>itemizedlist.label.properties</refname>
-<refpurpose>Properties that apply to each label inside itemized list.</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="itemizedlist.label.properties.frag">&lt;xsl:attribute-set name="itemizedlist.label.properties"&gt;
-&lt;/xsl:attribute-set&gt;</programlisting>
-</refsynopsisdiv>
-<refsection><info><title>Description</title></info>
-<para>Properties that apply to each label inside itemized list. E.g.:</para>
-<programlisting>&lt;xsl:attribute-set name="itemizedlist.label.properties"&gt;
-  &lt;xsl:attribute name="text-align"&gt;right&lt;/xsl:attribute&gt;
-&lt;/xsl:attribute-set&gt;</programlisting>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="itemizedlist.label.width">
-<refmeta>
-<refentrytitle>itemizedlist.label.width</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">length</refmiscinfo>
-</refmeta>
-<refnamediv>
-  <refname>itemizedlist.label.width</refname>
-<refpurpose>The default width of the label (bullet) in an itemized list.</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-  <programlisting id="itemizedlist.label.width.frag">
-    &lt;xsl:param name="itemizedlist.label.width"&gt;1.0em&lt;/xsl:param&gt;
-  </programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-<para>Specifies the default width of the label (usually a bullet or other
-symbol) in an itemized list. You can override the default value on any
-particular list with the &#8220;dbfo&#8221; processing instruction using the
-&#8220;label-width&#8221; pseudoattribute.</para>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="list.block.properties">
-<refmeta>
-<refentrytitle>list.block.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>list.block.properties</refname>
-<refpurpose>Properties that apply to each list-block generated by list.</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="list.block.properties.frag">&lt;xsl:attribute-set name="list.block.properties"&gt;
-  &lt;xsl:attribute name="provisional-label-separation"&gt;0.2em&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="provisional-distance-between-starts"&gt;1.5em&lt;/xsl:attribute&gt;
-&lt;/xsl:attribute-set&gt;</programlisting>
-</refsynopsisdiv>
-<refsection><info><title>Description</title></info>
-<para>Properties that apply to each fo:list-block generated by itemizedlist/orderedlist.</para>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="list.block.spacing">
-<refmeta>
-<refentrytitle>list.block.spacing</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>list.block.spacing</refname>
-<refpurpose>What spacing do you want before and after lists?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="list.block.spacing.frag">&lt;xsl:attribute-set name="list.block.spacing"&gt;
-  &lt;xsl:attribute name="space-before.optimum"&gt;1em&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="space-before.minimum"&gt;0.8em&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="space-before.maximum"&gt;1.2em&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="space-after.optimum"&gt;1em&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="space-after.minimum"&gt;0.8em&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="space-after.maximum"&gt;1.2em&lt;/xsl:attribute&gt;
-&lt;/xsl:attribute-set&gt;</programlisting>
-</refsynopsisdiv>
-<refsection><info><title>Description</title></info>
-<para>Specify the spacing required before and after a list. It is necessary to specify the space after a list block because lists can come inside of paras.  </para>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="list.item.spacing">
-<refmeta>
-<refentrytitle>list.item.spacing</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>list.item.spacing</refname>
-<refpurpose>What space do you want between list items?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="list.item.spacing.frag">&lt;xsl:attribute-set name="list.item.spacing"&gt;
-  &lt;xsl:attribute name="space-before.optimum"&gt;1em&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="space-before.minimum"&gt;0.8em&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="space-before.maximum"&gt;1.2em&lt;/xsl:attribute&gt;
-&lt;/xsl:attribute-set&gt;</programlisting>
-</refsynopsisdiv>
-<refsection><info><title>Description</title></info>
-<para>Specify what spacing you want between each list item.</para>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="orderedlist.properties">
-<refmeta>
-<refentrytitle>orderedlist.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>orderedlist.properties</refname>
-<refpurpose>Properties that apply to each list-block generated by orderedlist.</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="orderedlist.properties.frag">&lt;xsl:attribute-set name="orderedlist.properties" use-attribute-sets="list.block.properties"&gt;
-  &lt;xsl:attribute name="provisional-distance-between-starts"&gt;2em&lt;/xsl:attribute&gt;
-&lt;/xsl:attribute-set&gt;</programlisting>
-</refsynopsisdiv>
-<refsection><info><title>Description</title></info>
-<para>Properties that apply to each fo:list-block generated by orderedlist.</para>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="orderedlist.label.properties">
-<refmeta>
-<refentrytitle>orderedlist.label.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>orderedlist.label.properties</refname>
-<refpurpose>Properties that apply to each label inside ordered list.</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="orderedlist.label.properties.frag">&lt;xsl:attribute-set name="orderedlist.label.properties"&gt;
-&lt;/xsl:attribute-set&gt;</programlisting>
-</refsynopsisdiv>
-<refsection><info><title>Description</title></info>
-<para>Properties that apply to each label inside ordered list. E.g.:</para>
-<programlisting>&lt;xsl:attribute-set name="orderedlist.label.properties"&gt;
-  &lt;xsl:attribute name="text-align"&gt;right&lt;/xsl:attribute&gt;
-&lt;/xsl:attribute-set&gt;</programlisting>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="orderedlist.label.width">
-<refmeta>
-<refentrytitle>orderedlist.label.width</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">length</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>orderedlist.label.width</refname>
-<refpurpose>The default width of the label (number) in an ordered list.</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="orderedlist.label.width.frag">
-&lt;xsl:param name="orderedlist.label.width"&gt;1.2em&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-<para>Specifies the default width of the label (usually a number or
-sequence of numbers) in an ordered list. You can override the default
-value on any particular list with the &#8220;dbfo&#8221; processing instruction
-using the &#8220;label-width&#8221; pseudoattribute.</para>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="variablelist.max.termlength">
-<refmeta>
-<refentrytitle>variablelist.max.termlength</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">number</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>variablelist.max.termlength</refname>
-<refpurpose>Specifies the longest term in variablelists</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="variablelist.max.termlength.frag">
-&lt;xsl:param name="variablelist.max.termlength"&gt;24&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>In variablelists, the <tag>listitem</tag>
-is indented to leave room for the 
-<tag>term</tag> elements. That indent may be computed
-if it is not specified with a <tag class="attribute">termlength</tag>
-attribute on the <tag>variablelist</tag> element.
-</para>
-<para>
-The computation counts characters in the 
-<tag>term</tag> elements in the list
-to find the longest term.  However, some terms are very long
-and would produce extreme indents.  This parameter lets you
-set a maximum character count.  Any terms longer than the maximum
-would line wrap.  The default value is 24.
-</para>
-<para>
-The character counts are converted to physical widths
-by multiplying by 0.50em. There will be some variability
-in how many actual characters fit in the space
-since some characters are wider than others.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="variablelist.term.separator">
-<refmeta>
-<refentrytitle>variablelist.term.separator</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>variablelist.term.separator</refname>
-<refpurpose>Text to separate <tag>term</tag>s within a multi-term
-<tag>varlistentry</tag></refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="variablelist.term.separator.frag">
-&lt;xsl:param name="variablelist.term.separator"&gt;, &lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>When a <tag>varlistentry</tag> contains multiple <tag>term</tag>
-elements, the string specified in the value of the
-<parameter>variablelist.term.separator</parameter> parameter is placed
-after each <tag>term</tag> except the last.</para>
-
-<note>
-  <para>To generate a line break between multiple <tag>term</tag>s in
-  a <tag>varlistentry</tag>, set a non-zero value for the
-  <parameter>variablelist.term.break.after</parameter> parameter. If
-  you do so, you may also want to set the value of the
-  <parameter>variablelist.term.separator</parameter> parameter to an
-  empty string (to suppress rendering of the default comma and space
-  after each <tag>term</tag>).</para>
-</note>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="variablelist.term.properties">
-<refmeta>
-<refentrytitle>variablelist.term.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>variablelist.term.properties</refname>
-<refpurpose>To add properties to the term elements in a variablelist.</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="variablelist.term.properties.frag">
-&lt;xsl:attribute-set name="variablelist.term.properties"&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-<refsection><info><title>Description</title></info>
-<para>These properties are added to the block containing a
-term in a variablelist.
-Use this attribute-set to set
-font properties or alignment, for example.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="variablelist.term.break.after">
-<refmeta>
-<refentrytitle>variablelist.term.break.after</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>variablelist.term.break.after</refname>
-<refpurpose>Generate line break after each <tag>term</tag> within a
-multi-term <tag>varlistentry</tag>?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="variablelist.term.break.after.frag">
-&lt;xsl:param name="variablelist.term.break.after"&gt;0&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Set a non-zero value for the
-<parameter>variablelist.term.break.after</parameter> parameter to
-generate a line break between <tag>term</tag>s in a
-multi-term <tag>varlistentry</tag>.</para>
-
-<note>
-<para>If you set a non-zero value for
-<parameter>variablelist.term.break.after</parameter>, you may also
-want to set the value of the
-<parameter>variablelist.term.separator</parameter> parameter to an
-empty string (to suppress rendering of the default comma and space
-after each <tag>term</tag>).</para>
-</note>
-
-</refsection>
-</refentry>
-
-</reference><reference id="qa" xml:base="../fo/param.xml"><title>QAndASet</title>
-<refentry version="5.0" id="qandadiv.autolabel">
-<refmeta>
-<refentrytitle>qandadiv.autolabel</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>qandadiv.autolabel</refname>
-<refpurpose>Are divisions in QAndASets enumerated?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="qandadiv.autolabel.frag">&lt;xsl:param name="qandadiv.autolabel" select="1"&gt;&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, unlabeled qandadivs will be enumerated.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="qanda.inherit.numeration">
-<refmeta>
-<refentrytitle>qanda.inherit.numeration</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>qanda.inherit.numeration</refname>
-<refpurpose>Does enumeration of QandASet components inherit the numeration of parent elements?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="qanda.inherit.numeration.frag">
-&lt;xsl:param name="qanda.inherit.numeration" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, numbered <tag>qandadiv</tag> elements and
-<tag>question</tag> and <tag>answer</tag> inherit the enumeration of
-the ancestors of the <tag>qandaset</tag>.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="qanda.defaultlabel">
-<refmeta>
-<refentrytitle>qanda.defaultlabel</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">list</refmiscinfo> 
-<refmiscinfo class="other" otherclass="value">number</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">qanda</refmiscinfo> 
-<refmiscinfo class="other" otherclass="value">none</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>qanda.defaultlabel</refname>
-<refpurpose>Sets the default for defaultlabel on QandASet.</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="qanda.defaultlabel.frag">
-&lt;xsl:param name="qanda.defaultlabel"&gt;number&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If no <literal>defaultlabel</literal> attribute is specified on
-a <tag>qandaset</tag>, this value is used. It is generally one of the legal
-values for the defaultlabel attribute (<literal>none</literal>, 
-<literal>number</literal> or
-<literal>qanda</literal>), or one of the additional stylesheet-specific values
-(<literal>qnumber</literal> or <literal>qnumberanda</literal>).
-The default value is 'number'.
-</para>
-<para>The values are rendered as follows:</para>
-<variablelist>
-<varlistentry><term><literal>qanda</literal></term>
-<listitem>
-<para><tag>question</tag>s are labeled "Q:" and
-<tag>answer</tag>s are labeled "A:". </para>
-</listitem>
-</varlistentry>
-
-<varlistentry><term><literal>number</literal></term>
-<listitem>
-<para>The questions are enumerated and the answers
-are not labeled. </para>
-</listitem>
-</varlistentry>
-
-<varlistentry><term><literal>qnumber</literal></term>
-<listitem>
-<para>The questions are labeled "Q:" followed by a number, and answers are not 
-labeled. 
-When sections are numbered, adding a label
-to the number distinguishes the question numbers
-from the section numbers.
-This value is not allowed in the
-<tag class="attribute">defaultlabel</tag> attribute
-of a <tag>qandaset</tag> element.</para>
-</listitem>
-</varlistentry>
-
-<varlistentry><term><literal>qnumberanda</literal></term>
-<listitem>
-<para>The questions are labeled "Q:" followed by a number, and
-the answers are labeled "A:". 
-When sections are numbered, adding a label
-to the number distinguishes the question numbers
-from the section numbers.
-This value is not allowed in the
-<tag class="attribute">defaultlabel</tag> attribute
-of a <tag>qandaset</tag> element.</para>
-</listitem>
-</varlistentry>
-
-<varlistentry><term><literal>none</literal></term>
-<listitem>
-<para>No distinguishing label precedes Questions or Answers. 
-</para>
-</listitem>
-</varlistentry>
-</variablelist>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="qanda.in.toc">
-<refmeta>
-<refentrytitle>qanda.in.toc</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>qanda.in.toc</refname>
-<refpurpose>Should qandaentry questions appear in 
-the document table of contents?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="qanda.in.toc.frag">&lt;xsl:param name="qanda.in.toc" select="0"&gt;&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If true (non-zero), then the generated table of contents
-for a document will include <tag>qandaset</tag> titles, 
-<tag>qandadiv</tag> titles,
-and <tag>question</tag> elements.  The default value (zero) excludes
-them from the TOC.
-</para>
-<para>This parameter does not affect any tables of contents
-that may be generated inside a qandaset or qandadiv.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="qanda.nested.in.toc">
-<refmeta>
-<refentrytitle>qanda.nested.in.toc</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>qanda.nested.in.toc</refname>
-<refpurpose>Should nested answer/qandaentry instances appear in TOC?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="qanda.nested.in.toc.frag">
-&lt;xsl:param name="qanda.nested.in.toc" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, instances of <tag>qandaentry</tag>
-that are children of <tag>answer</tag> elements are shown in
-the TOC.</para>
-
-</refsection>
-</refentry>
-
-</reference><reference id="biblio" xml:base="../fo/param.xml"><title>Bibliography</title>
-<refentry version="5.0" id="bibliography.style">
-<refmeta>
-<refentrytitle>bibliography.style</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">list</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">normal</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">iso690</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>bibliography.style</refname>
-<refpurpose>Style used for formatting of biblioentries.</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="bibliography.style.frag">
-&lt;xsl:param name="bibliography.style"&gt;normal&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Currently only <literal>normal</literal> and
-<literal>iso690</literal> styles are supported.</para>
-
-<para>In order to use ISO690 style to the full extent you might need
-to use additional markup described on <link xlink:href="http://wiki.docbook.org/topic/ISO690Bibliography">the
-following WiKi page</link>.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="biblioentry.item.separator">
-<refmeta>
-<refentrytitle>biblioentry.item.separator</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>biblioentry.item.separator</refname>
-<refpurpose>Text to separate bibliography entries</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="biblioentry.item.separator.frag">&lt;xsl:param name="biblioentry.item.separator"&gt;. &lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Text to separate bibliography entries
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="bibliography.collection">
-<refmeta>
-<refentrytitle>bibliography.collection</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>bibliography.collection</refname>
-<refpurpose>Name of the bibliography collection file</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="bibliography.collection.frag">
-&lt;xsl:param name="bibliography.collection"&gt;http://docbook.sourceforge.net/release/bibliography/bibliography.xml&lt;/xsl:param&gt;
-
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Maintaining bibliography entries across a set of documents is tedious, time
-consuming, and error prone. It makes much more sense, usually, to store all of
-the bibliography entries in a single place and simply <quote>extract</quote>
-the ones you need in each document.</para>
-
-<para>That's the purpose of the
-<parameter>bibliography.collection</parameter> parameter. To setup a global
-bibliography <quote>database</quote>, follow these steps:</para>
-
-<para>First, create a stand-alone bibliography document that contains all of
-the documents that you wish to reference. Make sure that each bibliography
-entry (whether you use <tag>biblioentry</tag> or <tag>bibliomixed</tag>)
-has an ID.</para>
-
-<para>My global bibliography, <filename>~/bibliography.xml</filename> begins
-like this:</para>
-
-<informalexample>
-<programlisting>&lt;!DOCTYPE bibliography
-  PUBLIC "-//OASIS//DTD DocBook XML V4.1.2//EN"
-  "http://www.oasis-open.org/docbook/xml/4.1.2/docbookx.dtd"&gt;
-&lt;bibliography&gt;&lt;title&gt;References&lt;/title&gt;
-
-&lt;bibliomixed id="xml-rec"&gt;&lt;abbrev&gt;XML 1.0&lt;/abbrev&gt;Tim Bray,
-Jean Paoli, C. M. Sperberg-McQueen, and Eve Maler, editors.
-&lt;citetitle&gt;&lt;ulink url="http://www.w3.org/TR/REC-xml"&gt;Extensible Markup
-Language (XML) 1.0 Second Edition&lt;/ulink&gt;&lt;/citetitle&gt;.
-World Wide Web Consortium, 2000.
-&lt;/bibliomixed&gt;
-
-&lt;bibliomixed id="xml-names"&gt;&lt;abbrev&gt;Namespaces&lt;/abbrev&gt;Tim Bray,
-Dave Hollander,
-and Andrew Layman, editors.
-&lt;citetitle&gt;&lt;ulink url="http://www.w3.org/TR/REC-xml-names/"&gt;Namespaces in
-XML&lt;/ulink&gt;&lt;/citetitle&gt;.
-World Wide Web Consortium, 1999.
-&lt;/bibliomixed&gt;
-
-&lt;!-- ... --&gt;
-&lt;/bibliography&gt;
-</programlisting>
-</informalexample>
-
-<para>When you create a bibliography in your document, simply
-provide <emphasis>empty</emphasis> <tag>bibliomixed</tag>
-entries for each document that you wish to cite. Make sure that these
-elements have the same ID as the corresponding <quote>real</quote>
-entry in your global bibliography.</para>
-
-<para>For example:</para>
-
-<informalexample>
-<programlisting>&lt;bibliography&gt;&lt;title&gt;Bibliography&lt;/title&gt;
-
-&lt;bibliomixed id="xml-rec"/&gt;
-&lt;bibliomixed id="xml-names"/&gt;
-&lt;bibliomixed id="DKnuth86"&gt;Donald E. Knuth. &lt;citetitle&gt;Computers and
-Typesetting: Volume B, TeX: The Program&lt;/citetitle&gt;. Addison-Wesley,
-1986.  ISBN 0-201-13437-3.
-&lt;/bibliomixed&gt;
-&lt;bibliomixed id="relaxng"/&gt;
-
-&lt;/bibliography&gt;</programlisting>
-</informalexample>
-
-<para>Note that it's perfectly acceptable to mix entries from your
-global bibliography with <quote>normal</quote> entries. You can use
-<tag>xref</tag> or other elements to cross-reference your
-bibliography entries in exactly the same way you do now.</para>
-
-<para>Finally, when you are ready to format your document, simply set the
-<parameter>bibliography.collection</parameter> parameter (in either a
-customization layer or directly through your processor's interface) to
-point to your global bibliography.</para>
-
-<para>A relative path in the parameter is interpreted in one
-of two ways:</para>
-<orderedlist numeration="loweralpha">
-  <listitem>
-    <para>If your document contains no links to empty bibliographic elements,
-    then the path is relative to the file containing
-    the first <tag>bibliomixed</tag> element in the document.</para>
-  </listitem>
-  <listitem>
-    <para>If your document does contain links to empty bibliographic elements,
-    then the path is relative to the file containing
-    the first such link element in the document.</para>
-  </listitem>
-</orderedlist>
-<para>Once the collection file is opened by the first instance described
-above, it stays open for the current document
-and the relative path is not reinterpreted again.</para>
-
-<para>The stylesheets will format the bibliography in your document as if
-all of the entries referenced appeared there literally.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="bibliography.numbered">
-<refmeta>
-<refentrytitle>bibliography.numbered</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>bibliography.numbered</refname>
-<refpurpose>Should bibliography entries be numbered?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="bibliography.numbered.frag">
-&lt;xsl:param name="bibliography.numbered" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero bibliography entries will be numbered</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="biblioentry.properties">
-<refmeta>
-  <refentrytitle>biblioentry.properties</refentrytitle>
-  <refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>biblioentry.properties</refname>
-<refpurpose>To set the style for biblioentry.</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="biblioentry.properties.frag">&lt;xsl:attribute-set name="biblioentry.properties" use-attribute-sets="normal.para.spacing"&gt;
-  &lt;xsl:attribute name="start-indent"&gt;0.5in&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="text-indent"&gt;-0.5in&lt;/xsl:attribute&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-<refsection><info><title>Description</title></info>
-<para>How do you want biblioentry styled? </para>
-<para>Set the font-size, weight, space-above and space-below, indents, etc. to the style required</para>
-
-</refsection>
-</refentry>
-
-</reference><reference id="glossary" xml:base="../fo/param.xml"><title>Glossary</title>
-<refentry version="5.0" id="glossterm.auto.link">
-<refmeta>
-<refentrytitle>glossterm.auto.link</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>glossterm.auto.link</refname>
-<refpurpose>Generate links from glossterm to glossentry automatically?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="glossterm.auto.link.frag">
-&lt;xsl:param name="glossterm.auto.link" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, links from inline <tag>glossterm</tag>s to the corresponding 
-<tag>glossentry</tag> elements in a <tag>glossary</tag> or <tag>glosslist</tag> 
-will be automatically generated. This is useful when your glossterms are consistent 
-and you don't want to add links manually.</para>
-
-<para>The automatic link generation feature is not used on <tag>glossterm</tag> elements
-that have a <tag class="attribute">linkend</tag> attribute.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="firstterm.only.link">
-<refmeta>
-<refentrytitle>firstterm.only.link</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>firstterm.only.link</refname>
-<refpurpose>Does automatic glossterm linking only apply to firstterms?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="firstterm.only.link.frag">
-&lt;xsl:param name="firstterm.only.link" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, only <tag>firstterm</tag>s will be automatically linked
-to the glossary. If glossary linking is not enabled, this parameter
-has no effect.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="glossary.collection">
-<refmeta>
-<refentrytitle>glossary.collection</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>glossary.collection</refname>
-<refpurpose>Name of the glossary collection file</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="glossary.collection.frag">
-&lt;xsl:param name="glossary.collection"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Glossaries maintained independently across a set of documents
-are likely to become inconsistent unless considerable effort is
-expended to keep them in sync. It makes much more sense, usually, to
-store all of the glossary entries in a single place and simply
-<quote>extract</quote> the ones you need in each document.</para>
-
-<para>That's the purpose of the
-<parameter>glossary.collection</parameter> parameter. To setup a global
-glossary <quote>database</quote>, follow these steps:</para>
-
-<refsection><info><title>Setting Up the Glossary Database</title></info>
-
-<para>First, create a stand-alone glossary document that contains all of
-the entries that you wish to reference. Make sure that each glossary
-entry has an ID.</para>
-
-<para>Here's an example glossary:</para>
-
-<informalexample>
-<programlisting>
-&lt;?xml version="1.0" encoding="utf-8"?&gt;
-&lt;!DOCTYPE glossary
-  PUBLIC "-//OASIS//DTD DocBook XML V4.1.2//EN"
-  "http://www.oasis-open.org/docbook/xml/4.1.2/docbookx.dtd"&gt;
-&lt;glossary&gt;
-&lt;glossaryinfo&gt;
-&lt;editor&gt;&lt;firstname&gt;Eric&lt;/firstname&gt;&lt;surname&gt;Raymond&lt;/surname&gt;&lt;/editor&gt;
-&lt;title&gt;Jargon File 4.2.3 (abridged)&lt;/title&gt;
-&lt;releaseinfo&gt;Just some test data&lt;/releaseinfo&gt;
-&lt;/glossaryinfo&gt;
-
-&lt;glossdiv&gt;&lt;title&gt;0&lt;/title&gt;
-
-&lt;glossentry&gt;
-&lt;glossterm&gt;0&lt;/glossterm&gt;
-&lt;glossdef&gt;
-&lt;para&gt;Numeric zero, as opposed to the letter `O' (the 15th letter of
-the English alphabet). In their unmodified forms they look a lot
-alike, and various kluges invented to make them visually distinct have
-compounded the confusion. If your zero is center-dotted and letter-O
-is not, or if letter-O looks almost rectangular but zero looks more
-like an American football stood on end (or the reverse), you're
-probably looking at a modern character display (though the dotted zero
-seems to have originated as an option on IBM 3270 controllers). If
-your zero is slashed but letter-O is not, you're probably looking at
-an old-style ASCII graphic set descended from the default typewheel on
-the venerable ASR-33 Teletype (Scandinavians, for whom /O is a letter,
-curse this arrangement). (Interestingly, the slashed zero long
-predates computers; Florian Cajori's monumental "A History of
-Mathematical Notations" notes that it was used in the twelfth and
-thirteenth centuries.) If letter-O has a slash across it and the zero
-does not, your display is tuned for a very old convention used at IBM
-and a few other early mainframe makers (Scandinavians curse &lt;emphasis&gt;this&lt;/emphasis&gt;
-arrangement even more, because it means two of their letters collide).
-Some Burroughs/Unisys equipment displays a zero with a &lt;emphasis&gt;reversed&lt;/emphasis&gt;
-slash. Old CDC computers rendered letter O as an unbroken oval and 0
-as an oval broken at upper right and lower left. And yet another
-convention common on early line printers left zero unornamented but
-added a tail or hook to the letter-O so that it resembled an inverted
-Q or cursive capital letter-O (this was endorsed by a draft ANSI
-standard for how to draw ASCII characters, but the final standard
-changed the distinguisher to a tick-mark in the upper-left corner).
-Are we sufficiently confused yet?&lt;/para&gt;
-&lt;/glossdef&gt;
-&lt;/glossentry&gt;
-
-&lt;glossentry&gt;
-&lt;glossterm&gt;1TBS&lt;/glossterm&gt;
-&lt;glossdef&gt;
-&lt;para role="accidence"&gt;
-&lt;phrase role="pronounce"&gt;&lt;/phrase&gt;
-&lt;phrase role="partsofspeach"&gt;n&lt;/phrase&gt;
-&lt;/para&gt;
-&lt;para&gt;The "One True Brace Style"&lt;/para&gt;
-&lt;glossseealso&gt;indent style&lt;/glossseealso&gt;
-&lt;/glossdef&gt;
-&lt;/glossentry&gt;
-
-&lt;!-- ... --&gt;
-
-&lt;/glossdiv&gt;
-
-&lt;!-- ... --&gt;
-
-&lt;/glossary&gt;</programlisting>
-</informalexample>
-
-</refsection>
-
-<refsection><info><title>Marking Up Glossary Terms</title></info>
-
-<para>That takes care of the glossary database, now you have to get the entries
-into your document. Unlike bibliography entries, which can be empty, creating
-<quote>placeholder</quote> glossary entries would be very tedious. So instead,
-support for <parameter>glossary.collection</parameter> relies on implicit linking.</para>
-
-<para>In your source document, simply use <tag>firstterm</tag> and
-<tag>glossterm</tag> to identify the terms you wish to have included
-in the glossary. The stylesheets assume that you will either set the
-<tag class="attribute">baseform</tag> attribute correctly, or that the
-content of the element exactly matches a term in your glossary.</para>
-
-<para>If you're using a <parameter>glossary.collection</parameter>, don't
-make explicit links on the terms in your document.</para>
-
-<para>So, in your document, you might write things like this:</para>
-
-<informalexample>
-<programlisting>&lt;para&gt;This is dummy text, without any real meaning.
-The point is simply to reference glossary terms like &lt;glossterm&gt;0&lt;/glossterm&gt;
-and the &lt;firstterm baseform="1TBS"&gt;One True Brace Style (1TBS)&lt;/firstterm&gt;.
-The &lt;glossterm&gt;1TBS&lt;/glossterm&gt;, as you can probably imagine, is a nearly
-religious issue.&lt;/para&gt;</programlisting>
-</informalexample>
-
-<para>If you set the <parameter>firstterm.only.link</parameter> parameter,
-only the terms marked with <tag>firstterm</tag> will be links.
-Otherwise, all the terms will be linked.</para>
-
-</refsection>
-
-<refsection><info><title>Marking Up the Glossary</title></info>
-
-<para>The glossary itself has to be identified for the stylesheets. For lack
-of a better choice, the <tag class="attribute">role</tag> is used.
-To identify the glossary as the target for automatic processing, set
-the role to <quote><literal>auto</literal></quote>. The title of this
-glossary (and any other information from the <tag>glossaryinfo</tag>
-that's rendered by your stylesheet) will be displayed, but the entries will
-come from the database.
-</para>
-
-<para>Unfortunately, the glossary can't be empty, so you must put in
-at least one <tag>glossentry</tag>. The content of this entry
-is irrelevant, it will not be rendered:</para>
-
-<informalexample>
-<programlisting>&lt;glossary role="auto"&gt;
-&lt;glossentry&gt;
-&lt;glossterm&gt;Irrelevant&lt;/glossterm&gt;
-&lt;glossdef&gt;
-&lt;para&gt;If you can see this, the document was processed incorrectly. Use
-the &lt;parameter&gt;glossary.collection&lt;/parameter&gt; parameter.&lt;/para&gt;
-&lt;/glossdef&gt;
-&lt;/glossentry&gt;
-&lt;/glossary&gt;</programlisting>
-</informalexample>
-
-<para>What about glossary divisions? If your glossary database has glossary
-divisions <emphasis>and</emphasis> your automatic glossary contains at least
-one <tag>glossdiv</tag>, the automic glossary will have divisions.
-If the <tag>glossdiv</tag> is missing from either location, no divisions
-will be rendered.</para>
-
-<para>Glossary entries (and divisions, if appropriate) in the glossary will
-occur in precisely the order they occur in your database.</para>
-
-</refsection>
-
-<refsection><info><title>Formatting the Document</title></info>
-
-<para>Finally, when you are ready to format your document, simply set the
-<parameter>glossary.collection</parameter> parameter (in either a
-customization layer or directly through your processor's interface) to
-point to your global glossary.</para>
-
-<para>A relative path in the parameter is interpreted in one
-of two ways:</para>
-<orderedlist numeration="loweralpha">
-  <listitem>
-    <para>If the parameter <literal>glossterm.auto.link</literal>
-    is set to zero, then the path is relative to the file containing
-    the empty <tag>glossary</tag> element in the document.</para>
-  </listitem>
-  <listitem>
-    <para>If the parameter <literal>glossterm.auto.link</literal>
-    is set to non-zero, then the path is relative to the file containing
-    the first inline <tag>glossterm</tag> or
-    <tag>firstterm</tag> in the document to be linked.</para>
-  </listitem>
-</orderedlist>
-<para>Once the collection file is opened by the first instance described
-above, it stays open for the current document
-and the relative path is not reinterpreted again.</para>
-
-<para>The stylesheets will format the glossary in your document as if
-all of the entries implicilty referenced appeared there literally.</para>
-</refsection>
-
-<refsection><info><title>Limitations</title></info>
-
-<para>Glossary cross-references <emphasis>within the glossary</emphasis> are
-not supported. For example, this <emphasis>will not</emphasis> work:</para>
-
-<informalexample>
-<programlisting>&lt;glossentry&gt;
-&lt;glossterm&gt;gloss-1&lt;/glossterm&gt;
-&lt;glossdef&gt;&lt;para&gt;A description that references &lt;glossterm&gt;gloss-2&lt;/glossterm&gt;.&lt;/para&gt;
-&lt;glossseealso&gt;gloss-2&lt;/glossseealso&gt;
-&lt;/glossdef&gt;
-&lt;/glossentry&gt;</programlisting>
-</informalexample>
-
-<para>If you put glossary cross-references in your glossary that way,
-you'll get the cryptic error: <computeroutput>Warning:
-glossary.collection specified, but there are 0 automatic
-glossaries</computeroutput>.</para>
-
-<para>Instead, you must do two things:</para>
-
-<orderedlist>
-<listitem>
-<para>Markup your glossary using <tag>glossseealso</tag>:</para>
-
-<informalexample>
-<programlisting>&lt;glossentry&gt;
-&lt;glossterm&gt;gloss-1&lt;/glossterm&gt;
-&lt;glossdef&gt;&lt;para&gt;A description that references &lt;glossterm&gt;gloss-2&lt;/glossterm&gt;.&lt;/para&gt;
-&lt;glossseealso&gt;gloss-2&lt;/glossseealso&gt;
-&lt;/glossdef&gt;
-&lt;/glossentry&gt;</programlisting>
-</informalexample>
-</listitem>
-
-<listitem>
-<para>Make sure there is at least one <tag>glossterm</tag> reference to
-<glossterm>gloss-2</glossterm> <emphasis>in your document</emphasis>. The
-easiest way to do that is probably within a <tag>remark</tag> in your
-automatic glossary:</para>
-
-<informalexample>
-<programlisting>&lt;glossary role="auto"&gt;
-&lt;remark&gt;Make sure there's a reference to &lt;glossterm&gt;gloss-2&lt;/glossterm&gt;.&lt;/remark&gt;
-&lt;glossentry&gt;
-&lt;glossterm&gt;Irrelevant&lt;/glossterm&gt;
-&lt;glossdef&gt;
-&lt;para&gt;If you can see this, the document was processed incorrectly. Use
-the &lt;parameter&gt;glossary.collection&lt;/parameter&gt; parameter.&lt;/para&gt;
-&lt;/glossdef&gt;
-&lt;/glossentry&gt;
-&lt;/glossary&gt;</programlisting>
-</informalexample>
-</listitem>
-</orderedlist>
-</refsection>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="glossary.as.blocks">
-<refmeta>
-<refentrytitle>glossary.as.blocks</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>glossary.as.blocks</refname>
-<refpurpose>Present glossarys using blocks instead of lists?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="glossary.as.blocks.frag">
-&lt;xsl:param name="glossary.as.blocks" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, <tag>glossary</tag>s will be formatted as
-blocks.</para>
-
-<para>If you have long <tag>glossterm</tag>s, proper list
-markup in the FO case may produce unattractive lists. By setting this
-parameter, you can force the stylesheets to produce block markup
-instead of proper lists.</para>
-
-<para>You can override this setting with a processing instruction as the
-child of <tag>glossary</tag>: <tag class="xmlpi">dbfo
-glossary-presentation="blocks"</tag> or <tag class="xmlpi">dbfo
-glossary-presentation="list"</tag></para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="glosslist.as.blocks">
-<refmeta>
-<refentrytitle>glosslist.as.blocks</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>glosslist.as.blocks</refname>
-<refpurpose>Use blocks for glosslists?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="glosslist.as.blocks.frag">
-&lt;xsl:param name="glosslist.as.blocks" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>See <parameter>glossary.as.blocks</parameter>.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="glossentry.list.item.properties">
-<refmeta>
-<refentrytitle>glossentry.list.item.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>glossentry.list.item.properties</refname>
-<refpurpose>To add properties to each glossentry in a list.</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="glossentry.list.item.properties.frag">&lt;xsl:attribute-set name="glossentry.list.item.properties"&gt;
-  &lt;xsl:attribute name="space-before.optimum"&gt;1em&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="space-before.minimum"&gt;0.8em&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="space-before.maximum"&gt;1.2em&lt;/xsl:attribute&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-<refsection><info><title>Description</title></info>
-<para>These properties are added to the fo:list-item containing a
-glossentry in a glossary when the <parameter>glossary.as.blocks</parameter> parameter
-is zero.
-Use this attribute-set to set
-spacing between entries, for example.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="glossterm.block.properties">
-<refmeta>
-<refentrytitle>glossterm.block.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>glossterm.block.properties</refname>
-<refpurpose>To add properties to the block of a glossentry's glossterm.</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="glossterm.block.properties.frag">&lt;xsl:attribute-set name="glossterm.block.properties"&gt;
-  &lt;xsl:attribute name="space-before.optimum"&gt;1em&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="space-before.minimum"&gt;0.8em&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="space-before.maximum"&gt;1.2em&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="keep-with-next.within-column"&gt;always&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="keep-together.within-column"&gt;always&lt;/xsl:attribute&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-<refsection><info><title>Description</title></info>
-<para>These properties are added to the block containing a
-glossary term in a glossary when the <parameter>glossary.as.blocks</parameter> parameter
-is non-zero.
-Use this attribute-set to set the space above and below,
-font properties,
-and any indent for the glossary term.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="glossdef.block.properties">
-<refmeta>
-<refentrytitle>glossdef.block.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>glossdef.block.properties</refname>
-<refpurpose>To add properties to the block of a glossary definition.</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="glossdef.block.properties.frag">&lt;xsl:attribute-set name="glossdef.block.properties"&gt;
-  &lt;xsl:attribute name="margin-{$direction.align.start}"&gt;.25in&lt;/xsl:attribute&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-<refsection><info><title>Description</title></info>
-<para>These properties are added to the block containing a
-glossary definition in a glossary when
-the <parameter>glossary.as.blocks</parameter> parameter
-is non-zero.
-Use this attribute-set to set the space above and below,
-any font properties,
-and any indent for the glossary definition.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="glossterm.list.properties">
-<refmeta>
-<refentrytitle>glossterm.list.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>glossterm.list.properties</refname>
-<refpurpose>To add properties to the glossterm in a list.</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="glossterm.list.properties.frag">
-&lt;xsl:attribute-set name="glossterm.list.properties"&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-<refsection><info><title>Description</title></info>
-<para>These properties are added to the block containing a
-glossary term in a glossary when the <parameter>glossary.as.blocks</parameter> parameter
-is zero.
-Use this attribute-set to set
-font properties, for example.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="glossdef.list.properties">
-<refmeta>
-<refentrytitle>glossdef.list.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>glossdef.list.properties</refname>
-<refpurpose>To add properties to the glossary definition in a list.</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="glossdef.list.properties.frag">
-&lt;xsl:attribute-set name="glossdef.list.properties"&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-<refsection><info><title>Description</title></info>
-<para>These properties are added to the block containing a
-glossary definition in a glossary when
-the <parameter>glossary.as.blocks</parameter> parameter
-is zero.
-Use this attribute-set to set font properties, for example.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="glossterm.width">
-<refmeta>
-<refentrytitle>glossterm.width</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">length</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>glossterm.width</refname>
-<refpurpose>Width of glossterm in list presentation mode</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="glossterm.width.frag">
-&lt;xsl:param name="glossterm.width"&gt;2in&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This parameter specifies the width reserved for glossary terms when
-a list presentation is used.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="glossterm.separation">
-<refmeta>
-<refentrytitle>glossterm.separation</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">length</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>glossterm.separation</refname>
-<refpurpose>Separation between glossary terms and descriptions in list mode</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="glossterm.separation.frag">
-&lt;xsl:param name="glossterm.separation"&gt;0.25in&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Specifies the miminum horizontal
-separation between glossary terms and descriptions when
-they are presented side-by-side using lists
-when the <parameter>glossary.as.blocks</parameter>
-is zero.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="glossentry.show.acronym">
-<refmeta>
-<refentrytitle>glossentry.show.acronym</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">list</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">no</refmiscinfo> 
-<refmiscinfo class="other" otherclass="value">yes</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">primary</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>glossentry.show.acronym</refname>
-<refpurpose>Display <tag>glossentry</tag> acronyms?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="glossentry.show.acronym.frag">
-&lt;xsl:param name="glossentry.show.acronym"&gt;no&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>A setting of <quote>yes</quote> means they should be displayed;
-<quote>no</quote> means they shouldn't. If <quote>primary</quote> is used,
-then they are shown as the primary text for the entry.</para>
-
-<note>
-<para>This setting controls both <tag>acronym</tag> and
-<tag>abbrev</tag> elements in the <tag>glossentry</tag>.</para>
-</note>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="glossary.sort">
-<refmeta>
-<refentrytitle>glossary.sort</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>glossary.sort</refname>
-<refpurpose>Sort glossentry elements?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="glossary.sort.frag">
-&lt;xsl:param name="glossary.sort" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, then the glossentry elements within a
-glossary, glossdiv, or glosslist are sorted on the glossterm, using
-the current lang setting.  If zero (the default), then
-glossentry elements are not sorted and are presented
-in document order.
-</para>
-
-</refsection>
-</refentry>
-
-</reference><reference id="misc" xml:base="../fo/param.xml"><title>Miscellaneous</title>
-<refentry version="5.0" id="formal.procedures">
-<refmeta>
-<refentrytitle>formal.procedures</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>formal.procedures</refname>
-<refpurpose>Selects formal or informal procedures</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="formal.procedures.frag">
-&lt;xsl:param name="formal.procedures" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Formal procedures are numbered and always have a title.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="formal.title.placement">
-<refmeta>
-<refentrytitle>formal.title.placement</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">table</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>formal.title.placement</refname>
-<refpurpose>Specifies where formal object titles should occur</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="formal.title.placement.frag">
-&lt;xsl:param name="formal.title.placement"&gt;
-figure before
-example before
-equation before
-table before
-procedure before
-task before
-&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Specifies where formal object titles should occur. For each formal object
-type (<tag>figure</tag>,
-<tag>example</tag>,
-<tag>equation</tag>,
-<tag>table</tag>, and <tag>procedure</tag>)
-you can specify either the keyword
-<quote><literal>before</literal></quote> or
-<quote><literal>after</literal></quote>.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="runinhead.default.title.end.punct">
-<refmeta>
-<refentrytitle>runinhead.default.title.end.punct</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>runinhead.default.title.end.punct</refname>
-<refpurpose>Default punctuation character on a run-in-head</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="runinhead.default.title.end.punct.frag">&lt;xsl:param name="runinhead.default.title.end.punct"&gt;.&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, For a <tag>formalpara</tag>, use the specified
-string as the separator between the title and following text. The period is the default value.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="runinhead.title.end.punct">
-<refmeta>
-<refentrytitle>runinhead.title.end.punct</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>runinhead.title.end.punct</refname>
-<refpurpose>Characters that count as punctuation on a run-in-head</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="runinhead.title.end.punct.frag">
-&lt;xsl:param name="runinhead.title.end.punct"&gt;.!?:&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Specify which characters are to be counted as punctuation. These
-characters are checked for a match with the last character of the
-title. If no match is found, the
-<parameter>runinhead.default.title.end.punct</parameter> contents are
-inserted. This is to avoid duplicated punctuation in the output.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="show.comments">
-<refmeta>
-<refentrytitle>show.comments</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>show.comments</refname>
-<refpurpose>Display <tag>remark</tag> elements?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="show.comments.frag">
-&lt;xsl:param name="show.comments" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, comments will be displayed, otherwise they
-are suppressed.  Comments here refers to the <tag>remark</tag> element
-(which was called <literal>comment</literal> prior to DocBook
-4.0), not XML comments (&lt;-- like this --&gt;) which are
-unavailable.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="punct.honorific">
-<refmeta>
-<refentrytitle>punct.honorific</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>punct.honorific</refname>
-<refpurpose>Punctuation after an honorific in a personal name.</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="punct.honorific.frag">
-&lt;xsl:param name="punct.honorific"&gt;.&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This parameter specifies the punctuation that should be added after an
-honorific in a personal name.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="segmentedlist.as.table">
-<refmeta>
-<refentrytitle>segmentedlist.as.table</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>segmentedlist.as.table</refname>
-<refpurpose>Format segmented lists as tables?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="segmentedlist.as.table.frag">
-&lt;xsl:param name="segmentedlist.as.table" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, <tag>segmentedlist</tag>s will be formatted as
-tables.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="variablelist.as.blocks">
-<refmeta>
-<refentrytitle>variablelist.as.blocks</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>variablelist.as.blocks</refname>
-<refpurpose>Format <tag>variablelist</tag>s lists as blocks?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="variablelist.as.blocks.frag">
-&lt;xsl:param name="variablelist.as.blocks" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, <tag>variablelist</tag>s will be formatted as
-blocks.</para>
-
-<para>If you have long terms, proper list markup in the FO case may produce
-unattractive lists. By setting this parameter, you can force the stylesheets
-to produce block markup instead of proper lists.</para>
-
-<para>You can override this setting with a processing instruction as the
-child of <tag>variablelist</tag>: <tag class="xmlpi">dbfo
-list-presentation="blocks"</tag> or <tag class="xmlpi">dbfo
-list-presentation="list"</tag>.</para>
-
-<para>When using <literal>list-presentation="list"</literal>,
-you can also control the amount of space used for the <tag>term</tag>s with 
-the <tag class="xmlpi">dbfo term-width=".25in"</tag> processing instruction,
-the <tag class="attribute">termlength</tag> attribute on <tag>variablelist</tag>,
-or allow the stylesheets to attempt to calculate the amount of space to leave based on the 
-number of letters in the longest term.  
-</para>
-
-<programlisting>  &lt;variablelist&gt;
-        &lt;?dbfo list-presentation="list"?&gt;
-        &lt;?dbfo term-width="1.5in"?&gt;
-        &lt;?dbhtml list-presentation="table"?&gt;
-        &lt;?dbhtml term-width="1.5in"?&gt;
-        &lt;varlistentry&gt;
-          &lt;term&gt;list&lt;/term&gt;
-          &lt;listitem&gt;
-                &lt;para&gt;
-                  Formatted as a list even if variablelist.as.blocks is set to 1.
-                &lt;/para&gt;
-          &lt;/listitem&gt;
-        &lt;/varlistentry&gt;
-  &lt;/variablelist&gt;</programlisting>
-
-
-</refsection>
-
-</refentry>
-
-<refentry version="5.0" id="blockquote.properties">
-<refmeta>
-  <refentrytitle>blockquote.properties</refentrytitle>
-  <refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>  
-<refnamediv>
-<refname>blockquote.properties</refname>
-<refpurpose>To set the style for block quotations.</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="blockquote.properties.frag">
-&lt;xsl:attribute-set name="blockquote.properties"&gt;
-&lt;xsl:attribute name="margin-{$direction.align.start}"&gt;0.5in&lt;/xsl:attribute&gt;
-&lt;xsl:attribute name="margin-{$direction.align.end}"&gt;0.5in&lt;/xsl:attribute&gt;
-&lt;xsl:attribute name="space-after.minimum"&gt;0.5em&lt;/xsl:attribute&gt;
-&lt;xsl:attribute name="space-after.optimum"&gt;1em&lt;/xsl:attribute&gt;
-&lt;xsl:attribute name="space-after.maximum"&gt;2em&lt;/xsl:attribute&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The <parameter>blockquote.properties</parameter> attribute set specifies
-the formating properties of block quotations.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="ulink.show">
-<refmeta>
-<refentrytitle>ulink.show</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>ulink.show</refname>
-<refpurpose>Display URLs after <tag>ulink</tag>s?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="ulink.show.frag">
-&lt;xsl:param name="ulink.show" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, the URL of each <tag>ulink</tag> will
-appear after the text of the link. If the text of the link and the URL
-are identical, the URL is suppressed. </para>
-
-<para>See also <parameter>ulink.footnotes</parameter>.</para>
-
-<note><para>DocBook 5 does not have an <tag>ulink</tag> element. When processing 
-DocBoook 5 documents, <parameter>ulink.show</parameter> applies to all inline 
-elements that are marked up with <tag class="attribute">xlink:href</tag> attributes 
-that point to external resources.</para>
-</note>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="ulink.footnotes">
-<refmeta>
-<refentrytitle>ulink.footnotes</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>ulink.footnotes</refname>
-<refpurpose>Generate footnotes for <tag>ulink</tag>s?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="ulink.footnotes.frag">
-&lt;xsl:param name="ulink.footnotes" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, and if <parameter>ulink.show</parameter> also is non-zero,
-the URL of each <tag>ulink</tag> will appear as a footnote.</para>
-
-<note><para>DocBook 5 does not have an <tag>ulink</tag> element. When processing 
-DocBoook 5 documents, <parameter>ulink.footnotes</parameter> applies to all inline 
-elements that are marked up with <tag class="attribute">xlink:href</tag> attributes 
-that point to external resources.</para>
-</note>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="ulink.hyphenate">
-<refmeta>
-<refentrytitle>ulink.hyphenate</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>ulink.hyphenate</refname>
-<refpurpose>Allow URLs to be automatically hyphenated</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="ulink.hyphenate.frag">
-&lt;xsl:param name="ulink.hyphenate"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If not empty, the specified character (or more generally,
-content) is added to URLs after every character included in the string
-in the <parameter>ulink.hyphenate.chars</parameter> parameter (default
-is <quote>/</quote>) to enable hyphenation of ulinks. If the character
-in this parameter is a Unicode soft hyphen (0x00AD) or Unicode
-zero-width space (0x200B), some FO processors will be able to
-reasonably hyphenate long URLs.</para>
-
-<para>Note that this hyphenation process is only applied when the
-ulink element is empty and the url attribute is reused as the link
-text.  It is not applied if the ulink has literal text content. The
-same applies in in DocBook 5, where ulink was replaced with link with
-an xlink:href attribute.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="ulink.hyphenate.chars">
-<refmeta>
-<refentrytitle>ulink.hyphenate.chars</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>ulink.hyphenate.chars</refname>
-<refpurpose>List of characters to allow ulink URLs to be automatically
-hyphenated on</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="ulink.hyphenate.chars.frag">
-&lt;xsl:param name="ulink.hyphenate.chars"&gt;/&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If the <parameter>ulink.hyphenate</parameter> parameter is not
-empty, then hyphenation of ulinks is turned on, and any character
-contained in this parameter is treated as an allowable hyphenation
-point. This and <parameter>ulink.hyphenate</parameter> work together,
-one is pointless without the other being set to a non-empty value</para>
-
-<para>The default value is <quote>/</quote>, but the parameter could
-be customized to contain other URL characters, as for example:</para>
-<programlisting>
-&lt;xsl:param name="ulink.hyphenate.chars"&gt;:/@&amp;?.#&lt;/xsl:param&gt;
-</programlisting>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="shade.verbatim">
-<refmeta>
-<refentrytitle>shade.verbatim</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>shade.verbatim</refname>
-<refpurpose>Should verbatim environments be shaded?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="shade.verbatim.frag">&lt;xsl:param name="shade.verbatim" select="0"&gt;&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>In the FO stylesheet, if this parameter is non-zero then the
-<property>shade.verbatim.style</property> properties will be applied
-to verbatim environments.</para>
-
-<para>In the HTML stylesheet, this parameter is now deprecated. Use
-CSS instead.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="shade.verbatim.style">
-<refmeta>
-<refentrytitle>shade.verbatim.style</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>shade.verbatim.style</refname>
-<refpurpose>Properties that specify the style of shaded verbatim listings</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="shade.verbatim.style.frag">
-
-&lt;xsl:attribute-set name="shade.verbatim.style"&gt;
-  &lt;xsl:attribute name="background-color"&gt;#E0E0E0&lt;/xsl:attribute&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Properties that specify the style of shaded verbatim listings. The
-parameters specified (the border and background color) are added to
-the styling of the xsl-fo output. A border might be specified as "thin
-black solid" for example. See <link xlink:href="http://www.w3.org/TR/2004/WD-xsl11-20041216/#border">xsl-fo</link></para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="hyphenate.verbatim">
-<refmeta>
-<refentrytitle>hyphenate.verbatim</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>hyphenate.verbatim</refname>
-<refpurpose>Should verbatim environments be hyphenated on space characters?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="hyphenate.verbatim.frag">&lt;xsl:param name="hyphenate.verbatim" select="0"&gt;&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If the lines of program listing are too long to fit into one
-line it is quite common to split them at space and indicite by hook
-arrow that code continues on the next line. You can turn on this
-behaviour for <tag>programlisting</tag>,
-<tag>screen</tag> and <tag>synopsis</tag> elements by
-using this parameter.</para>
-
-<para>Note that you must also enable line wrapping for verbatim environments and
-select appropriate hyphenation character (e.g. hook arrow). This can
-be done using <parameter>monospace.verbatim.properties</parameter>
-attribute set:</para>
-
-<programlisting>&lt;xsl:attribute-set name="monospace.verbatim.properties" 
-                   use-attribute-sets="verbatim.properties monospace.properties"&gt;
-  &lt;xsl:attribute name="wrap-option"&gt;wrap&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="hyphenation-character"&gt;&amp;#x25BA;&lt;/xsl:attribute&gt;
-&lt;/xsl:attribute-set&gt;</programlisting>
-
-<para>For a list of arrows available in Unicode see <uri xlink:href="http://www.unicode.org/charts/PDF/U2190.pdf">http://www.unicode.org/charts/PDF/U2190.pdf</uri> and <uri xlink:href="http://www.unicode.org/charts/PDF/U2900.pdf">http://www.unicode.org/charts/PDF/U2900.pdf</uri> and make sure that
-selected character is available in the font you are using for verbatim
-environments.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="hyphenate.verbatim.characters">
-<refmeta>
-<refentrytitle>hyphenate.verbatim.characters</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>hyphenate.verbatim.characters</refname>
-<refpurpose>List of characters after which a line break can occur in listings</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="hyphenate.verbatim.characters.frag">
-&lt;xsl:param name="hyphenate.verbatim.characters"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If you enable <parameter>hyphenate.verbatim</parameter> line
-breaks are allowed only on space characters. If this is not enough for
-your document, you can specify list of additional characters after
-which line break is allowed in this parameter.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="use.svg">
-<refmeta>
-<refentrytitle>use.svg</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>use.svg</refname>
-<refpurpose>Allow SVG in the result tree?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="use.svg.frag">
-&lt;xsl:param name="use.svg" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, SVG will be considered an acceptable image format. SVG
-is passed through to the result tree, so correct rendering of the resulting
-diagram depends on the formatter (FO processor or web browser) that is used
-to process the output from the stylesheet.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="use.role.as.xrefstyle">
-<refmeta>
-<refentrytitle>use.role.as.xrefstyle</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>use.role.as.xrefstyle</refname>
-<refpurpose>Use <tag class="attribute">role</tag> attribute for
-<tag class="attribute">xrefstyle</tag> on <tag>xref</tag>?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="use.role.as.xrefstyle.frag">
-&lt;xsl:param name="use.role.as.xrefstyle" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>In DocBook documents that conform to a schema older than V4.3, this parameter allows 
-<tag class="attribute">role</tag> to serve the purpose of specifying the cross reference style.</para>
-
-<para>If non-zero, the <tag class="attribute">role</tag> attribute on
-<tag>xref</tag> will be used to select the cross reference style.
-In DocBook V4.3, the <tag class="attribute">xrefstyle</tag> attribute was added for this purpose.
-If the <tag class="attribute">xrefstyle</tag> attribute is present, 
-<tag class="attribute">role</tag> will be ignored, regardless of the setting
-of this parameter.</para>
-
-</refsection>
-
-<refsection><info><title>Example</title></info>
-
-<para>The following small stylesheet shows how to configure the
-stylesheets to make use of the cross reference style:</para>
-
-<programlisting>&lt;?xml version="1.0"?&gt;
-&lt;xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
-                version="1.0"&gt;
-
-&lt;xsl:import href="../xsl/html/docbook.xsl"/&gt;
-
-&lt;xsl:output method="html"/&gt;
-
-&lt;xsl:param name="local.l10n.xml" select="document('')"/&gt;
-&lt;l:i18n xmlns:l="http://docbook.sourceforge.net/xmlns/l10n/1.0"&gt;
-  &lt;l:l10n xmlns:l="http://docbook.sourceforge.net/xmlns/l10n/1.0" language="en"&gt;
-   &lt;l:context name="xref"&gt;
-      &lt;l:template name="chapter" style="title" text="Chapter %n, %t"/&gt;
-      &lt;l:template name="chapter" text="Chapter %n"/&gt;
-    &lt;/l:context&gt;
-  &lt;/l:l10n&gt;
-&lt;/l:i18n&gt;
-
-&lt;/xsl:stylesheet&gt;</programlisting>
-
-<para>With this stylesheet, the cross references in the following document:</para>
-
-<programlisting>&lt;?xml version="1.0" encoding="utf-8"?&gt;
-&lt;!DOCTYPE book PUBLIC "-//OASIS//DTD DocBook XML V4.2//EN"
-                  "http://www.oasis-open.org/docbook/xml/4.2/docbookx.dtd"&gt;
-&lt;book id="book"&gt;&lt;title&gt;Book&lt;/title&gt;
-
-&lt;preface&gt;
-&lt;title&gt;Preface&lt;/title&gt;
-
-&lt;para&gt;Normal: &lt;xref linkend="ch1"/&gt;.&lt;/para&gt;
-&lt;para&gt;Title: &lt;xref xrefstyle="title" linkend="ch1"/&gt;.&lt;/para&gt;
-
-&lt;/preface&gt;
-
-&lt;chapter id="ch1"&gt;
-&lt;title&gt;First Chapter&lt;/title&gt;
-
-&lt;para&gt;Irrelevant.&lt;/para&gt;
-
-&lt;/chapter&gt;
-&lt;/book&gt;</programlisting>
-
-<para>will appear as:</para>
-
-<informalexample>
-<para>Normal: Chapter 1.</para>
-<para>Title: Chapter 1, <emphasis>First Chapter</emphasis>.</para>
-</informalexample>
-</refsection>
-
-</refentry>
-
-<refentry version="5.0" id="menuchoice.separator">
-<refmeta>
-<refentrytitle>menuchoice.separator</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>menuchoice.separator</refname>
-<refpurpose>Separator between items of a <tag>menuchoice</tag>
-other than <tag>guimenuitem</tag> and
-<tag>guisubmenu</tag></refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="menuchoice.separator.frag">
-&lt;xsl:param name="menuchoice.separator"&gt;+&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Separator used to connect items of a <tag>menuchoice</tag> other
-than <tag>guimenuitem</tag> and <tag>guisubmenu</tag>. The latter
-elements are linked with <parameter>menuchoice.menu.separator</parameter>.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="menuchoice.menu.separator">
-<refmeta>
-<refentrytitle>menuchoice.menu.separator</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>menuchoice.menu.separator</refname>
-<refpurpose>Separator between items of a <tag>menuchoice</tag>
-with <tag>guimenuitem</tag> or
-<tag>guisubmenu</tag></refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="menuchoice.menu.separator.frag">
-&lt;xsl:param name="menuchoice.menu.separator"&gt; &#8594; &lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Separator used to connect items of a <tag>menuchoice</tag> with
-<tag>guimenuitem</tag> or <tag>guisubmenu</tag>. Other elements
-are linked with <parameter>menuchoice.separator</parameter>.
-</para>
-<para>The default value is &amp;#x2192;, which is the
-&amp;rarr; (right arrow) character entity.  
-The current FOP (0.20.5) requires setting the font-family
-explicitly.
-</para>
-<para>The default value also includes spaces around the arrow,
-which will allow a line to break.  Replace the spaces with
-&amp;#xA0; (nonbreaking space) if you don't want those
-spaces to break.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="default.float.class">
-<refmeta>
-<refentrytitle>default.float.class</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>default.float.class</refname>
-<refpurpose>Specifies the default float class</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="default.float.class.frag">
-&lt;xsl:param name="default.float.class"&gt;
-  &lt;xsl:choose&gt;
-    &lt;xsl:when test="contains($stylesheet.result.type,'html')"&gt;left&lt;/xsl:when&gt;
-    &lt;xsl:otherwise&gt;before&lt;/xsl:otherwise&gt;
-  &lt;/xsl:choose&gt;
-&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Selects the direction in which a float should be placed. for
-xsl-fo this is before, for html it is left. For Western texts, the
-before direction is the top of the page.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="footnote.number.format">
-<refmeta>
-<refentrytitle>footnote.number.format</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">list</refmiscinfo> 
-<refmiscinfo class="other" otherclass="value">1<alt>1,2,3...</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">A<alt>A,B,C...</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">a<alt>a,b,c...</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">i<alt>i,ii,iii...</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">I<alt>I,II,III...</alt></refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>footnote.number.format</refname>
-<refpurpose>Identifies the format used for footnote numbers</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="footnote.number.format.frag">
-&lt;xsl:param name="footnote.number.format"&gt;1&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The <parameter>footnote.number.format</parameter> specifies the format
-to use for footnote numeration (1, i, I, a, or A).</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="table.footnote.number.format">
-<refmeta>
-<refentrytitle>table.footnote.number.format</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">list</refmiscinfo> 
-<refmiscinfo class="other" otherclass="value">1<alt>1,2,3...</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">A<alt>A,B,C...</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">a<alt>a,b,c...</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">i<alt>i,ii,iii...</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">I<alt>I,II,III...</alt></refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>table.footnote.number.format</refname>
-<refpurpose>Identifies the format used for footnote numbers in tables</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="table.footnote.number.format.frag">
-&lt;xsl:param name="table.footnote.number.format"&gt;a&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The <parameter>table.footnote.number.format</parameter> specifies the format
-to use for footnote numeration (1, i, I, a, or A) in tables.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="footnote.number.symbols">
-<refmeta>
-<refentrytitle>footnote.number.symbols</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype"/>
-</refmeta>
-<refnamediv>
-<refname>footnote.number.symbols</refname>
-<refpurpose>Special characters to use as footnote markers</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="footnote.number.symbols.frag">
-&lt;xsl:param name="footnote.number.symbols"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If <parameter>footnote.number.symbols</parameter> is not the empty string,
-footnotes will use the characters it contains as footnote symbols. For example,
-<quote>*&amp;#x2020;&amp;#x2021;&amp;#x25CA;&amp;#x2720;</quote> will identify
-footnotes with <quote>*</quote>, <quote>&#8224;</quote>, <quote>&#8225;</quote>,
-<quote>&#9674;</quote>, and <quote>&#10016;</quote>. If there are more footnotes
-than symbols, the stylesheets will fall back to numbered footnotes using
-<parameter>footnote.number.format</parameter>.</para>
-
-<para>The use of symbols for footnotes depends on the ability of your
-processor (or browser) to render the symbols you select. Not all systems are
-capable of displaying the full range of Unicode characters. If the quoted characters
-in the preceding paragraph are not displayed properly, that's a good indicator
-that you may have trouble using those symbols for footnotes.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="table.footnote.number.symbols">
-<refmeta>
-<refentrytitle>table.footnote.number.symbols</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>table.footnote.number.symbols</refname>
-<refpurpose>Special characters to use a footnote markers in tables</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="table.footnote.number.symbols.frag">
-&lt;xsl:param name="table.footnote.number.symbols"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If <parameter>table.footnote.number.symbols</parameter> is not the empty string,
-table footnotes will use the characters it contains as footnote symbols. For example,
-<quote>*&amp;#x2020;&amp;#x2021;&amp;#x25CA;&amp;#x2720;</quote> will identify
-footnotes with <quote>*</quote>, <quote>&#8224;</quote>, <quote>&#8225;</quote>,
-<quote>&#9674;</quote>, and <quote>&#10016;</quote>. If there are more footnotes
-than symbols, the stylesheets will fall back to numbered footnotes using
-<parameter>table.footnote.number.format</parameter>.</para>
-
-<para>The use of symbols for footnotes depends on the ability of your
-processor (or browser) to render the symbols you select. Not all systems are
-capable of displaying the full range of Unicode characters. If the quoted characters
-in the preceding paragraph are not displayed properly, that's a good indicator
-that you may have trouble using those symbols for footnotes.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="footnote.properties">
-<refmeta>
-<refentrytitle>footnote.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>  
-<refnamediv>
-<refname>footnote.properties</refname>
-<refpurpose>Properties applied to each footnote body
-</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="footnote.properties.frag">
-&lt;xsl:attribute-set name="footnote.properties"&gt;
-  &lt;xsl:attribute name="font-family"&gt;&lt;xsl:value-of select="$body.fontset"&gt;&lt;/xsl:value-of&gt;&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="font-size"&gt;&lt;xsl:value-of select="$footnote.font.size"&gt;&lt;/xsl:value-of&gt;&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="font-weight"&gt;normal&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="font-style"&gt;normal&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="text-align"&gt;&lt;xsl:value-of select="$alignment"&gt;&lt;/xsl:value-of&gt;&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="start-indent"&gt;0pt&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="end-indent"&gt;0pt&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="text-indent"&gt;0pt&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="hyphenate"&gt;&lt;xsl:value-of select="$hyphenate"&gt;&lt;/xsl:value-of&gt;&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="wrap-option"&gt;wrap&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="linefeed-treatment"&gt;treat-as-space&lt;/xsl:attribute&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This attribute set is applied to the footnote-block 
-for each footnote.
-It can be used to set the
-font-size, font-family, and other inheritable properties that will be
-applied to all footnotes.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="table.footnote.properties">
-<refmeta>
-<refentrytitle>table.footnote.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>table.footnote.properties</refname>
-<refpurpose>Properties applied to each table footnote body
-</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="table.footnote.properties.frag">
-&lt;xsl:attribute-set name="table.footnote.properties"&gt;
-  &lt;xsl:attribute name="font-family"&gt;&lt;xsl:value-of select="$body.fontset"&gt;&lt;/xsl:value-of&gt;&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="font-size"&gt;&lt;xsl:value-of select="$footnote.font.size"&gt;&lt;/xsl:value-of&gt;&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="font-weight"&gt;normal&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="font-style"&gt;normal&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="space-before"&gt;2pt&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="text-align"&gt;&lt;xsl:value-of select="$alignment"&gt;&lt;/xsl:value-of&gt;&lt;/xsl:attribute&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This attribute set is applied to the footnote-block 
-for each table footnote.
-It can be used to set the
-font-size, font-family, and other inheritable properties that will be
-applied to all table footnotes.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="footnote.mark.properties">
-<refmeta>
-<refentrytitle>footnote.mark.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>  
-<refnamediv>
-<refname>footnote.mark.properties</refname>
-<refpurpose>Properties applied to each footnote mark
-</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="footnote.mark.properties.frag">
-&lt;xsl:attribute-set name="footnote.mark.properties"&gt;
-  &lt;xsl:attribute name="font-family"&gt;&lt;xsl:value-of select="$body.fontset"&gt;&lt;/xsl:value-of&gt;&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="font-size"&gt;75%&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="font-weight"&gt;normal&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="font-style"&gt;normal&lt;/xsl:attribute&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This attribute set is applied to the footnote mark used
-for each footnote.
-It should contain only inline properties.
-</para>
-
-<para>The property to make the mark a superscript is contained in the
-footnote template itself, because the current version of FOP reports
-an error if baseline-shift is used.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="footnote.sep.leader.properties">
-<refmeta>
-<refentrytitle>footnote.sep.leader.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>footnote.sep.leader.properties</refname>
-<refpurpose>Properties associated with footnote separators</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="footnote.sep.leader.properties.frag">
-&lt;xsl:attribute-set name="footnote.sep.leader.properties"&gt;
-  &lt;xsl:attribute name="color"&gt;black&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="leader-pattern"&gt;rule&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="leader-length"&gt;1in&lt;/xsl:attribute&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The styling for the rule line that separates the
-footnotes from the body text.
-These are properties applied to the fo:leader used as
-the separator.
-</para>
-<para>If you want to do more than just set properties on
-the leader element, then you can customize the template
-named <literal>footnote.separator</literal> in 
-<filename>fo/pagesetup.xsl</filename>.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="xref.with.number.and.title">
-<refmeta>
-<refentrytitle>xref.with.number.and.title</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>xref.with.number.and.title</refname>
-<refpurpose>Use number and title in cross references</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="xref.with.number.and.title.frag">
-&lt;xsl:param name="xref.with.number.and.title" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>A cross reference may include the number (for example, the number of
-an example or figure) and the <tag>title</tag> which is a required child of some
-targets. This parameter inserts both the relevant number as well as
-the title into the link. </para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="superscript.properties">
-<refmeta>
-<refentrytitle>superscript.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>superscript.properties</refname>
-<refpurpose>Properties associated with superscripts</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="superscript.properties.frag">
-&lt;xsl:attribute-set name="superscript.properties"&gt;
-  &lt;xsl:attribute name="font-size"&gt;75%&lt;/xsl:attribute&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Specifies styling properties for superscripts.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="subscript.properties">
-<refmeta>
-<refentrytitle>subscript.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>subscript.properties</refname>
-<refpurpose>Properties associated with subscripts</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="subscript.properties.frag">
-&lt;xsl:attribute-set name="subscript.properties"&gt;
-  &lt;xsl:attribute name="font-size"&gt;75%&lt;/xsl:attribute&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Specifies styling properties for subscripts.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="pgwide.properties">
-<refmeta>
-<refentrytitle>pgwide.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>pgwide.properties</refname>
-<refpurpose>Properties to make a figure or table page wide.
-</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="pgwide.properties.frag">
-&lt;xsl:attribute-set name="pgwide.properties"&gt;
-  &lt;xsl:attribute name="start-indent"&gt;0pt&lt;/xsl:attribute&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This attribute set is used to set the properties
-that make a figure or table "page wide" in fo output.
-It comes into effect when an attribute <literal>pgwide="1"</literal>
-is used.
-</para>
-
-<para>
-By default, it sets <parameter>start-indent</parameter>
-to <literal>0pt</literal>.
-In a stylesheet that sets the parameter
-<parameter>body.start.indent</parameter>
-to a non-zero value in order to indent body text,
-this attribute set can be used to outdent pgwide
-figures to the start margin.
-</para>
-
-<para>If a document uses a multi-column page layout,
-then this attribute set could try setting <parameter>span</parameter>
-to a value of <literal>all</literal>.  However, this may
-not work with some processors because a span property must be on an
-fo:block that is a direct child of fo:flow.  It may work in
-some processors anyway.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="highlight.source">
-<refmeta>
-<refentrytitle>highlight.source</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>highlight.source</refname>
-<refpurpose>Should the content of <tag>programlisting</tag>
-be syntactically highlighted?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="highlight.source.frag">
-&lt;xsl:param name="highlight.source" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>When this parameter is non-zero, the stylesheets will try to do syntax highlighting of the 
-content of <tag>programlisting</tag> elements. You specify the language for each programlisting 
-by using the <tag class="attribute">language</tag> attribute. The <parameter>highlight.default.language</parameter> 
-parameter can be used to specify the language for programlistings without a <tag class="attribute">language</tag> 
-attribute. Syntax highlighting also works for <tag>screen</tag> and <tag>synopsis</tag> elements.</para>
-
-<para>The actual highlighting work is done by the XSLTHL extension module. This is an external Java library that has to be 
-downloaded separately (see below).</para>
-
-<itemizedlist>
-<para>In order to use this extension, you must</para> 
-
-<listitem><para>add <filename>xslthl-2.x.x.jar</filename> to your Java classpath. The latest version is available
-from <link xlink:href="http://sourceforge.net/projects/xslthl">the XSLT syntax highlighting project</link> 
-at SourceForge.</para>
-</listitem>
-<listitem>
-<para>use a customization layer in which you import one of the following stylesheet modules: 
-<itemizedlist>
-  <listitem>
-    <para><filename>html/highlight.xsl</filename>
-    </para>
-  </listitem>
-<listitem>
-    <para><filename>xhtml/highlight.xsl</filename>
-    </para>
-  </listitem>
-<listitem>
-    <para><filename>xhtml-1_1/highlight.xsl</filename>
-    </para>
-  </listitem>
-<listitem>
-    <para><filename>fo/highlight.xsl</filename>
-    </para>
-</listitem>
-</itemizedlist>
-</para>
-</listitem>
-<listitem><para>let either the <literal>xslthl.config</literal> Java system property or the
-<parameter>highlight.xslthl.config</parameter> parameter point to the configuration file for syntax 
-highlighting (using URL syntax). DocBook XSL comes with a ready-to-use configuration file, 
-<filename>highlighting/xslthl-config.xml</filename>.</para>
-</listitem>
-</itemizedlist>
-
-<para>The extension works with Saxon 6.5.x and Xalan-J. (Saxon 8.5 or later is also supported, but since it is 
-an XSLT 2.0 processor it is not guaranteed to work with DocBook XSL in all circumstances.)</para>
-
-<para>The following is an example of a Saxon 6 command adapted for syntax highlighting, to be used on Windows:</para>
-
-<informalexample>
-<para><command>java -cp c:/Java/saxon.jar;c:/Java/xslthl-2.0.1.jar 
--Dxslthl.config=file:///c:/docbook-xsl/highlighting/xslthl-config.xml com.icl.saxon.StyleSheet 
--o test.html test.xml myhtml.xsl</command></para>
-</informalexample>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="highlight.xslthl.config">
-<refmeta>
-<refentrytitle>highlight.xslthl.config</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">uri</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>highlight.xslthl.config</refname>
-<refpurpose>Location of XSLTHL configuration file</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="highlight.xslthl.config.frag">
-&lt;xsl:param name="highlight.xslthl.config"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This location has precedence over the corresponding Java property.</para>
-
-<para>Please note that usually you have to specify location as URL not
-just as a simple path on the local
-filesystem. E.g. <filename>file:///home/user/xslthl/my-xslthl-config.xml</filename>.</para>
-
-
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="highlight.default.language">
-<refmeta>
-<refentrytitle>highlight.default.language</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>highlight.default.language</refname>
-<refpurpose>Default language of programlisting</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="highlight.default.language.frag">
-&lt;xsl:param name="highlight.default.language"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This language is used when there is no language attribute on programlisting.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="email.delimiters.enabled">
-<refmeta>
-<refentrytitle>email.delimiters.enabled</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>email.delimiters.enabled</refname>
-<refpurpose>Generate delimiters around email addresses?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="email.delimiters.enabled.frag">
-&lt;xsl:param name="email.delimiters.enabled" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, delimiters
-
-<footnote><para>For delimiters, the
-stylesheets are currently hard-coded to output angle
-brackets.</para></footnote> 
-
-are generated around e-mail addresses
-(the output of the <tag>email</tag> element).</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="email.mailto.enabled">
-<refmeta>
-<refentrytitle>email.mailto.enabled</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>email.mailto.enabled</refname>
-<refpurpose>Generate mailto: links for email addresses?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="email.mailto.enabled.frag">
-&lt;xsl:param name="email.mailto.enabled" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero the generated output for the <tag>email</tag> element
-will be a clickable mailto: link that brings up the default mail client
-on the system.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="section.container.element">
-<refmeta>
-<refentrytitle>section.container.element</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">list</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">block</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">wrapper</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>section.container.element</refname>
-<refpurpose>Select XSL-FO element name to contain sections</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="section.container.element.frag">
-&lt;xsl:param name="section.container.element"&gt;block&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Selects the element name for outer container of
-each section. The choices are <literal>block</literal> (default)
-or <literal>wrapper</literal>.
-The <literal>fo:</literal> namespace prefix is added
-by the stylesheet to form the full element name.
-</para>
-
-<para>This element receives the section <literal>id</literal>
-attribute and the appropriate section level attribute-set.
-</para>
-
-<para>Changing this parameter to <literal>wrapper</literal>
-is only necessary when producing multi-column output
-that contains page-wide spans.  Using <literal>fo:wrapper</literal>
-avoids the nesting of <literal>fo:block</literal>
-elements that prevents spans from working (the standard says
-a span must be on a block that is a direct child of 
-<literal>fo:flow</literal>).
-</para>
-
-<para>If set to <literal>wrapper</literal>, the
-section attribute-sets only support properties
-that are inheritable.  That's because there is no
-block to apply them to.  Properties such as
-font-family are inheritable, but properties such as
-border are not.
-</para>
-
-<para>Only some XSL-FO processors need to use this parameter.
-The Antenna House processor, for example, will handle 
-spans in nested blocks without changing the element name.
-The RenderX XEP product and FOP follow the XSL-FO standard 
-and need to use <literal>wrapper</literal>.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="monospace.verbatim.font.width">
-<refmeta>
-<refentrytitle>monospace.verbatim.font.width</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">length</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>monospace.verbatim.font.width</refname>
-<refpurpose>Width of a single monospace font character</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="monospace.verbatim.font.width.frag">
-&lt;xsl:param name="monospace.verbatim.font.width"&gt;0.60em&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Specifies with em units the width of a single character
-of the monospace font. The default value is <literal>0.6em</literal>.</para>
-
-<para>This parameter is only used when a <tag>screen</tag>
-or <tag>programlisting</tag> element has a 
-<tag class="attribute">width</tag> attribute, which is
-expressed as a plain integer to indicate the maximum character count
-of each line.
-To convert this character count to an actual maximum width
-measurement, the width of the font characters must be provided.
-Different monospace fonts have different character width,
-so this parameter should be adjusted to fit the 
-monospace font being used.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="exsl.node.set.available">
-<refmeta>
-<refentrytitle>exsl.node.set.available</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>exsl.node.set.available</refname>
-<refpurpose>Is the test function-available('exsl:node-set') true?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="exsl.node.set.available.frag">&lt;xsl:param name="exsl.node.set.available"&gt; 
-  &lt;xsl:choose&gt;
-    &lt;xsl:when exsl:foo="" test="function-available('exsl:node-set') or                        contains(system-property('xsl:vendor'),                          'Apache Software Foundation')"&gt;1&lt;/xsl:when&gt;
-    &lt;xsl:otherwise&gt;0&lt;/xsl:otherwise&gt;
-  &lt;/xsl:choose&gt;
-&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero,
-then the exsl:node-set() function is available to be used in
-the stylesheet.
-If zero, then the function is not available.
-This param automatically detects the presence of
-the function and does not normally need to be set manually.</para>
-
-<para>This param was created to handle a long-standing
-bug in the Xalan processor that fails to detect the
-function even though it is available.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="bookmarks.collapse">
-<refmeta>
-<refentrytitle>bookmarks.collapse</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo> 
-</refmeta>
-<refnamediv>
-<refname>bookmarks.collapse</refname>
-<refpurpose>Specifies the initial state of bookmarks</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="bookmarks.collapse.frag">
-&lt;xsl:param name="bookmarks.collapse" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, the bookmark tree is collapsed so that only the 
-top-level bookmarks are displayed initially. Otherwise, the whole tree 
-of bookmarks is displayed.</para>
-
-<para>This parameter currently works with FOP 0.93 or later.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="generate.consistent.ids">
-<refmeta>
-<refentrytitle>generate.consistent.ids</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>generate.consistent.ids</refname>
-<refpurpose>Generate consistent id values if document is unchanged</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="generate.consistent.ids.frag">
-&lt;xsl:param name="generate.consistent.ids" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>When the stylesheet assigns an id value to an output element,
-the generate-id() function may be used.  That function may not
-produce consistent values between runs.  Version control
-systems may misidentify the changing id values as changes
-to the document.</para>
-
-<para>If you set this parameter's value to 1, then the
-template named <literal>object.id</literal> will replace
-the use of the function generate-id() with
-<literal>&lt;xsl:number level="multiple" count="*"/&gt;</literal>.
-This counts preceding elements to generate a unique number for
-the id value.</para>
-
-<caution>
-<para>This param does not associate permanent unique id values
-with particular elements.
-The id values are consistent only as long as the document
-structure does not change.
-If the document structure changes, then the counting
-of elements changes, and all id values after
-the first such change may be different, even when there is
-no change to the element itself or its output.
-</para>
-</caution>
-
-<para>The default value of this parameter is zero, so generate-id() is used
-by default.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="base.dir">
-<refmeta>
-<refentrytitle>base.dir</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">uri</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>base.dir</refname>
-<refpurpose>The base directory of chunks</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="base.dir.frag">
-&lt;xsl:param name="base.dir"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If specified, the <parameter>base.dir</parameter> parameter identifies
-the output directory for chunks. (If not specified, the output directory
-is system dependent.)</para>
-
-<para>Starting with version 1.77 of the stylesheets, 
-the param's value will have a trailing slash added if it does
-not already have one.</para>
-
-<caution><para>Do not use <parameter>base.dir</parameter>
-to add a filename prefix string to chunked  files. 
-Instead, use the <parameter>chunked.filename.prefix</parameter>
-parameter.</para></caution>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="chunk.quietly">
-<refmeta>
-<refentrytitle>chunk.quietly</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>chunk.quietly</refname>
-<refpurpose>Omit the chunked filename messages.</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="chunk.quietly.frag">
-&lt;xsl:param name="chunk.quietly" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If zero (the default), the XSL processor emits a message naming
-each separate chunk filename as it is being output.
-If nonzero, then the messages are suppressed.
-</para>
-
-</refsection>
-</refentry>
-
-</reference><reference id="graphics" xml:base="../fo/param.xml"><title>Graphics</title>
-<refentry version="5.0" id="graphic.default.extension">
-<refmeta>
-<refentrytitle>graphic.default.extension</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>graphic.default.extension</refname>
-<refpurpose>Default extension for graphic filenames</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="graphic.default.extension.frag">&lt;xsl:param name="graphic.default.extension"&gt;&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If a <tag>graphic</tag> or <tag>mediaobject</tag>
-includes a reference to a filename that does not include an extension,
-and the <tag class="attribute">format</tag> attribute is
-<emphasis>unspecified</emphasis>, the default extension will be used.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="default.image.width">
-<refmeta>
-<refentrytitle>default.image.width</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">length</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>default.image.width</refname>
-<refpurpose>The default width of images</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="default.image.width.frag">
-&lt;xsl:param name="default.image.width"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If specified, this value will be used for the
-<tag class="attribute">width</tag> attribute on images that do not specify any 
-<emphasis xlink:title="DocBook 5: The Definitive Guide" xlink:href="http://docbook.org/tdg5/en/html/imagedata.html#viewport.area">viewport dimensions</emphasis>.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="preferred.mediaobject.role">
-<refmeta>
-<refentrytitle>preferred.mediaobject.role</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>preferred.mediaobject.role</refname>
-<refpurpose>Select which mediaobject to use based on
-this value of an object's <tag class="attribute">role</tag> attribute.
-</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="preferred.mediaobject.role.frag">
-&lt;xsl:param name="preferred.mediaobject.role"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>A mediaobject may contain several objects such as imageobjects.
-If the parameter <parameter>use.role.for.mediaobject</parameter> is
-non-zero, then the <literal>role</literal> attribute on
-<tag>imageobject</tag>s and other objects within a
-<tag>mediaobject</tag> container will be used to select which object
-will be used.  If one of the objects has a role value that matches the
-<parameter>preferred.mediaobject.role</parameter> parameter, then it
-has first priority for selection.  If more than one has such a role
-value, the first one is used.
-</para>
-<para>
-See the <parameter>use.role.for.mediaobject</parameter> parameter
-for the sequence of selection.</para>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="use.role.for.mediaobject">
-<refmeta>
-<refentrytitle>use.role.for.mediaobject</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>use.role.for.mediaobject</refname>
-<refpurpose>Use <tag class="attribute">role</tag> attribute 
-value for selecting which of several objects within a mediaobject to use.
-</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="use.role.for.mediaobject.frag">
-&lt;xsl:param name="use.role.for.mediaobject" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, the <tag class="attribute">role</tag> attribute on
-<tag>imageobject</tag>s or other objects within a <tag>mediaobject</tag> container will be used to select which object will be
-used.
-</para>
-<para>
-The order of selection when then parameter is non-zero is:
-</para>
-<orderedlist>
-<listitem>
-    <para>If the stylesheet parameter <parameter>preferred.mediaobject.role</parameter> has a value, then the object whose role equals that value is selected.</para>
-</listitem>
-<listitem>
-<para>Else if an object's role attribute has a value of
-<literal>html</literal> for HTML processing or
-<literal>fo</literal> for FO output, then the first
-of such objects is selected.
-</para>
-</listitem>
-<listitem>
-<para>Else the first suitable object is selected.</para>
-</listitem>
-</orderedlist>
-<para>
-If the value of 
-<parameter>use.role.for.mediaobject</parameter>
-is zero, then role attributes are not considered
-and the first suitable object
-with or without a role value is used.
-</para>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="ignore.image.scaling">
-<refmeta>
-<refentrytitle>ignore.image.scaling</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>ignore.image.scaling</refname>
-<refpurpose>Tell the stylesheets to ignore the author's image scaling attributes</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="ignore.image.scaling.frag">
-&lt;xsl:param name="ignore.image.scaling" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, the scaling attributes on graphics and media objects are
-ignored.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="img.src.path">
-<refmeta>
-<refentrytitle>img.src.path</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>img.src.path</refname>
-<refpurpose>Path to HTML/FO image files</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="img.src.path.frag">&lt;xsl:param name="img.src.path"&gt;&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Add a path prefix to the value of the <tag class="attribute">fileref</tag> 
-attribute of <tag>graphic</tag>, <tag>inlinegraphic</tag>, and <tag>imagedata</tag> elements. The resulting 
-compound path is used in the output as the value of the <tag class="attribute">src</tag> 
-attribute of <tag class="element">img</tag> (HTML) or <tag class="element">external-graphic</tag> (FO).
-</para>
-
-<para>
-The path given by <literal>img.src.path</literal> could be relative to the directory where the HTML/FO
-files are created, or it could be an absolute URI.
-The default value is empty.
-Be sure to include a trailing slash if needed.
-</para>
-
-<para>This prefix is not applied to any filerefs that start
-with "/" or contain "//:".
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="keep.relative.image.uris">
-<refmeta>
-<refentrytitle>keep.relative.image.uris</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>keep.relative.image.uris</refname>
-<refpurpose>Should image URIs be resolved against xml:base?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="keep.relative.image.uris.frag">
-
-&lt;xsl:param name="keep.relative.image.uris" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, relative URIs (in, for example
-<literal>fileref</literal> attributes) will be used in the generated
-output. Otherwise, the URIs will be made absolute with respect to the
-base URI.</para>
-
-<para>Note that the stylesheets calculate (and use) the absolute form
-for some purposes, this only applies to the resulting output.</para>
-
-</refsection>
-</refentry>
-
-</reference><reference id="general" xml:base="../fo/param.xml"><title>Pagination and General Styles</title>
-<partintro id="margins_partintro">
-<section id="margins_intro"><title>Understanding XSL FO Margins</title>
-
-<para>To make sense of the parameters in this section, it's useful to
-consider <xref linkend="fig.pagemodel"/>.</para>
-
-<figure id="fig.pagemodel">
-  <title>Page Model</title>
-  <mediaobject id="fo-pageregions-image">
-    <imageobject role="html">
-      <imagedata fileref="page.png"/>
-    </imageobject>
-    <imageobject role="fo">
-      <imagedata fileref="fo/page.png"/>
-    </imageobject>
-    <textobject><phrase>Figure showing page margins</phrase></textobject>
-    <textobject>
-      <para>This figure shows the physical page with the various FO page regions
-      identified.</para>
-    </textobject>
-  </mediaobject>
-</figure>
-
-<para>First, let's consider the regions on the page.</para>
-
-<para>The white region is the physical page. Its dimensions are determined by
-the <parameter>page.height</parameter> and <parameter>page.width</parameter>
-parameters.</para>
-
-<para>The yellow region is the region-body. The size and placement of
-the region body is constrained by the dimensions labelled in the
-figure.</para>
-
-<para>The pink region at the top of the page is the region-before. The
-darker area inside the region-before is the header text. In XSL, the default
-display alignment for a region is <literal>before</literal>, but the
-DocBook stylesheets still explicitly make it <literal>before</literal>. That's
-why the darker area is at the top.</para>
-
-<para>The pink region at the bottom of the page is the region-after.
-The darker area is the footer text. In XSL, the default display
-alignment for a region is <literal>before</literal>,
-but the DocBook stylesheets explicitly make it
-<literal>after</literal>. That's why the darker area is at the bottom.</para>
-
-<para>The dimensions in the figure are:</para>
-
-<orderedlist numeration="upperalpha">
-<listitem><para>The page-master margin-top.
-</para></listitem>
-<listitem><para>The region-before extent.
-</para></listitem>
-<listitem><para>The region-body margin-top.
-</para></listitem>
-<listitem><para>The region-after extent.
-</para></listitem>
-<listitem><para>The page-master margin-bottom.
-</para></listitem>
-<listitem><para>The region-body margin-bottom.
-</para></listitem>
-<listitem><para>The sum of the page-master margin-left and the
-region-body margin-left. In DocBook, the region-body margin-left is
-zero by default, so this is simply the page-master margin-left.
-</para></listitem>
-<listitem><para>The sum of the page-master margin-right and the
-region-body margin-right. In DocBook, the region-body margin-right is
-zero by default, so this is simply the page-master margin-right.
-</para></listitem>
-</orderedlist>
-
-</section>
-</partintro>
-
-<refentry version="5.0" id="page.height">
-<refmeta>
-<refentrytitle>page.height</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">length</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>page.height</refname>
-<refpurpose>The height of the physical page</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="page.height.frag">&lt;xsl:param name="page.height"&gt;
-  &lt;xsl:choose&gt;
-    &lt;xsl:when test="$page.orientation = 'portrait'"&gt;
-      &lt;xsl:value-of select="$page.height.portrait"&gt;&lt;/xsl:value-of&gt;
-    &lt;/xsl:when&gt;
-    &lt;xsl:otherwise&gt;
-      &lt;xsl:value-of select="$page.width.portrait"&gt;&lt;/xsl:value-of&gt;
-    &lt;/xsl:otherwise&gt;
-  &lt;/xsl:choose&gt;
-&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The page height is generally calculated from the
-<parameter>paper.type</parameter> and
-<parameter>page.orientation</parameter> parameters.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="page.height.portrait">
-<refmeta>
-<refentrytitle>page.height.portrait</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">length</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>page.height.portrait</refname>
-<refpurpose>Specify the physical size of the long edge of the page</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="page.height.portrait.frag">&lt;xsl:param name="page.height.portrait"&gt;
-  &lt;xsl:choose&gt;
-    &lt;xsl:when test="$paper.type = 'A4landscape'"&gt;210mm&lt;/xsl:when&gt;
-    &lt;xsl:when test="$paper.type = 'USletter'"&gt;11in&lt;/xsl:when&gt;
-    &lt;xsl:when test="$paper.type = 'USlandscape'"&gt;8.5in&lt;/xsl:when&gt;
-    &lt;xsl:when test="$paper.type = 'USlegal'"&gt;14in&lt;/xsl:when&gt;
-    &lt;xsl:when test="$paper.type = 'USlegallandscape'"&gt;8.5in&lt;/xsl:when&gt;
-    &lt;xsl:when test="$paper.type = '4A0'"&gt;2378mm&lt;/xsl:when&gt;
-    &lt;xsl:when test="$paper.type = '2A0'"&gt;1682mm&lt;/xsl:when&gt;
-    &lt;xsl:when test="$paper.type = 'A0'"&gt;1189mm&lt;/xsl:when&gt;
-    &lt;xsl:when test="$paper.type = 'A1'"&gt;841mm&lt;/xsl:when&gt;
-    &lt;xsl:when test="$paper.type = 'A2'"&gt;594mm&lt;/xsl:when&gt;
-    &lt;xsl:when test="$paper.type = 'A3'"&gt;420mm&lt;/xsl:when&gt;
-    &lt;xsl:when test="$paper.type = 'A4'"&gt;297mm&lt;/xsl:when&gt;
-    &lt;xsl:when test="$paper.type = 'A5'"&gt;210mm&lt;/xsl:when&gt;
-    &lt;xsl:when test="$paper.type = 'A6'"&gt;148mm&lt;/xsl:when&gt;
-    &lt;xsl:when test="$paper.type = 'A7'"&gt;105mm&lt;/xsl:when&gt;
-    &lt;xsl:when test="$paper.type = 'A8'"&gt;74mm&lt;/xsl:when&gt;
-    &lt;xsl:when test="$paper.type = 'A9'"&gt;52mm&lt;/xsl:when&gt;
-    &lt;xsl:when test="$paper.type = 'A10'"&gt;37mm&lt;/xsl:when&gt;
-    &lt;xsl:when test="$paper.type = 'B0'"&gt;1414mm&lt;/xsl:when&gt;
-    &lt;xsl:when test="$paper.type = 'B1'"&gt;1000mm&lt;/xsl:when&gt;
-    &lt;xsl:when test="$paper.type = 'B2'"&gt;707mm&lt;/xsl:when&gt;
-    &lt;xsl:when test="$paper.type = 'B3'"&gt;500mm&lt;/xsl:when&gt;
-    &lt;xsl:when test="$paper.type = 'B4'"&gt;353mm&lt;/xsl:when&gt;
-    &lt;xsl:when test="$paper.type = 'B5'"&gt;250mm&lt;/xsl:when&gt;
-    &lt;xsl:when test="$paper.type = 'B6'"&gt;176mm&lt;/xsl:when&gt;
-    &lt;xsl:when test="$paper.type = 'B7'"&gt;125mm&lt;/xsl:when&gt;
-    &lt;xsl:when test="$paper.type = 'B8'"&gt;88mm&lt;/xsl:when&gt;
-    &lt;xsl:when test="$paper.type = 'B9'"&gt;62mm&lt;/xsl:when&gt;
-    &lt;xsl:when test="$paper.type = 'B10'"&gt;44mm&lt;/xsl:when&gt;
-    &lt;xsl:when test="$paper.type = 'C0'"&gt;1297mm&lt;/xsl:when&gt;
-    &lt;xsl:when test="$paper.type = 'C1'"&gt;917mm&lt;/xsl:when&gt;
-    &lt;xsl:when test="$paper.type = 'C2'"&gt;648mm&lt;/xsl:when&gt;
-    &lt;xsl:when test="$paper.type = 'C3'"&gt;458mm&lt;/xsl:when&gt;
-    &lt;xsl:when test="$paper.type = 'C4'"&gt;324mm&lt;/xsl:when&gt;
-    &lt;xsl:when test="$paper.type = 'C5'"&gt;229mm&lt;/xsl:when&gt;
-    &lt;xsl:when test="$paper.type = 'C6'"&gt;162mm&lt;/xsl:when&gt;
-    &lt;xsl:when test="$paper.type = 'C7'"&gt;114mm&lt;/xsl:when&gt;
-    &lt;xsl:when test="$paper.type = 'C8'"&gt;81mm&lt;/xsl:when&gt;
-    &lt;xsl:when test="$paper.type = 'C9'"&gt;57mm&lt;/xsl:when&gt;
-    &lt;xsl:when test="$paper.type = 'C10'"&gt;40mm&lt;/xsl:when&gt;
-    &lt;xsl:otherwise&gt;11in&lt;/xsl:otherwise&gt;
-  &lt;/xsl:choose&gt;
-&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The portrait page height is the length of the long
-edge of the physical page.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="page.margin.bottom">
-<refmeta>
-<refentrytitle>page.margin.bottom</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">length</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>page.margin.bottom</refname>
-<refpurpose>The bottom margin of the page</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="page.margin.bottom.frag">
-&lt;xsl:param name="page.margin.bottom"&gt;0.5in&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The bottom page margin is the distance from the bottom of the region-after
-to the physical bottom of the page.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="page.margin.inner">
-<refmeta>
-<refentrytitle>page.margin.inner</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">length</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>page.margin.inner</refname>
-<refpurpose>The inner page margin</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="page.margin.inner.frag">&lt;xsl:param name="page.margin.inner"&gt;
-  &lt;xsl:choose&gt;
-    &lt;xsl:when test="$double.sided != 0"&gt;1.25in&lt;/xsl:when&gt;
-    &lt;xsl:otherwise&gt;1in&lt;/xsl:otherwise&gt;
-  &lt;/xsl:choose&gt;
-&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The inner page margin is the distance from bound edge of the
-page to the first column of text. </para>
-
-<para>The inner page margin is the distance from bound edge of the
-page to the outer edge of the first column of text.</para>
-
-<para>In left-to-right text direction,
-this is the left margin of recto (front side) pages.
-For single-sided output, it is the left margin
-of all pages.</para>
-
-<para>In right-to-left text direction,
-this is the right margin of recto pages.
-For single-sided output, this is the
-right margin of all pages.</para>
-
-<note>
-<para>Current versions (at least as of version 4.13)
-of the XEP XSL-FO processor do not
-correctly handle these margin settings for documents
-with right-to-left text direction.
-The workaround in that situation is to reverse
-the values for <parameter>page.margin.inner</parameter>
-and <parameter>page.margin.outer</parameter>, until
-this bug is fixed by RenderX.  It does not affect documents
-with left-to-right text direction.</para>
-</note>
-
-<para>See also <parameter>writing.mode</parameter>.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="page.margin.outer">
-<refmeta>
-<refentrytitle>page.margin.outer</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">length</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>page.margin.outer</refname>
-<refpurpose>The outer page margin</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="page.margin.outer.frag">&lt;xsl:param name="page.margin.outer"&gt;
-  &lt;xsl:choose&gt;
-    &lt;xsl:when test="$double.sided != 0"&gt;0.75in&lt;/xsl:when&gt;
-    &lt;xsl:otherwise&gt;1in&lt;/xsl:otherwise&gt;
-  &lt;/xsl:choose&gt;
-&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The outer page margin is the distance from non-bound edge of the
-page to the outer edge of the last column of text.</para>
-
-<para>In left-to-right text direction,
-this is the right margin of recto (front side) pages.
-For single-sided output, it is the right margin
-of all pages.</para>
-
-<para>In right-to-left text direction,
-this is the left margin of recto pages.
-For single-sided output, this is the
-left margin of all pages.</para>
-
-<note>
-<para>Current versions (at least as of version 4.13)
-of the XEP XSL-FO processor do not
-correctly handle these margin settings for documents
-with right-to-left text direction.
-The workaround in that situation is to reverse
-the values for <parameter>page.margin.inner</parameter>
-and <parameter>page.margin.outer</parameter>, until
-this bug is fixed by RenderX.  It does not affect documents
-with left-to-right text direction.</para>
-</note>
-
-<para>See also <parameter>writing.mode</parameter>.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="page.margin.top">
-<refmeta>
-<refentrytitle>page.margin.top</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">length</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>page.margin.top</refname>
-<refpurpose>The top margin of the page</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="page.margin.top.frag">
-&lt;xsl:param name="page.margin.top"&gt;0.5in&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The top page margin is the distance from the physical top of the
-page to the top of the region-before.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="page.orientation">
-<refmeta>
-<refentrytitle>page.orientation</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">list</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">portrait</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">landscape</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>page.orientation</refname>
-<refpurpose>Select the page orientation</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="page.orientation.frag">
-&lt;xsl:param name="page.orientation"&gt;portrait&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para> Select one from portrait or landscape.
-In portrait orientation, the short edge is horizontal; in
-landscape orientation, it is vertical.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="page.width">
-<refmeta>
-<refentrytitle>page.width</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">length</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>page.width</refname>
-<refpurpose>The width of the physical page</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="page.width.frag">&lt;xsl:param name="page.width"&gt;
-  &lt;xsl:choose&gt;
-    &lt;xsl:when test="$page.orientation = 'portrait'"&gt;
-      &lt;xsl:value-of select="$page.width.portrait"&gt;&lt;/xsl:value-of&gt;
-    &lt;/xsl:when&gt;
-    &lt;xsl:otherwise&gt;
-      &lt;xsl:value-of select="$page.height.portrait"&gt;&lt;/xsl:value-of&gt;
-    &lt;/xsl:otherwise&gt;
-  &lt;/xsl:choose&gt;
-&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The page width is generally calculated from the
-<parameter>paper.type</parameter> and 
-<parameter>page.orientation</parameter> parameters.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="page.width.portrait">
-<refmeta>
-<refentrytitle>page.width.portrait</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">length</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>page.width.portrait</refname>
-<refpurpose>Specify the physical size of the short edge of the page</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="page.width.portrait.frag">&lt;xsl:param name="page.width.portrait"&gt;
-  &lt;xsl:choose&gt;
-    &lt;xsl:when test="$paper.type = 'USletter'"&gt;8.5in&lt;/xsl:when&gt;
-    &lt;xsl:when test="$paper.type = 'USlandscape'"&gt;11in&lt;/xsl:when&gt;
-    &lt;xsl:when test="$paper.type = 'USlegal'"&gt;8.5in&lt;/xsl:when&gt;
-    &lt;xsl:when test="$paper.type = 'USlegallandscape'"&gt;14in&lt;/xsl:when&gt;
-    &lt;xsl:when test="$paper.type = '4A0'"&gt;1682mm&lt;/xsl:when&gt;
-    &lt;xsl:when test="$paper.type = '2A0'"&gt;1189mm&lt;/xsl:when&gt;
-    &lt;xsl:when test="$paper.type = 'A0'"&gt;841mm&lt;/xsl:when&gt;
-    &lt;xsl:when test="$paper.type = 'A1'"&gt;594mm&lt;/xsl:when&gt;
-    &lt;xsl:when test="$paper.type = 'A2'"&gt;420mm&lt;/xsl:when&gt;
-    &lt;xsl:when test="$paper.type = 'A3'"&gt;297mm&lt;/xsl:when&gt;
-    &lt;xsl:when test="$paper.type = 'A4'"&gt;210mm&lt;/xsl:when&gt;
-    &lt;xsl:when test="$paper.type = 'A5'"&gt;148mm&lt;/xsl:when&gt;
-    &lt;xsl:when test="$paper.type = 'A6'"&gt;105mm&lt;/xsl:when&gt;
-    &lt;xsl:when test="$paper.type = 'A7'"&gt;74mm&lt;/xsl:when&gt;
-    &lt;xsl:when test="$paper.type = 'A8'"&gt;52mm&lt;/xsl:when&gt;
-    &lt;xsl:when test="$paper.type = 'A9'"&gt;37mm&lt;/xsl:when&gt;
-    &lt;xsl:when test="$paper.type = 'A10'"&gt;26mm&lt;/xsl:when&gt;
-    &lt;xsl:when test="$paper.type = 'B0'"&gt;1000mm&lt;/xsl:when&gt;
-    &lt;xsl:when test="$paper.type = 'B1'"&gt;707mm&lt;/xsl:when&gt;
-    &lt;xsl:when test="$paper.type = 'B2'"&gt;500mm&lt;/xsl:when&gt;
-    &lt;xsl:when test="$paper.type = 'B3'"&gt;353mm&lt;/xsl:when&gt;
-    &lt;xsl:when test="$paper.type = 'B4'"&gt;250mm&lt;/xsl:when&gt;
-    &lt;xsl:when test="$paper.type = 'B5'"&gt;176mm&lt;/xsl:when&gt;
-    &lt;xsl:when test="$paper.type = 'B6'"&gt;125mm&lt;/xsl:when&gt;
-    &lt;xsl:when test="$paper.type = 'B7'"&gt;88mm&lt;/xsl:when&gt;
-    &lt;xsl:when test="$paper.type = 'B8'"&gt;62mm&lt;/xsl:when&gt;
-    &lt;xsl:when test="$paper.type = 'B9'"&gt;44mm&lt;/xsl:when&gt;
-    &lt;xsl:when test="$paper.type = 'B10'"&gt;31mm&lt;/xsl:when&gt;
-    &lt;xsl:when test="$paper.type = 'C0'"&gt;917mm&lt;/xsl:when&gt;
-    &lt;xsl:when test="$paper.type = 'C1'"&gt;648mm&lt;/xsl:when&gt;
-    &lt;xsl:when test="$paper.type = 'C2'"&gt;458mm&lt;/xsl:when&gt;
-    &lt;xsl:when test="$paper.type = 'C3'"&gt;324mm&lt;/xsl:when&gt;
-    &lt;xsl:when test="$paper.type = 'C4'"&gt;229mm&lt;/xsl:when&gt;
-    &lt;xsl:when test="$paper.type = 'C5'"&gt;162mm&lt;/xsl:when&gt;
-    &lt;xsl:when test="$paper.type = 'C6'"&gt;114mm&lt;/xsl:when&gt;
-    &lt;xsl:when test="$paper.type = 'C7'"&gt;81mm&lt;/xsl:when&gt;
-    &lt;xsl:when test="$paper.type = 'C8'"&gt;57mm&lt;/xsl:when&gt;
-    &lt;xsl:when test="$paper.type = 'C9'"&gt;40mm&lt;/xsl:when&gt;
-    &lt;xsl:when test="$paper.type = 'C10'"&gt;28mm&lt;/xsl:when&gt;
-    &lt;xsl:otherwise&gt;8.5in&lt;/xsl:otherwise&gt;
-  &lt;/xsl:choose&gt;
-&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The portrait page width is the length of the short
-edge of the physical page.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="paper.type">
-<refmeta>
-<refentrytitle>paper.type</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">list</refmiscinfo>
-<refmiscinfo class="other" otherclass="list-type">open</refmiscinfo>
-<refmiscinfo class="other" otherclass="list-type">open</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">USletter<alt>8.5x11in</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">USlandscape<alt>11x8.5in</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">USlegal<alt>8.5inx14in</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">USlegallandscape<alt>14inx8.5in</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">4A0<alt>2378x1682mm</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">2A0<alt>1682x1189mm</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">A0<alt>1189x841mm</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">A1<alt>841x594mm</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">A2<alt>594x420mm</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">A3<alt>420x297mm</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">A4<alt>297x210mm</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">A5<alt>210x148mm</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">A6<alt>148x105mm</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">A7<alt>105x74mm</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">A8<alt>74x52mm</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">A9<alt>52x37mm</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">A10<alt>37x26mm</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">B0<alt>1414x1000mm</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">B1<alt>1000x707mm</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">B2<alt>707x500mm</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">B3<alt>500x353mm</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">B4<alt>353x250mm</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">B5<alt>250x176mm</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">B6<alt>176x125mm</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">B7<alt>125x88mm</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">B8<alt>88x62mm</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">B9<alt>62x44mm</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">B10<alt>44x31mm</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">C0<alt>1297x917mm</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">C1<alt>917x648mm</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">C2<alt>648x458mm</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">C3<alt>458x324mm</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">C4<alt>324x229mm</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">C5<alt>229x162mm</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">C6<alt>162x114mm</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">C7<alt>114x81mm</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">C8<alt>81x57mm</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">C9<alt>57x40mm</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">C10<alt>40x28mm</alt></refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>paper.type</refname>
-<refpurpose>Select the paper type</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="paper.type.frag">
-&lt;xsl:param name="paper.type"&gt;USletter&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The paper type is a convenient way to specify the paper size.
-The list of known paper sizes includes USletter and most of the A,
-B, and C sizes. See <parameter>page.width.portrait</parameter>, for example.
-
-
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="double.sided">
-<refmeta>
-<refentrytitle>double.sided</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>double.sided</refname>
-<refpurpose>Is the document to be printed double sided?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="double.sided.frag">
-&lt;xsl:param name="double.sided" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This parameter is useful when printing a document
-on both sides of the paper.</para>
-
-<para>if set to non-zero, documents are formatted using different page-masters
-for odd and even pages.  These can differ by using a slightly wider margin
-on the binding edge of the page, and alternating left-right
-positions of header or footer elements.
-</para>
-
-<para>If set to zero (the default), then only the 'odd' page masters
-are used for both even and odd numbered pages.</para>
-
-<para>See also <parameter>force.blank.pages</parameter>,
-<parameter>page.margin.inner</parameter> and
-<parameter>page.margin.outer</parameter>.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="force.blank.pages">
-<refmeta>
-<refentrytitle>force.blank.pages</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>force.blank.pages</refname>
-<refpurpose>Generate blank page to end on even page number</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="force.blank.pages.frag">
-&lt;xsl:param name="force.blank.pages" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero (the default), then each page sequence will be forced to
-end on an even-numbered page, by inserting a blank page
-if necessary. This will force the next page sequence to start
-on an odd-numbered page, which is a standard convention
-for printed and bound books.</para>
-
-<para>If zero, then such blank pages will not be inserted.
-Chapters will start on the next available page,
-regardless of whether it is an even or odd number.
-This is useful when publishing online where blank
-pages are not needed.
-</para>
-
-<para>This param is independent of the 
-<parameter>double.sided</parameter> parameter, which
-just triggers the use of even and odd page sequence 
-masters that differ in their header and footer placement.
-So you can combine the two params for alternating
-headers/footers and no blank pages.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="body.margin.bottom">
-<refmeta>
-<refentrytitle>body.margin.bottom</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">length</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>body.margin.bottom</refname>
-<refpurpose>The bottom margin of the body text</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="body.margin.bottom.frag">
-&lt;xsl:param name="body.margin.bottom"&gt;0.5in&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The body bottom margin is the distance from the last line of text
-in the page body to the bottom of the region-after.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="body.margin.top">
-<refmeta>
-<refentrytitle>body.margin.top</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">length</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>body.margin.top</refname>
-<refpurpose>To specify the size of the top margin of a page</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="body.margin.top.frag">
-&lt;xsl:param name="body.margin.top"&gt;0.5in&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The body top margin is the distance from the top of the
-region-before to the first line of text in the page body.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="body.margin.inner">
-<refmeta>
-<refentrytitle>body.margin.inner</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">length</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>body.margin.inner</refname>
-<refpurpose>Specify the size of the inner margin of the body region</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="body.margin.inner.frag">
-&lt;xsl:param name="body.margin.inner"&gt;0in&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The inner body margin is the extra inner side 
-(binding side) margin taken from the body
-region in addition to the inner page margin.
-It makes room for a side region for text content whose width is 
-specified by the <parameter>region.inner.extent</parameter>
-parameter.</para>
-
-<para>For double-sided output,
-this side region 
-is <literal>fo:region-start</literal> on a odd-numbered page,
-and <literal>fo:region-end</literal> on an even-numbered page.</para>
-
-<para>For single-sided output,
-this side region
-is <literal>fo:region-start</literal> for all pages.</para>
-
-<para>This correspondence applies to all languages,
-both left-to-right and right-to-left writing modes.</para>
-
-<para>The default value is zero.</para>
-
-<para>See also
-<parameter>region.inner.extent</parameter>,
-<parameter>region.outer.extent</parameter>,
-<parameter>body.margin.outer</parameter>,
-<parameter>side.region.precedence</parameter>.
-</para>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="body.margin.outer">
-<refmeta>
-<refentrytitle>body.margin.outer</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">length</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>body.margin.outer</refname>
-<refpurpose>Specify the size of the outer margin of the body region</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="body.margin.outer.frag">
-&lt;xsl:param name="body.margin.outer"&gt;0in&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The outer body margin is the extra outer side 
-(opposite the binding side) margin taken
-from the body
-region in addition to the outer page margin.
-It makes room for a side region for text content whose width is 
-specified by the <parameter>region.outer.extent</parameter>
-parameter.</para>
-
-<para>For double-sided output,
-this side region 
-is <literal>fo:region-end</literal> on a odd-numbered page,
-and <literal>fo:region-start</literal> on an even-numbered page.</para>
-
-<para>For single-sided output,
-this side region
-is <literal>fo:region-end</literal> for all pages.</para>
-
-<para>This correspondence applies to all languages,
-both left-to-right and right-to-left writing modes.</para>
-
-<para>The default value is zero.</para>
-
-<para>See also
-<parameter>region.inner.extent</parameter>,
-<parameter>region.outer.extent</parameter>,
-<parameter>body.margin.inner</parameter>,
-<parameter>side.region.precedence</parameter>.
-</para>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="body.start.indent">
-<refmeta>
-<refentrytitle>body.start.indent</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">length</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>body.start.indent</refname>
-<refpurpose>The start-indent for the body text</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="body.start.indent.frag">
-&lt;xsl:param name="body.start.indent"&gt;
-  &lt;xsl:choose&gt;
-    &lt;xsl:when test="$fop.extensions != 0"&gt;0pt&lt;/xsl:when&gt;
-    &lt;xsl:when test="$passivetex.extensions != 0"&gt;0pt&lt;/xsl:when&gt;
-    &lt;xsl:otherwise&gt;4pc&lt;/xsl:otherwise&gt;
-  &lt;/xsl:choose&gt;
-&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This parameter provides
-the means of indenting the body text relative to
-section titles.
-For left-to-right text direction, it indents the left side.
-For right-to-left text direction, it indents the right side.
-It is used in place of the 
-<parameter>title.margin.left</parameter> for
-all XSL-FO processors except FOP 0.25.
-It enables support for side floats to appear
-in the indented margin area.
-</para>
-<para>This start-indent property is added to the fo:flow
-for certain page sequences.  Which page-sequences it is 
-applied to is determined by the template named
-<literal>set.flow.properties</literal>.
-By default, that template adds it to the flow
-for page-sequences using the <quote>body</quote>
-master-reference, as well as appendixes and prefaces.
-</para>
-<para>If this parameter is used, section titles should have
-a start-indent value of 0pt if they are to be
-outdented relative to the body text.
-</para>
-
-<para>If you are using FOP, then set this parameter to a zero
-width value and set the <parameter>title.margin.left</parameter>
-parameter to the negative value of the desired indent.
-</para>
-
-<para>See also <parameter>body.end.indent</parameter> and
-<parameter>title.margin.left</parameter>.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="body.end.indent">
-<refmeta>
-<refentrytitle>body.end.indent</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">length</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>body.end.indent</refname>
-<refpurpose>The end-indent for the body text</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="body.end.indent.frag">
-&lt;xsl:param name="body.end.indent"&gt;0pt&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This end-indent property is added to the fo:flow
-for certain page sequences.  Which page-sequences it is 
-applied to is determined by the template named
-<literal>set.flow.properties</literal>.
-By default, that template adds it to the flow
-for page-sequences using the <quote>body</quote>
-master-reference, as well as appendixes and prefaces.
-</para>
-
-<para>See also <parameter>body.start.indent</parameter>.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="alignment">
-<refmeta>
-<refentrytitle>alignment</refentrytitle>
-  <refmiscinfo class="other" otherclass="datatype">list</refmiscinfo>
-  <refmiscinfo class="other" otherclass="list-type">open</refmiscinfo>
-  <refmiscinfo class="other" otherclass="value">left</refmiscinfo>
-  <refmiscinfo class="other" otherclass="value">start</refmiscinfo>
-  <refmiscinfo class="other" otherclass="value">right</refmiscinfo>
-  <refmiscinfo class="other" otherclass="value">end</refmiscinfo>
-  <refmiscinfo class="other" otherclass="value">center</refmiscinfo>
-  <refmiscinfo class="other" otherclass="value">justify</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>alignment</refname>
-<refpurpose>Specify the default text alignment</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="alignment.frag">&lt;xsl:param name="alignment"&gt;justify&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The default text alignment is used for most body text.
-Allowed values are 
-<literal>left</literal>,
-<literal>right</literal>,
-<literal>start</literal>,
-<literal>end</literal>,
-<literal>center</literal>,
-<literal>justify</literal>.
-The default value is <literal>justify</literal>.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="hyphenate">
-<refmeta>
-<refentrytitle>hyphenate</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">list</refmiscinfo>
-<refmiscinfo class="other" otherclass="list-type">closed</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">true</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">false</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>hyphenate</refname>
-<refpurpose>Specify hyphenation behavior</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="hyphenate.frag">&lt;xsl:param name="hyphenate"&gt;true&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If true, words may be hyphenated. Otherwise, they may not.</para>
-<para>See also <parameter>ulink.hyphenate.chars</parameter> </para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="line-height">
-<refmeta>
-<refentrytitle>line-height</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>line-height</refname>
-<refpurpose>Specify the line-height property</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="line-height.frag">
-&lt;xsl:param name="line-height"&gt;normal&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Sets the line-height property.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="column.count.back">
-<refmeta>
-<refentrytitle>column.count.back</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">integer</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>column.count.back</refname>
-<refpurpose>Number of columns on back matter pages</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="column.count.back.frag">
-&lt;xsl:param name="column.count.back" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Number of columns on back matter (appendix, glossary, etc.) pages.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="column.count.body">
-<refmeta>
-<refentrytitle>column.count.body</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">integer</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>column.count.body</refname>
-<refpurpose>Number of columns on body pages</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="column.count.body.frag">
-&lt;xsl:param name="column.count.body" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Number of columns on body pages.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="column.count.front">
-<refmeta>
-<refentrytitle>column.count.front</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">integer</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>column.count.front</refname>
-<refpurpose>Number of columns on front matter pages</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="column.count.front.frag">
-&lt;xsl:param name="column.count.front" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Number of columns on front matter (dedication, preface, etc.) pages.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="column.count.index">
-<refmeta>
-<refentrytitle>column.count.index</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">integer</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>column.count.index</refname>
-<refpurpose>Number of columns on index pages</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="column.count.index.frag">
-&lt;xsl:param name="column.count.index"&gt;2&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Number of columns on index pages.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="column.count.lot">
-<refmeta>
-<refentrytitle>column.count.lot</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">integer</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>column.count.lot</refname>
-<refpurpose>Number of columns on a 'List-of-Titles' page</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="column.count.lot.frag">
-&lt;xsl:param name="column.count.lot" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Number of columns on a page sequence containing the Table of Contents,
-List of Figures, etc.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="column.count.titlepage">
-<refmeta>
-<refentrytitle>column.count.titlepage</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">integer</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>column.count.titlepage</refname>
-<refpurpose>Number of columns on a title page</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="column.count.titlepage.frag">
-&lt;xsl:param name="column.count.titlepage" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Number of columns on a title page</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="column.gap.back">
-<refmeta>
-<refentrytitle>column.gap.back</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">length</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>column.gap.back</refname>
-<refpurpose>Gap between columns in back matter</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="column.gap.back.frag">
-&lt;xsl:param name="column.gap.back"&gt;12pt&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Specifies the gap between columns in back matter (if
-<parameter>column.count.back</parameter> is greater than one).</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="column.gap.body">
-<refmeta>
-<refentrytitle>column.gap.body</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">length</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>column.gap.body</refname>
-<refpurpose>Gap between columns in the body</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="column.gap.body.frag">
-&lt;xsl:param name="column.gap.body"&gt;12pt&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Specifies the gap between columns in body matter (if
-<parameter>column.count.body</parameter> is greater than one).</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="column.gap.front">
-<refmeta>
-<refentrytitle>column.gap.front</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">length</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>column.gap.front</refname>
-<refpurpose>Gap between columns in the front matter</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="column.gap.front.frag">
-&lt;xsl:param name="column.gap.front"&gt;12pt&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Specifies the gap between columns in front matter (if
-<parameter>column.count.front</parameter> is greater than one).</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="column.gap.index">
-<refmeta>
-<refentrytitle>column.gap.index</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">length</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>column.gap.index</refname>
-<refpurpose>Gap between columns in the index</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="column.gap.index.frag">
-&lt;xsl:param name="column.gap.index"&gt;12pt&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Specifies the gap between columns in indexes (if
-<parameter>column.count.index</parameter> is greater than one).</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="column.gap.lot">
-<refmeta>
-<refentrytitle>column.gap.lot</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">length</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>column.gap.lot</refname>
-<refpurpose>Gap between columns on a 'List-of-Titles' page</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="column.gap.lot.frag">
-&lt;xsl:param name="column.gap.lot"&gt;12pt&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Specifies the gap between columns on 'List-of-Titles' pages (if
-<parameter>column.count.lot</parameter> is greater than one).</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="column.gap.titlepage">
-<refmeta>
-<refentrytitle>column.gap.titlepage</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">length</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>column.gap.titlepage</refname>
-<refpurpose>Gap between columns on title pages</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="column.gap.titlepage.frag">
-&lt;xsl:param name="column.gap.titlepage"&gt;12pt&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Specifies the gap between columns on title pages (if
-<parameter>column.count.titlepage</parameter> is greater than one).</para>
-
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="region.after.extent">
-<refmeta>
-<refentrytitle>region.after.extent</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">length</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>region.after.extent</refname>
-<refpurpose>Specifies the height of the footer.</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="region.after.extent.frag">
-&lt;xsl:param name="region.after.extent"&gt;0.4in&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The region after extent is the height of the area where footers
-are printed.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="region.before.extent">
-<refmeta>
-<refentrytitle>region.before.extent</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">length</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>region.before.extent</refname>
-<refpurpose>Specifies the height of the header</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="region.before.extent.frag">
-&lt;xsl:param name="region.before.extent"&gt;0.4in&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The region before extent is the height of the area where headers
-are printed.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="region.inner.extent">
-<refmeta>
-<refentrytitle>region.inner.extent</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">length</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>region.inner.extent</refname>
-<refpurpose>Specifies the width of the inner side region</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="region.inner.extent.frag">
-&lt;xsl:param name="region.inner.extent"&gt;0in&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The region inner extent is the width of the optional
-text area next to the inner side (binding side) of the
-body region.  </para>
-
-<para>For double-sided output, this side region 
-is <literal>fo:region-start</literal> on a odd-numbered page,
-and <literal>fo:region-end</literal> on an even-numbered page.</para>
-
-<para>For single-sided output, this side region
-is <literal>fo:region-start</literal> for all pages.</para>
-
-<para>This correspondence applies to all languages,
-both left-to-right and right-to-left writing modes.</para>
-
-<para>The default value of this parameter is zero.  If you enlarge this extent,
-be sure to also enlarge the <parameter>body.margin.inner</parameter>
-parameter to make room for its content, otherwise any text in
-the side region may overlap with the body text.</para>
-
-<para>See also
-<parameter>region.outer.extent</parameter>,
-<parameter>body.margin.inner</parameter>,
-<parameter>body.margin.outer</parameter>,
-<parameter>side.region.precedence</parameter>.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="region.outer.extent">
-<refmeta>
-<refentrytitle>region.outer.extent</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">length</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>region.outer.extent</refname>
-<refpurpose>Specifies the width of the outer side region</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="region.outer.extent.frag">
-&lt;xsl:param name="region.outer.extent"&gt;0in&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The region outer extent is the width of the optional
-text area next to the outer side (opposite the binding side) of the
-body region.  </para>
-
-<para>For double-sided output, this side region 
-is <literal>fo:region-end</literal> on a odd-numbered page,
-and <literal>fo:region-start</literal> on an even-numbered page.</para>
-
-<para>For single-sided output, this side region
-is <literal>fo:region-end</literal> for all pages.</para>
-
-<para>This correspondence applies to all languages,
-both left-to-right and right-to-left writing modes.</para>
-
-<para>The default value of this parameter is zero.  If you enlarge this extent,
-be sure to also enlarge the <parameter>body.margin.outer</parameter>
-parameter to make room for its content, otherwise any text in
-the side region may overlap with the body text.</para>
-
-<para>See also
-<parameter>region.inner.extent</parameter>,
-<parameter>body.margin.inner</parameter>,
-<parameter>body.margin.outer</parameter>,
-<parameter>side.region.precedence</parameter>.
-</para>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="default.units">
-<refmeta>
-<refentrytitle>default.units</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">list</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">cm</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">mm</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">in</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">pt</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">pc</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">px</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">em</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>default.units</refname>
-<refpurpose>Default units for an unqualified dimension</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="default.units.frag">
-&lt;xsl:param name="default.units"&gt;pt&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If an unqualified dimension is encountered (for example, in a
-graphic width), the <parameter>default.units</parameter> will be used for the
-units. Unqualified dimensions are not allowed in XSL Formatting Objects.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="normal.para.spacing">
-<refmeta>
-<refentrytitle>normal.para.spacing</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>normal.para.spacing</refname>
-<refpurpose>What space do you want between normal paragraphs</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="normal.para.spacing.frag">&lt;xsl:attribute-set name="normal.para.spacing"&gt;
-  &lt;xsl:attribute name="space-before.optimum"&gt;1em&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="space-before.minimum"&gt;0.8em&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="space-before.maximum"&gt;1.2em&lt;/xsl:attribute&gt;
-&lt;/xsl:attribute-set&gt;</programlisting>
-</refsynopsisdiv>
-<refsection><info><title>Description</title></info>
-<para>Specify the spacing required between normal paragraphs as well as
-the following block-level elements:
-</para>
-<literallayout>ackno
-acknowledgements
-cmdsynopsis
-glosslist
-sidebar
-simpara
-simplelist
-</literallayout>
-<para>To customize the spacing, you need to reset all three attributes.</para>
-
-<para>To specify properties on just <tag>para</tag> elements without
-affecting these other elements,
-use the
-<link linkend="para.properties">para.properties</link>
-attribute-set. </para>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="para.properties">
-<refmeta>
-<refentrytitle>para.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>para.properties</refname>
-<refpurpose>Properties to apply to para elements</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="para.properties.frag">&lt;xsl:attribute-set name="para.properties" use-attribute-sets="normal.para.spacing"&gt;
-&lt;/xsl:attribute-set&gt;</programlisting>
-</refsynopsisdiv>
-<refsection><info><title>Description</title></info>
-<para>Specify properties to apply to the fo:block of a para element,
-such as <literal>text-indent</literal>.
-Although the default attribute-set is empty, it uses the attribute-set
-named <literal>normal.para.spacing</literal> to add vertical space before
-each para. The <literal>para.properties</literal> attribute-set can override those 
-spacing properties for para only.</para>
-<para>See also
-<link linkend="normal.para.spacing">normal.para.spacing</link>.
-</para>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="body.font.master">
-<refmeta>
-<refentrytitle>body.font.master</refentrytitle>
-  <refmiscinfo class="other" otherclass="datatype">number</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>body.font.master</refname>
-<refpurpose>Specifies the default point size for body text</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="body.font.master.frag">
-&lt;xsl:param name="body.font.master"&gt;10&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The body font size is specified in two parameters
-(<parameter>body.font.master</parameter> and <parameter>body.font.size</parameter>)
-so that math can be performed on the font size by XSLT.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="body.font.size">
-<refmeta>
-<refentrytitle>body.font.size</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">length</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>body.font.size</refname>
-<refpurpose>Specifies the default font size for body text</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="body.font.size.frag">
-&lt;xsl:param name="body.font.size"&gt;
- &lt;xsl:value-of select="$body.font.master"&gt;&lt;/xsl:value-of&gt;&lt;xsl:text&gt;pt&lt;/xsl:text&gt;
-&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The body font size is specified in two parameters
-(<parameter>body.font.master</parameter> and <parameter>body.font.size</parameter>)
-so that math can be performed on the font size by XSLT.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="footnote.font.size">
-<refmeta>
-<refentrytitle>footnote.font.size</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">length</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>footnote.font.size</refname>
-<refpurpose>The font size for footnotes</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="footnote.font.size.frag">&lt;xsl:param name="footnote.font.size"&gt;
- &lt;xsl:value-of select="$body.font.master * 0.8"&gt;&lt;/xsl:value-of&gt;&lt;xsl:text&gt;pt&lt;/xsl:text&gt;
-&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The footnote font size is used for...footnotes!
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="title.margin.left">
-<refmeta>
-<refentrytitle>title.margin.left</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">length</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>title.margin.left</refname>
-<refpurpose>Adjust the left margin for titles</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="title.margin.left.frag">
-&lt;xsl:param name="title.margin.left"&gt;
-  &lt;xsl:choose&gt;
-    &lt;xsl:when test="$fop.extensions != 0"&gt;-4pc&lt;/xsl:when&gt;
-    &lt;xsl:when test="$passivetex.extensions != 0"&gt;0pt&lt;/xsl:when&gt;
-    &lt;xsl:otherwise&gt;0pt&lt;/xsl:otherwise&gt;
-  &lt;/xsl:choose&gt;
-&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This parameter provides
-the means of adjusting the left margin for titles
-when the XSL-FO processor being used is
-an old version of FOP (0.25 and earlier).
-It is only useful when the <parameter>fop.extensions</parameter>
-is nonzero.</para>
-
-<para>The left margin of the body region
-is calculated to include this space,
-and titles are outdented to the left outside
-the body region by this amount,
-effectively leaving titles at the intended left margin
-and the body text indented.
-Currently this method is only used for old FOP because
-it cannot properly use the <parameter>body.start.indent</parameter>
-parameter.
-</para>
-<para>
-The default value when the <parameter>fop.extensions</parameter>
-parameter is nonzero is -4pc, which means the
-body text is indented 4 picas relative to
-the titles.
-The default value when the <parameter>fop.extensions</parameter>
-parameter equals zero is 0pt, and
-the body indent should instead be specified
-using the <parameter>body.start.indent</parameter>
-parameter.
-</para>
-<para>
-If you set the value to zero, be sure to still include
-a unit indicator such as <literal>0pt</literal>, or
-the FO processor will report errors.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="draft.mode">
-<refmeta>
-<refentrytitle>draft.mode</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">list</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">no</refmiscinfo> 
-<refmiscinfo class="other" otherclass="value">yes</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">maybe</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>draft.mode</refname>
-<refpurpose>Select draft mode</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="draft.mode.frag">
-&lt;xsl:param name="draft.mode"&gt;no&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Selects draft mode. If <parameter>draft.mode</parameter> is
-<quote><literal>yes</literal></quote>, the entire document will be treated
-as a draft. If it is <quote><literal>no</literal></quote>, the entire document
-will be treated as a final copy. If it is <quote><literal>maybe</literal></quote>,
-individual sections will be treated as draft or final independently, depending
-on how their <literal>status</literal> attribute is set.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="draft.watermark.image">
-<refmeta>
-<refentrytitle>draft.watermark.image</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">uri</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>draft.watermark.image</refname>
-<refpurpose>The URI of the image to be used for draft watermarks</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="draft.watermark.image.frag">
-&lt;xsl:param name="draft.watermark.image"&gt;images/draft.png&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The image to be used for draft watermarks.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="headers.on.blank.pages">
-<refmeta>
-<refentrytitle>headers.on.blank.pages</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>headers.on.blank.pages</refname>
-<refpurpose>Put headers on blank pages?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="headers.on.blank.pages.frag">
-&lt;xsl:param name="headers.on.blank.pages" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, headers will be placed on blank pages.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="footers.on.blank.pages">
-<refmeta>
-<refentrytitle>footers.on.blank.pages</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>footers.on.blank.pages</refname>
-<refpurpose>Put footers on blank pages?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="footers.on.blank.pages.frag">
-&lt;xsl:param name="footers.on.blank.pages" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, footers will be placed on blank pages.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="header.rule">
-<refmeta>
-<refentrytitle>header.rule</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>header.rule</refname>
-<refpurpose>Rule under headers?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="header.rule.frag">
-&lt;xsl:param name="header.rule" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, a rule will be drawn below the page headers.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="footer.rule">
-<refmeta>
-<refentrytitle>footer.rule</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>footer.rule</refname>
-<refpurpose>Rule over footers?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="footer.rule.frag">
-&lt;xsl:param name="footer.rule" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, a rule will be drawn above the page footers.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="header.column.widths">
-<refmeta>
-<refentrytitle>header.column.widths</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>header.column.widths</refname>
-<refpurpose>Specify relative widths of header areas</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv><programlisting id="header.column.widths.frag">
-&lt;xsl:param name="header.column.widths"&gt;1 1 1&lt;/xsl:param&gt;
-</programlisting></refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Page headers in print output use a three column table
-to position text at the left, center, and right side of
-the header on the page.
-This parameter lets you specify the relative sizes of the
-three columns.  The default value is
-"1 1 1".</para>
-
-<para>The parameter value must be three numbers, separated
-by white space. The first number represents the relative
-width of the inside header for
-double-sided output.  The second number is the relative
-width of the center header.  The third number is the
-relative width of the outside header for
-double-sided output.
-</para>
-<para>For single-sided output, the first number is the
-relative width of left header for left-to-right
-text direction, or the right header for right-to-left
-text direction.  
-The third number is the
-relative width of right header for left-to-right
-text direction, or the left header for right-to-left
-text direction.</para>
-
-<para>The numbers are used to specify the column widths
-for the table that makes up the header area.
-In the FO output, this looks like:
-</para>
-
-<programlisting>
-&lt;fo:table-column column-number="1" 
-    column-width="proportional-column-width(1)"/&gt;
-</programlisting>
-
-<para>
-The <literal>proportional-column-width()</literal>
-function computes a column width by dividing its
-argument by the total of the arguments for all the columns, and
-then multiplying the result by the width of the whole table
-(assuming all the column specs use the function).
-Its argument can be any positive integer or floating point number.
-Zero is an acceptable value, although some FO processors
-may warn about it, in which case using a very small number might
-be more satisfactory.
-</para>
-
-<para>For example, the value "1 2 1" means the center
-header should have twice the width of the other areas.
-A value of "0 0 1" means the entire header area
-is reserved for the right (or outside) header text.
-Note that to keep the center area centered on
-the page, the left and right values must be
-the same. A specification like "1 2 3" means the
-center area is no longer centered on the page
-since the right area is three times the width of the left area.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="footer.column.widths">
-<refmeta>
-<refentrytitle>footer.column.widths</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>footer.column.widths</refname>
-<refpurpose>Specify relative widths of footer areas</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv><programlisting id="footer.column.widths.frag">
-&lt;xsl:param name="footer.column.widths"&gt;1 1 1&lt;/xsl:param&gt;
-</programlisting></refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Page footers in print output use a three column table
-to position text at the left, center, and right side of
-the footer on the page.
-This parameter lets you specify the relative sizes of the
-three columns.  The default value is
-"1 1 1".</para>
-
-<para>The parameter value must be three numbers, separated
-by white space. The first number represents the relative
-width of the inside footer for
-double-sided output.  The second number is the relative
-width of the center footer.  The third number is the
-relative width of the outside footer for
-double-sided output.
-</para>
-<para>For single-sided output, the first number is the
-relative width of left footer for left-to-right
-text direction, or the right footer for right-to-left
-text direction.  
-The third number is the
-relative width of right footer for left-to-right
-text direction, or the left footer for right-to-left
-text direction.</para>
-
-<para>The numbers are used to specify the column widths
-for the table that makes up the footer area.
-In the FO output, this looks like:
-</para>
-
-<programlisting>
-&lt;fo:table-column column-number="1" 
-    column-width="proportional-column-width(1)"/&gt;
-</programlisting>
-
-<para>
-The <literal>proportional-column-width()</literal>
-function computes a column width by dividing its
-argument by the total of the arguments for all the columns, and
-then multiplying the result by the width of the whole table
-(assuming all the column specs use the function).
-Its argument can be any positive integer or floating point number.
-Zero is an acceptable value, although some FO processors
-may warn about it, in which case using a very small number might
-be more satisfactory.
-</para>
-
-<para>For example, the value "1 2 1" means the center
-footer should have twice the width of the other areas.
-A value of "0 0 1" means the entire footer area
-is reserved for the right (or outside) footer text.
-Note that to keep the center area centered on
-the page, the left and right values must be
-the same. A specification like "1 2 3" means the
-center area is no longer centered on the page
-since the right area is three times the width of the left area.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="header.table.properties">
-<refmeta>
-<refentrytitle>header.table.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>header.table.properties</refname>
-<refpurpose>Apply properties to the header layout table</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="header.table.properties.frag">
-&lt;xsl:attribute-set name="header.table.properties"&gt;
-  &lt;xsl:attribute name="table-layout"&gt;fixed&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="width"&gt;100%&lt;/xsl:attribute&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Properties applied to the table that lays out the page header.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="header.table.height">
-<refmeta>
-<refentrytitle>header.table.height</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">length</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>header.table.height</refname>
-<refpurpose>Specify the minimum height of the table containing the running page headers</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv><programlisting id="header.table.height.frag">
-&lt;xsl:param name="header.table.height"&gt;14pt&lt;/xsl:param&gt;
-</programlisting></refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Page headers in print output use a three column table
-to position text at the left, center, and right side of
-the header on the page.
-This parameter lets you specify the minimum height 
-of the single row in the table.  
-Since this specifies only the minimum height,
-the table should automatically grow to fit taller content.
-The default value is "14pt".</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="footer.table.properties">
-<refmeta>
-<refentrytitle>footer.table.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>footer.table.properties</refname>
-<refpurpose>Apply properties to the footer layout table</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="footer.table.properties.frag">
-&lt;xsl:attribute-set name="footer.table.properties"&gt;
-  &lt;xsl:attribute name="table-layout"&gt;fixed&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="width"&gt;100%&lt;/xsl:attribute&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Properties applied to the table that lays out the page footer.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="footer.table.height">
-<refmeta>
-<refentrytitle>footer.table.height</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">length</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>footer.table.height</refname>
-<refpurpose>Specify the minimum height of the table containing the running page footers</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv><programlisting id="footer.table.height.frag">
-&lt;xsl:param name="footer.table.height"&gt;14pt&lt;/xsl:param&gt;
-</programlisting></refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Page footers in print output use a three column table
-to position text at the left, center, and right side of
-the footer on the page.
-This parameter lets you specify the minimum height 
-of the single row in the table.  
-Since this specifies only the minimum height,
-the table should automatically grow to fit taller content.
-The default value is "14pt".</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="header.content.properties">
-<refmeta>
-<refentrytitle>header.content.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>header.content.properties</refname>
-<refpurpose>Properties of page header content</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="header.content.properties.frag">
-&lt;xsl:attribute-set name="header.content.properties"&gt;
-  &lt;xsl:attribute name="font-family"&gt;
-    &lt;xsl:value-of select="$body.fontset"&gt;&lt;/xsl:value-of&gt;
-  &lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="margin-left"&gt;
-    &lt;xsl:value-of select="$title.margin.left"&gt;&lt;/xsl:value-of&gt;
-  &lt;/xsl:attribute&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Properties of page header content.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="footer.content.properties">
-<refmeta>
-<refentrytitle>footer.content.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>footer.content.properties</refname>
-<refpurpose>Properties of page footer content</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="footer.content.properties.frag">
-&lt;xsl:attribute-set name="footer.content.properties"&gt;
-  &lt;xsl:attribute name="font-family"&gt;
-    &lt;xsl:value-of select="$body.fontset"&gt;&lt;/xsl:value-of&gt;
-  &lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="margin-left"&gt;
-    &lt;xsl:value-of select="$title.margin.left"&gt;&lt;/xsl:value-of&gt;
-  &lt;/xsl:attribute&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Properties of page footer content.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="marker.section.level">
-<refmeta>
-<refentrytitle>marker.section.level</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">integer</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>marker.section.level</refname>
-<refpurpose>Control depth of sections shown in running headers or footers</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="marker.section.level.frag">
-&lt;xsl:param name="marker.section.level"&gt;2&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The <parameter>marker.section.level</parameter> parameter
-controls the depth of section levels that may be displayed
-in running headers and footers.  For example, if the value
-is 2 (the default), then titles from <tag>sect1</tag> and 
-<tag>sect2</tag> or equivalent <tag>section</tag>
-elements are candidates for use in running headers and
-footers.
-</para>
-<para>Each candidate title is marked in the FO output with a
-<tag>&lt;fo:marker marker-class-name="section.head.marker"&gt;</tag>
-element.
-</para>
-<para>In order for such titles to appear in headers
-or footers, the <literal>header.content</literal>
-or <literal>footer.content</literal> template
-must be customized to retrieve the marker using
-an output element such as:
-</para>
-<programlisting>
-&lt;fo:retrieve-marker retrieve-class-name="section.head.marker"
-                       retrieve-position="first-including-carryover"
-                       retrieve-boundary="page-sequence"/&gt;
-</programlisting>
-
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="side.region.precedence"> 
-<refmeta> 
-<refentrytitle>side.region.precedence</refentrytitle> 
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo> 
-</refmeta> 
-<refnamediv> 
-<refname>side.region.precedence</refname> 
-<refpurpose>Determines side region page layout precedence</refpurpose> 
-</refnamediv> 
-<refsynopsisdiv> <programlisting id="side.region.precedence.frag">
-&lt;xsl:param name="side.region.precedence"&gt;false&lt;/xsl:param&gt;
-</programlisting> 
-</refsynopsisdiv> 
-<refsection><info><title>Description</title></info> 
- 
-<para>If optional side regions on a page
-are established using parameters such as
-<parameter>body.margin.inner</parameter>, 
-<parameter>region.inner.extent</parameter>, etc., then this
-parameter determines what happens at the corners where the
-side regions meet the header and footer regions.</para>
-
-<para>If the value of this parameter is <literal>true</literal>,
-then the side regions have precedence and extend higher
-and lower, while the header and footer regions are narrower
-and fit inside the side regions.</para>
-
-<para>If the value of this parameter is <literal>false</literal>
-(the default value), then the header and footer regions 
-have precedence and extend over and below the side regions.
-Any value other than <literal>true</literal> or
-<literal>false</literal> is taken to be <literal>false</literal>.</para>
-
-<para>If you need to set precedence separately for
-individual regions, then you can set four
-parameters that are normally internal to the stylesheet.
-These four parameters are normally set based
-on the value from <parameter>side.region.precedence</parameter>:</para>
-
-<programlisting>region.before.precedence
-region.after.precedence
-region.start.precedence
-region.end.precedence</programlisting>
-
-<para>See also
-<parameter>region.inner.extent</parameter>,
-<parameter>region.outer.extent</parameter>,
-<parameter>body.margin.inner</parameter>,
-<parameter>body.margin.outer</parameter>.
-</para>
-</refsection> </refentry>
-
-<refentry version="5.0" id="region.inner.properties">
-<refmeta>
-<refentrytitle>region.inner.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>region.inner.properties</refname>
-<refpurpose>Properties of running inner side region</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="region.inner.properties.frag">
-&lt;xsl:attribute-set name="region.inner.properties"&gt;
-  &lt;xsl:attribute name="border-width"&gt;0&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="padding"&gt;0&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="reference-orientation"&gt;90&lt;/xsl:attribute&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The FO stylesheet supports optional side regions
-similar to the header and footer regions.
-Any attributes declared in this attribute-set 
-are applied to the region element in the page master
-on the inner side (binding side) of the page.
-This corresponds to <literal>&lt;fo:regin-start&gt;</literal>
-on odd-numbered pages and <literal>&lt;fo:region-end&gt;</literal>
-on even-numbered pages.
-For single-sided output, it always corresponds to
-<literal>&lt;fo:regin-start&gt;</literal>.</para>
-
-<para>You can customize the template named 
-<literal>inner.region.content</literal> to specify
-the content of the inner side region.</para>
-
-<para>See also
-<parameter>inner.region.content.properties</parameter>,
-<parameter>page.margin.inner</parameter>, 
-<parameter>body.margin.inner</parameter>,
-and the corresponding <literal>outer</literal>
-parameters.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="region.outer.properties">
-<refmeta>
-<refentrytitle>region.outer.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>region.outer.properties</refname>
-<refpurpose>Properties of running outer side region</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="region.outer.properties.frag">
-&lt;xsl:attribute-set name="region.outer.properties"&gt;
-  &lt;xsl:attribute name="border-width"&gt;0&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="padding"&gt;0&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="reference-orientation"&gt;90&lt;/xsl:attribute&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The FO stylesheet supports optional side regions
-similar to the header and footer regions.
-Any attributes declared in this attribute-set 
-are applied to the region element in the page master
-on the outer side (opposite the binding side) of the page.
-This corresponds to <literal>&lt;fo:regin-start&gt;</literal>
-on odd-numbered pages and <literal>&lt;fo:region-end&gt;</literal>
-on even-numbered pages.
-For single-sided output, it always corresponds to
-<literal>&lt;fo:regin-start&gt;</literal>.</para>
-
-<para>You can customize the template named 
-<literal>outer.region.content</literal> to specify
-the content of the outer side region.</para>
-
-<para>See also
-<parameter>outer.region.content.properties</parameter>,
-<parameter>page.margin.outer</parameter>, 
-<parameter>body.margin.outer</parameter>,
-and the corresponding <literal>inner</literal>
-parameters.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="inner.region.content.properties">
-<refmeta>
-<refentrytitle>inner.region.content.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>inner.region.content.properties</refname>
-<refpurpose>Properties of running inner side content</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="inner.region.content.properties.frag">
-&lt;xsl:attribute-set name="inner.region.content.properties"&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The FO stylesheet supports optional side regions
-similar to the header and footer regions.
-Any attributes declared in this attribute-set 
-are applied to the fo:block in the side region
-on the inner side (binding side) of the page.
-This corresponds to the <literal>start</literal>
-region on odd-numbered pages and the <literal>end</literal>
-region on even-numbered pages.
-For single-sided output, it always corresponds to
-the <literal>start</literal> region.</para>
-
-<para>You can customize the template named 
-<literal>inner.region.content</literal> to specify
-the content of the inner side region.</para>
-
-<para>See also
-<parameter>region.inner.properties</parameter>,
-<parameter>page.margin.inner</parameter>, 
-<parameter>body.margin.inner</parameter>,
-and the corresponding <literal>outer</literal>
-parameters.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="outer.region.content.properties">
-<refmeta>
-<refentrytitle>outer.region.content.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>outer.region.content.properties</refname>
-<refpurpose>Properties of running outer side content</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="outer.region.content.properties.frag">
-&lt;xsl:attribute-set name="outer.region.content.properties"&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The FO stylesheet supports optional side regions
-similar to the header and footer regions.
-Any attributes declared in this attribute-set 
-are applied to the fo:block in the side region
-on the outer side (opposite the binding side) of the page.
-This corresponds to the <literal>start</literal>
-region on odd-numbered pages and the <literal>end</literal>
-region on even-numbered pages.
-For single-sided output, it always corresponds to
-the <literal>start</literal> region.</para>
-
-<para>You can customize the template named 
-<literal>outer.region.content</literal> to specify
-the content of the outer side region.</para>
-
-<para>See also
-<parameter>region.outer.properties</parameter>,
-<parameter>page.margin.outer</parameter>, 
-<parameter>body.margin.outer</parameter>,
-and the corresponding <literal>inner</literal>
-parameters.</para>
-</refsection>
-</refentry>
-
-</reference><reference id="fonts" xml:base="../fo/param.xml"><title>Font Families</title>
-<refentry version="5.0" id="body.font.family">
-<refmeta>
-<refentrytitle>body.font.family</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">list</refmiscinfo>
-<refmiscinfo class="other" otherclass="list-type">open</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">serif</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">sans-serif</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">monospace</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>body.font.family</refname>
-<refpurpose>The default font family for body text</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="body.font.family.frag">
-&lt;xsl:param name="body.font.family"&gt;serif&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The body font family is the default font used for text in the page body.</para>
-<para>If more than one font is required, enter the font names,
-separated by a comma, e.g.</para>
-<literallayout>
-  &lt;xsl:param name="body.font.family"&gt;Arial, SimSun, serif&lt;/xsl:param&gt;
-
-</literallayout>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="dingbat.font.family">
-<refmeta>
-<refentrytitle>dingbat.font.family</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">list</refmiscinfo>
-<refmiscinfo class="other" otherclass="list-type">open</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">serif</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">sans-serif</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">monospace</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>dingbat.font.family</refname>
-<refpurpose>The font family for copyright, quotes, and other symbols</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="dingbat.font.family.frag">
-&lt;xsl:param name="dingbat.font.family"&gt;serif&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The dingbat font family is used for dingbats. If it is defined
-as the empty string, no font change is effected around dingbats.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="monospace.font.family">
-<refmeta>
-<refentrytitle>monospace.font.family</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>monospace.font.family</refname>
-<refpurpose>The default font family for monospace environments</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="monospace.font.family.frag">
-&lt;xsl:param name="monospace.font.family"&gt;monospace&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The monospace font family is used for verbatim environments
-(program listings, screens, etc.).
-</para>
-<para>If more than one font is required, enter the font names,
-separated by a comma, e.g.</para>
-<literallayout>
-  &lt;xsl:param name="body.font.family"&gt;Arial, SimSun, serif&lt;/xsl:param&gt;
-
-</literallayout>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="sans.font.family">
-<refmeta>
-<refentrytitle>sans.font.family</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>sans.font.family</refname>
-<refpurpose>The default sans-serif font family</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="sans.font.family.frag">
-&lt;xsl:param name="sans.font.family"&gt;sans-serif&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The default sans-serif font family. At the present, this isn't
-actually used by the stylesheets.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="title.font.family">
-<refmeta>
-<refentrytitle>title.font.family</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">list</refmiscinfo>
-<refmiscinfo class="other" otherclass="list-type">open</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">serif</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">sans-serif</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">monospace</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>title.font.family</refname>
-<refpurpose>The default font family for titles</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="title.font.family.frag">
-&lt;xsl:param name="title.font.family"&gt;sans-serif&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The title font family is used for titles (chapter, section, figure,
-etc.)
-</para>
-<para>If more than one font is required, enter the font names,
-separated by a comma, e.g.</para>
-<literallayout>
-  &lt;xsl:param name="body.font.family"&gt;Arial, SimSun, serif&lt;/xsl:param&gt;
-
-</literallayout>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="symbol.font.family">
-<refmeta>
-<refentrytitle>symbol.font.family</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">list</refmiscinfo>
-<refmiscinfo class="other" otherclass="list-type">open</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">serif</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">sans-serif</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">monospace</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>symbol.font.family</refname>
-<refpurpose>The font families to be searched for symbols outside
-    of the body font</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="symbol.font.family.frag">
-&lt;xsl:param name="symbol.font.family"&gt;Symbol,ZapfDingbats&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>A typical body or title font does not contain all
-the character glyphs that DocBook supports.  This parameter
-specifies additional fonts that should be searched for
-special characters not in the normal font.
-These symbol font names are automatically appended
-to the body or title font family name when fonts
-are specified in a 
-<tag class="attribute">font-family</tag>
-property in the FO output.
-</para>
-<para>The symbol font names should be entered as a
-comma-separated list.  The default value is
-<literal>Symbol,ZapfDingbats</literal>.
-</para>
-
-</refsection>
-</refentry>
-
-</reference><reference id="propsets" xml:base="../fo/param.xml"><title>Property Sets</title>
-<refentry version="5.0" id="formal.object.properties">
-<refmeta>
-<refentrytitle>formal.object.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>formal.object.properties</refname>
-<refpurpose>Properties associated with a formal object such as a figure, or other component that has a title</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="formal.object.properties.frag">
-&lt;xsl:attribute-set name="formal.object.properties"&gt;
-  &lt;xsl:attribute name="space-before.minimum"&gt;0.5em&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="space-before.optimum"&gt;1em&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="space-before.maximum"&gt;2em&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="space-after.minimum"&gt;0.5em&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="space-after.optimum"&gt;1em&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="space-after.maximum"&gt;2em&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="keep-together.within-column"&gt;always&lt;/xsl:attribute&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The styling for formal objects in docbook. Specify the spacing
-before and after the object.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="formal.title.properties">
-<refmeta>
-<refentrytitle>formal.title.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>formal.title.properties</refname>
-<refpurpose>Style the title element of formal object such as a figure.</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="formal.title.properties.frag">
-&lt;xsl:attribute-set name="formal.title.properties" use-attribute-sets="normal.para.spacing"&gt;
-  &lt;xsl:attribute name="font-weight"&gt;bold&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="font-size"&gt;
-    &lt;xsl:value-of select="$body.font.master * 1.2"&gt;&lt;/xsl:value-of&gt;
-    &lt;xsl:text&gt;pt&lt;/xsl:text&gt;
-  &lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="hyphenate"&gt;false&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="space-after.minimum"&gt;0.4em&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="space-after.optimum"&gt;0.6em&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="space-after.maximum"&gt;0.8em&lt;/xsl:attribute&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-<refsection><info><title>Description</title></info>
-<para>Specify how the title should be styled. Specify the font size and weight of the title of the formal object.</para>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="informal.object.properties">
-<refmeta>
-<refentrytitle>informal.object.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>informal.object.properties</refname>
-<refpurpose>Properties associated with an informal (untitled) object, such as an informalfigure</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="informal.object.properties.frag">&lt;xsl:attribute-set name="informal.object.properties"&gt;
-  &lt;xsl:attribute name="space-before.minimum"&gt;0.5em&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="space-before.optimum"&gt;1em&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="space-before.maximum"&gt;2em&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="space-after.minimum"&gt;0.5em&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="space-after.optimum"&gt;1em&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="space-after.maximum"&gt;2em&lt;/xsl:attribute&gt;
-&lt;/xsl:attribute-set&gt;</programlisting>
-</refsynopsisdiv>
-<refsection><info><title>Description</title></info>
-<para>The styling for informal objects in docbook. Specify the spacing before and after the object.</para>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="monospace.properties">
-<refmeta>
-<refentrytitle>monospace.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>monospace.properties</refname>
-<refpurpose>Properties of monospaced content</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="monospace.properties.frag">
-&lt;xsl:attribute-set name="monospace.properties"&gt;
-  &lt;xsl:attribute name="font-family"&gt;
-    &lt;xsl:value-of select="$monospace.font.family"&gt;&lt;/xsl:value-of&gt;
-  &lt;/xsl:attribute&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Specifies the font name for monospaced output. This property set
-used to set the font-size as well, but that doesn't work very well
-when different fonts are used (as they are in titles and paragraphs,
-for example).</para>
-
-<para>If you want to set the font-size in a customization layer, it's
-probably going to be more appropriate to set font-size-adjust, if your
-formatter supports it.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="verbatim.properties">
-<refmeta>
-<refentrytitle>verbatim.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>verbatim.properties</refname>
-<refpurpose>Properties associated with verbatim text</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="verbatim.properties.frag">
-&lt;xsl:attribute-set name="verbatim.properties"&gt;
-  &lt;xsl:attribute name="space-before.minimum"&gt;0.8em&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="space-before.optimum"&gt;1em&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="space-before.maximum"&gt;1.2em&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="space-after.minimum"&gt;0.8em&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="space-after.optimum"&gt;1em&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="space-after.maximum"&gt;1.2em&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="hyphenate"&gt;false&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="wrap-option"&gt;no-wrap&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="white-space-collapse"&gt;false&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="white-space-treatment"&gt;preserve&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="linefeed-treatment"&gt;preserve&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="text-align"&gt;start&lt;/xsl:attribute&gt;
-&lt;/xsl:attribute-set&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-<para>This attribute set is used on all verbatim environments.</para>
-</refsection>
-
-</refentry>
-
-<refentry version="5.0" id="monospace.verbatim.properties">
-<refmeta>
-<refentrytitle>monospace.verbatim.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>monospace.verbatim.properties</refname>
-<refpurpose>What font and size do you want for monospaced content?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="monospace.verbatim.properties.frag">
-&lt;xsl:attribute-set name="monospace.verbatim.properties" use-attribute-sets="verbatim.properties monospace.properties"&gt;
-  &lt;xsl:attribute name="text-align"&gt;start&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="wrap-option"&gt;no-wrap&lt;/xsl:attribute&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-<refsection><info><title>Description</title></info>
-<para>Specify the font name and size you want for monospaced output</para>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="sidebar.properties">
-<refmeta>
-<refentrytitle>sidebar.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>sidebar.properties</refname>
-<refpurpose>Attribute set for sidebar properties</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="sidebar.properties.frag">
-&lt;xsl:attribute-set name="sidebar.properties" use-attribute-sets="formal.object.properties"&gt;
-  &lt;xsl:attribute name="border-style"&gt;solid&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="border-width"&gt;1pt&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="border-color"&gt;black&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="background-color"&gt;#DDDDDD&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="padding-start"&gt;12pt&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="padding-end"&gt;12pt&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="padding-top"&gt;6pt&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="padding-bottom"&gt;6pt&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="margin-{$direction.align.start}"&gt;0pt&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="margin-{$direction.align.end}"&gt;0pt&lt;/xsl:attribute&gt;
-&lt;!--
-  &lt;xsl:attribute name="margin-top"&gt;6pt&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="margin-bottom"&gt;6pt&lt;/xsl:attribute&gt;
---&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The styling for sidebars.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="sidebar.title.properties">
-<refmeta>
-<refentrytitle>sidebar.title.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>sidebar.title.properties</refname>
-<refpurpose>Attribute set for sidebar titles</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="sidebar.title.properties.frag">
-&lt;xsl:attribute-set name="sidebar.title.properties"&gt;
-  &lt;xsl:attribute name="font-weight"&gt;bold&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="hyphenate"&gt;false&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="text-align"&gt;start&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="keep-with-next.within-column"&gt;always&lt;/xsl:attribute&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The styling for sidebars titles.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="sidebar.float.type">
-<refmeta>
-<refentrytitle>sidebar.float.type</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">list</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">none</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">before</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">left</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">start</refmiscinfo> 
-<refmiscinfo class="other" otherclass="value">right</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">end</refmiscinfo>     
-<refmiscinfo class="other" otherclass="value">inside</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">outside</refmiscinfo> 
-</refmeta>
-<refnamediv>
-<refname>sidebar.float.type</refname>
-<refpurpose>Select type of float for sidebar elements</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="sidebar.float.type.frag">
-&lt;xsl:param name="sidebar.float.type"&gt;none&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Selects the type of float for sidebar elements.
-</para>
-<itemizedlist>
-<listitem>
-<para>If <parameter>sidebar.float.type</parameter> is
-<quote><literal>none</literal></quote>, then 
-no float is used.
-</para>
-</listitem>
-<listitem>
-<para>If <parameter>sidebar.float.type</parameter> is
-<quote><literal>before</literal></quote>, then 
-the float appears at the top of the page.  On some processors,
-that may be the next page rather than the current page.
-</para>
-</listitem>
-
-<listitem>
-<para>If <parameter>sidebar.float.type</parameter> is
-<quote><literal>left</literal></quote>,
-then a left side float is used.
-</para>
-</listitem>
-
-<listitem>
-<para>If <parameter>sidebar.float.type</parameter> is
-<quote><literal>start</literal></quote>,
-then when the text direction is left-to-right a left side float is used.
-When the text direction is right-to-left, a right side float is used.
-</para>
-</listitem>
-
-<listitem>
-<para>If <parameter>sidebar.float.type</parameter> is
-<quote><literal>right</literal></quote>,
-then a right side float is used.
-</para>
-</listitem>
-
-<listitem>
-<para>If <parameter>sidebar.float.type</parameter> is
-<quote><literal>end</literal></quote>,
-then when the text direction is left-to-right a right side float is used.
-When the text direction is right-to-left, a left side float is used.
-</para>
-</listitem>
-
-<listitem>
-<para>If your XSL-FO processor supports floats positioned on the
-<quote><literal>inside</literal></quote> or
-<quote><literal>outside</literal></quote>
-of double-sided pages, then you have those two 
-options for side floats as well.
-</para>
-</listitem>
-</itemizedlist>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="sidebar.float.width">
-<refmeta>
-<refentrytitle>sidebar.float.width</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">length</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>sidebar.float.width</refname>
-<refpurpose>Set the default width for sidebars</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="sidebar.float.width.frag">
-&lt;xsl:param name="sidebar.float.width"&gt;1in&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Sets the default width for sidebars when used as a side float.
-The width determines the degree to which the sidebar block intrudes into
-the text area.
-</para>
-<para>If <parameter>sidebar.float.type</parameter> is
-<quote><literal>before</literal></quote> or 
-<quote><literal>none</literal></quote>, then 
-this parameter is ignored.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="margin.note.properties">
-<refmeta>
-<refentrytitle>margin.note.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>margin.note.properties</refname>
-<refpurpose>Attribute set for margin.note properties</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="margin.note.properties.frag">
-&lt;xsl:attribute-set name="margin.note.properties"&gt;
-  &lt;xsl:attribute name="font-size"&gt;90%&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="text-align"&gt;start&lt;/xsl:attribute&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The styling for margin notes.
-By default, margin notes are not implemented for any
-element. A stylesheet customization is needed to make
-use of this attribute-set.</para>
-
-<para>You can use a template named <quote>floater</quote>
-to create the customization.
-That template can create side floats by specifying the
-content and characteristics as template parameters.
-</para>
-
-<para>For example:</para>
-<programlisting>&lt;xsl:template match="para[@role='marginnote']"&gt;
-  &lt;xsl:call-template name="floater"&gt;
-    &lt;xsl:with-param name="position"&gt;
-      &lt;xsl:value-of select="$margin.note.float.type"/&gt;
-    &lt;/xsl:with-param&gt;
-    &lt;xsl:with-param name="width"&gt;
-      &lt;xsl:value-of select="$margin.note.width"/&gt;
-    &lt;/xsl:with-param&gt;
-    &lt;xsl:with-param name="content"&gt;
-      &lt;xsl:apply-imports/&gt;
-    &lt;/xsl:with-param&gt;
-  &lt;/xsl:call-template&gt;
-&lt;/xsl:template&gt;</programlisting>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="margin.note.title.properties">
-<refmeta>
-<refentrytitle>margin.note.title.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>margin.note.title.properties</refname>
-<refpurpose>Attribute set for margin note titles</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="margin.note.title.properties.frag">
-&lt;xsl:attribute-set name="margin.note.title.properties"&gt;
-  &lt;xsl:attribute name="font-weight"&gt;bold&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="hyphenate"&gt;false&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="text-align"&gt;start&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="keep-with-next.within-column"&gt;always&lt;/xsl:attribute&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The styling for margin note titles.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="margin.note.float.type">
-<refmeta>
-<refentrytitle>margin.note.float.type</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">list</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">none</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">before</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">left</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">start</refmiscinfo> 
-<refmiscinfo class="other" otherclass="value">right</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">end</refmiscinfo>     
-<refmiscinfo class="other" otherclass="value">inside</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">outside</refmiscinfo> 
-</refmeta>
-<refnamediv>
-<refname>margin.note.float.type</refname>
-<refpurpose>Select type of float for margin note customizations</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="margin.note.float.type.frag">
-&lt;xsl:param name="margin.note.float.type"&gt;none&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Selects the type of float for margin notes.
-DocBook does not define a margin note element, so this
-feature must be implemented as a customization of the stylesheet.
-See <parameter>margin.note.properties</parameter> for
-an example.
-</para>
-<itemizedlist>
-<listitem>
-<para>If <parameter>margin.note.float.type</parameter> is
-<quote><literal>none</literal></quote>, then 
-no float is used.
-</para>
-</listitem>
-<listitem>
-<para>If <parameter>margin.note.float.type</parameter> is
-<quote><literal>before</literal></quote>, then 
-the float appears at the top of the page.  On some processors,
-that may be the next page rather than the current page.
-</para>
-</listitem>
-<listitem>
-<para>If <parameter>margin.note.float.type</parameter> is
-<quote><literal>left</literal></quote> or
-<quote><literal>start</literal></quote>, then 
-a left side float is used.
-</para>
-</listitem>
-<listitem>
-<para>If <parameter>margin.note.float.type</parameter> is
-<quote><literal>right</literal></quote> or
-<quote><literal>end</literal></quote>, then 
-a right side float is used.
-</para>
-</listitem>
-<listitem>
-<para>If your XSL-FO processor supports floats positioned on the
-<quote><literal>inside</literal></quote> or
-<quote><literal>outside</literal></quote>
-of double-sided pages, then you have those two 
-options for side floats as well.
-</para>
-</listitem>
-</itemizedlist>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="margin.note.width">
-<refmeta>
-<refentrytitle>margin.note.width</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">length</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>margin.note.width</refname>
-<refpurpose>Set the default width for margin notes</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="margin.note.width.frag">
-&lt;xsl:param name="margin.note.width"&gt;1in&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Sets the default width for margin notes when used as a side
-float.  The width determines the degree to which the margin note block
-intrudes into the text area.
-</para>
-<para>If <parameter>margin.note.float.type</parameter> is
-<quote><literal>before</literal></quote> or 
-<quote><literal>none</literal></quote>, then 
-this parameter is ignored.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="component.title.properties">
-<refmeta>
-<refentrytitle>component.title.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>component.title.properties</refname>
-<refpurpose>Properties for component titles</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="component.title.properties.frag">
-&lt;xsl:attribute-set name="component.title.properties"&gt;
-  &lt;xsl:attribute name="keep-with-next.within-column"&gt;always&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="space-before.optimum"&gt;&lt;xsl:value-of select="concat($body.font.master, 'pt')"&gt;&lt;/xsl:value-of&gt;&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="space-before.minimum"&gt;&lt;xsl:value-of select="concat($body.font.master, 'pt * 0.8')"&gt;&lt;/xsl:value-of&gt;&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="space-before.maximum"&gt;&lt;xsl:value-of select="concat($body.font.master, 'pt * 1.2')"&gt;&lt;/xsl:value-of&gt;&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="hyphenate"&gt;false&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="text-align"&gt;
-    &lt;xsl:choose&gt;
-      &lt;xsl:when test="((parent::article | parent::articleinfo | parent::info/parent::article) and not(ancestor::book) and not(self::bibliography))         or (parent::slides | parent::slidesinfo)"&gt;center&lt;/xsl:when&gt;
-      &lt;xsl:otherwise&gt;start&lt;/xsl:otherwise&gt;
-    &lt;/xsl:choose&gt;
-  &lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="start-indent"&gt;&lt;xsl:value-of select="$title.margin.left"&gt;&lt;/xsl:value-of&gt;&lt;/xsl:attribute&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The properties common to all component titles.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="component.titlepage.properties">
-<refmeta>
-<refentrytitle>component.titlepage.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>component.titlepage.properties</refname>
-<refpurpose>Properties for component titlepages</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="component.titlepage.properties.frag">
-&lt;xsl:attribute-set name="component.titlepage.properties"&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The properties that are applied to the outer block containing
-all the component title page information. 
-Its main use is to set a <literal>span="all"</literal>
-property on the block that is a direct child of the flow.</para>
-
-<para>This attribute-set also applies to index titlepages. It is empty by default.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="section.title.properties">
-<refmeta>
-<refentrytitle>section.title.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>section.title.properties</refname>
-<refpurpose>Properties for section titles</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="section.title.properties.frag">
-&lt;xsl:attribute-set name="section.title.properties"&gt;
-  &lt;xsl:attribute name="font-family"&gt;
-    &lt;xsl:value-of select="$title.fontset"&gt;&lt;/xsl:value-of&gt;
-  &lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="font-weight"&gt;bold&lt;/xsl:attribute&gt;
-  &lt;!-- font size is calculated dynamically by section.heading template --&gt;
-  &lt;xsl:attribute name="keep-with-next.within-column"&gt;always&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="space-before.minimum"&gt;0.8em&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="space-before.optimum"&gt;1.0em&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="space-before.maximum"&gt;1.2em&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="text-align"&gt;start&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="start-indent"&gt;&lt;xsl:value-of select="$title.margin.left"&gt;&lt;/xsl:value-of&gt;&lt;/xsl:attribute&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The properties common to all section titles.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="section.title.level1.properties">
-<refmeta>
-<refentrytitle>section.title.level1.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>section.title.level1.properties</refname>
-<refpurpose>Properties for level-1 section titles</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="section.title.level1.properties.frag">
-&lt;xsl:attribute-set name="section.title.level1.properties"&gt;
-  &lt;xsl:attribute name="font-size"&gt;
-    &lt;xsl:value-of select="$body.font.master * 2.0736"&gt;&lt;/xsl:value-of&gt;
-    &lt;xsl:text&gt;pt&lt;/xsl:text&gt;
-  &lt;/xsl:attribute&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The properties of level-1 section titles.</para>
-
-</refsection>
-</refentry>
-
-
-<refentry version="5.0" id="section.title.level2.properties">
-<refmeta>
-<refentrytitle>section.title.level2.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>section.title.level2.properties</refname>
-<refpurpose>Properties for level-2 section titles</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="section.title.level2.properties.frag">
-&lt;xsl:attribute-set name="section.title.level2.properties"&gt;
-  &lt;xsl:attribute name="font-size"&gt;
-    &lt;xsl:value-of select="$body.font.master * 1.728"&gt;&lt;/xsl:value-of&gt;
-    &lt;xsl:text&gt;pt&lt;/xsl:text&gt;
-  &lt;/xsl:attribute&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The properties of level-2 section titles.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="section.title.level3.properties">
-<refmeta>
-<refentrytitle>section.title.level3.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>section.title.level3.properties</refname>
-<refpurpose>Properties for level-3 section titles</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="section.title.level3.properties.frag">
-&lt;xsl:attribute-set name="section.title.level3.properties"&gt;
-  &lt;xsl:attribute name="font-size"&gt;
-    &lt;xsl:value-of select="$body.font.master * 1.44"&gt;&lt;/xsl:value-of&gt;
-    &lt;xsl:text&gt;pt&lt;/xsl:text&gt;
-  &lt;/xsl:attribute&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The properties of level-3 section titles.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="section.title.level4.properties">
-<refmeta>
-<refentrytitle>section.title.level4.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>section.title.level4.properties</refname>
-<refpurpose>Properties for level-4 section titles</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="section.title.level4.properties.frag">
-&lt;xsl:attribute-set name="section.title.level4.properties"&gt;
-  &lt;xsl:attribute name="font-size"&gt;
-    &lt;xsl:value-of select="$body.font.master * 1.2"&gt;&lt;/xsl:value-of&gt;
-    &lt;xsl:text&gt;pt&lt;/xsl:text&gt;
-  &lt;/xsl:attribute&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The properties of level-4 section titles.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="section.title.level5.properties">
-<refmeta>
-<refentrytitle>section.title.level5.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>section.title.level5.properties</refname>
-<refpurpose>Properties for level-5 section titles</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="section.title.level5.properties.frag">
-&lt;xsl:attribute-set name="section.title.level5.properties"&gt;
-  &lt;xsl:attribute name="font-size"&gt;
-    &lt;xsl:value-of select="$body.font.master"&gt;&lt;/xsl:value-of&gt;
-    &lt;xsl:text&gt;pt&lt;/xsl:text&gt;
-  &lt;/xsl:attribute&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The properties of level-5 section titles.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="section.title.level6.properties">
-<refmeta>
-<refentrytitle>section.title.level6.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>section.title.level6.properties</refname>
-<refpurpose>Properties for level-6 section titles</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="section.title.level6.properties.frag">
-&lt;xsl:attribute-set name="section.title.level6.properties"&gt;
-  &lt;xsl:attribute name="font-size"&gt;
-    &lt;xsl:value-of select="$body.font.master"&gt;&lt;/xsl:value-of&gt;
-    &lt;xsl:text&gt;pt&lt;/xsl:text&gt;
-  &lt;/xsl:attribute&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The properties of level-6 section titles. This property set is actually
-used for all titles below level 5.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="section.properties">
-<refmeta>
-<refentrytitle>section.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>section.properties</refname>
-<refpurpose>Properties for all section levels</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="section.properties.frag">
-&lt;xsl:attribute-set name="section.properties"&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The properties that apply to the containing
-block of all section levels, and therefore apply to
-the whole section.  
-This attribute set is inherited by the
-more specific attribute sets such as
-<tag>section.level1.properties</tag>.
-The default is empty.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="section.level1.properties">
-<refmeta>
-<refentrytitle>section.level1.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>section.level1.properties</refname>
-<refpurpose>Properties for level-1 sections</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="section.level1.properties.frag">
-&lt;xsl:attribute-set name="section.level1.properties" use-attribute-sets="section.properties"&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The properties that apply to the containing
-block of a level-1 section, and therefore apply to
-the whole section.  This includes <tag>sect1</tag>
-elements and <tag>section</tag> elements at level 1.
-</para>
-
-<para>For example, you could start each level-1 section on
-a new page by using:</para>
-<programlisting>&lt;xsl:attribute-set name="section.level1.properties"&gt;
-  &lt;xsl:attribute name="break-before"&gt;page&lt;/xsl:attribute&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-
-<para>This attribute set inherits attributes from the
-general <tag>section.properties</tag> attribute set.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="section.level2.properties">
-<refmeta>
-<refentrytitle>section.level2.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>section.level2.properties</refname>
-<refpurpose>Properties for level-2 sections</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="section.level2.properties.frag">
-&lt;xsl:attribute-set name="section.level2.properties" use-attribute-sets="section.properties"&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The properties that apply to the containing
-block of a level-2 section, and therefore apply to
-the whole section.  This includes <tag>sect2</tag>
-elements and <tag>section</tag> elements at level 2.
-</para>
-
-<para>For example, you could start each level-2 section on
-a new page by using:</para>
-<programlisting>&lt;xsl:attribute-set name="section.level2.properties"&gt;
-  &lt;xsl:attribute name="break-before"&gt;page&lt;/xsl:attribute&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-
-<para>This attribute set inherits attributes from the
-general <tag>section.properties</tag> attribute set.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="section.level3.properties">
-<refmeta>
-<refentrytitle>section.level3.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>section.level3.properties</refname>
-<refpurpose>Properties for level-3 sections</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="section.level3.properties.frag">
-&lt;xsl:attribute-set name="section.level3.properties" use-attribute-sets="section.properties"&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The properties that apply to the containing
-block of a level-3 section, and therefore apply to
-the whole section.  This includes <tag>sect3</tag>
-elements and <tag>section</tag> elements at level 3.
-</para>
-
-<para>For example, you could start each level-3 section on
-a new page by using:</para>
-<programlisting>&lt;xsl:attribute-set name="section.level3.properties"&gt;
-  &lt;xsl:attribute name="break-before"&gt;page&lt;/xsl:attribute&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-
-<para>This attribute set inherits attributes from the
-general <tag>section.properties</tag> attribute set.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="section.level4.properties">
-<refmeta>
-<refentrytitle>section.level4.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>section.level4.properties</refname>
-<refpurpose>Properties for level-4 sections</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="section.level4.properties.frag">
-&lt;xsl:attribute-set name="section.level4.properties" use-attribute-sets="section.properties"&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The properties that apply to the containing
-block of a level-4 section, and therefore apply to
-the whole section.  This includes <tag>sect4</tag>
-elements and <tag>section</tag> elements at level 4.
-</para>
-
-<para>For example, you could start each level-4 section on
-a new page by using:</para>
-<programlisting>&lt;xsl:attribute-set name="section.level4.properties"&gt;
-  &lt;xsl:attribute name="break-before"&gt;page&lt;/xsl:attribute&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-
-<para>This attribute set inherits attributes from the
-general <tag>section.properties</tag> attribute set.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="section.level5.properties">
-<refmeta>
-<refentrytitle>section.level5.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>section.level5.properties</refname>
-<refpurpose>Properties for level-5 sections</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="section.level5.properties.frag">
-&lt;xsl:attribute-set name="section.level5.properties" use-attribute-sets="section.properties"&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The properties that apply to the containing
-block of a level-5 section, and therefore apply to
-the whole section.  This includes <tag>sect5</tag>
-elements and <tag>section</tag> elements at level 5.
-</para>
-
-<para>For example, you could start each level-5 section on
-a new page by using:</para>
-<programlisting>&lt;xsl:attribute-set name="section.level5.properties"&gt;
-  &lt;xsl:attribute name="break-before"&gt;page&lt;/xsl:attribute&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-
-<para>This attribute set inherits attributes from the
-general <tag>section.properties</tag> attribute set.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="section.level6.properties">
-<refmeta>
-<refentrytitle>section.level6.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>section.level6.properties</refname>
-<refpurpose>Properties for level-6 sections</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="section.level6.properties.frag">
-&lt;xsl:attribute-set name="section.level6.properties" use-attribute-sets="section.properties"&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The properties that apply to the containing
-block of a level 6 or lower section, and therefore apply to
-the whole section.  This includes 
-<tag>section</tag> elements at level 6 and lower.
-</para>
-
-<para>For example, you could start each level-6 section on
-a new page by using:</para>
-<programlisting>&lt;xsl:attribute-set name="section.level6.properties"&gt;
-  &lt;xsl:attribute name="break-before"&gt;page&lt;/xsl:attribute&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-
-<para>This attribute set inherits attributes from the
-general <tag>section.properties</tag> attribute set.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="figure.properties">
-<refmeta>
-<refentrytitle>figure.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>  
-<refnamediv>
-<refname>figure.properties</refname>
-<refpurpose>Properties associated with a figure</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="figure.properties.frag">
-&lt;xsl:attribute-set name="figure.properties" use-attribute-sets="formal.object.properties"&gt;&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The styling for figures.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="example.properties">
-<refmeta>
-<refentrytitle>example.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>example.properties</refname>
-<refpurpose>Properties associated with a example</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="example.properties.frag">
-&lt;xsl:attribute-set name="example.properties" use-attribute-sets="formal.object.properties"&gt;
-    &lt;xsl:attribute name="keep-together.within-column"&gt;auto&lt;/xsl:attribute&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The styling for examples.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="equation.properties">
-<refmeta>
-<refentrytitle>equation.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>equation.properties</refname>
-<refpurpose>Properties associated with a equation</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="equation.properties.frag">
-&lt;xsl:attribute-set name="equation.properties" use-attribute-sets="formal.object.properties"&gt;&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The styling for equations.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="equation.number.properties">
-<refmeta>
-<refentrytitle>equation.number.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>equation.number.properties</refname>
-<refpurpose>Properties that apply to the <tag>fo:table-cell</tag> containing the number
-of an <tag>equation</tag> that does not have a title.</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="equation.number.properties.frag">&lt;xsl:attribute-set name="equation.number.properties"&gt;
-  &lt;xsl:attribute name="text-align"&gt;end&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="display-align"&gt;center&lt;/xsl:attribute&gt;
-&lt;/xsl:attribute-set&gt;</programlisting>
-</refsynopsisdiv>
-<refsection><info><title>Description</title></info>
-<para>Properties that apply to the fo:table-cell containing the number
-of an equation when it has no title. The number in an equation with a
-title is formatted along with the title, and this attribute-set does not apply.</para>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="table.properties">
-<refmeta>
-<refentrytitle>table.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>table.properties</refname>
-<refpurpose>Properties associated with the block surrounding a table</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="table.properties.frag">
-&lt;xsl:attribute-set name="table.properties" use-attribute-sets="formal.object.properties"&gt;
-  &lt;xsl:attribute name="keep-together.within-column"&gt;auto&lt;/xsl:attribute&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Block styling properties for tables. This parameter should really
-have been called <literal>table.block.properties</literal> or something
-like that, but we&#8217;re leaving it to avoid backwards-compatibility
-problems.</para>
-
-<para>See also <parameter>table.table.properties</parameter>.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="task.properties">
-<refmeta>
-<refentrytitle>task.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>task.properties</refname>
-<refpurpose>Properties associated with a task</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="task.properties.frag">
-&lt;xsl:attribute-set name="task.properties" use-attribute-sets="formal.object.properties"&gt;
-    &lt;xsl:attribute name="keep-together.within-column"&gt;auto&lt;/xsl:attribute&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Properties to style the entire block containing a task element.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="informalfigure.properties">
-<refmeta>
-<refentrytitle>informalfigure.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>informalfigure.properties</refname>
-<refpurpose>Properties associated with an informalfigure</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="informalfigure.properties.frag">
-&lt;xsl:attribute-set name="informalfigure.properties" use-attribute-sets="informal.object.properties"&gt;&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The styling for informalfigures.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="informalexample.properties">
-<refmeta>
-<refentrytitle>informalexample.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>informalexample.properties</refname>
-<refpurpose>Properties associated with an informalexample</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="informalexample.properties.frag">
-&lt;xsl:attribute-set name="informalexample.properties" use-attribute-sets="informal.object.properties"&gt;&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The styling for informalexamples.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="informalequation.properties">
-<refmeta>
-<refentrytitle>informalequation.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>informalequation.properties</refname>
-<refpurpose>Properties associated with an informalequation</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="informalequation.properties.frag">
-&lt;xsl:attribute-set name="informalequation.properties" use-attribute-sets="informal.object.properties"&gt;&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The styling for informalequations.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="informaltable.properties">
-<refmeta>
-<refentrytitle>informaltable.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>informaltable.properties</refname>
-<refpurpose>Properties associated with the block surrounding an informaltable</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="informaltable.properties.frag">
-&lt;xsl:attribute-set name="informaltable.properties" use-attribute-sets="informal.object.properties"&gt;&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Block styling properties for informaltables. This parameter should really
-have been called <literal>informaltable.block.properties</literal> or something
-like that, but we&#8217;re leaving it to avoid backwards-compatibility
-problems.</para>
-
-<para>See also <parameter>table.table.properties</parameter>.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="procedure.properties">
-<refmeta>
-<refentrytitle>procedure.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>procedure.properties</refname>
-<refpurpose>Properties associated with a procedure</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="procedure.properties.frag">
-&lt;xsl:attribute-set name="procedure.properties" use-attribute-sets="formal.object.properties"&gt;
-  &lt;xsl:attribute name="keep-together.within-column"&gt;auto&lt;/xsl:attribute&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The styling for procedures.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="root.properties">
-<refmeta>
-<refentrytitle>root.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>root.properties</refname>
-<refpurpose>The properties of the fo:root element</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="root.properties.frag">
-&lt;xsl:attribute-set name="root.properties"&gt;
-  &lt;xsl:attribute name="font-family"&gt;
-    &lt;xsl:value-of select="$body.fontset"&gt;&lt;/xsl:value-of&gt;
-  &lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="font-size"&gt;
-    &lt;xsl:value-of select="$body.font.size"&gt;&lt;/xsl:value-of&gt;
-  &lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="text-align"&gt;
-    &lt;xsl:value-of select="$alignment"&gt;&lt;/xsl:value-of&gt;
-  &lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="line-height"&gt;
-    &lt;xsl:value-of select="$line-height"&gt;&lt;/xsl:value-of&gt;
-  &lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="font-selection-strategy"&gt;character-by-character&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="line-height-shift-adjustment"&gt;disregard-shifts&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="writing-mode"&gt;
-    &lt;xsl:value-of select="$direction.mode"&gt;&lt;/xsl:value-of&gt;
-  &lt;/xsl:attribute&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This property set is used on the <tag>fo:root</tag> element of
-an FO file. It defines a set of default, global parameters.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="qanda.title.properties">
-<refmeta>
-<refentrytitle>qanda.title.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>qanda.title.properties</refname>
-<refpurpose>Properties for qanda set titles</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="qanda.title.properties.frag">
-&lt;xsl:attribute-set name="qanda.title.properties"&gt;
-  &lt;xsl:attribute name="font-family"&gt;
-    &lt;xsl:value-of select="$title.fontset"&gt;&lt;/xsl:value-of&gt;
-  &lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="font-weight"&gt;bold&lt;/xsl:attribute&gt;
-  &lt;!-- font size is calculated dynamically by qanda.heading template --&gt;
-  &lt;xsl:attribute name="keep-with-next.within-column"&gt;always&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="space-before.minimum"&gt;0.8em&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="space-before.optimum"&gt;1.0em&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="space-before.maximum"&gt;1.2em&lt;/xsl:attribute&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The properties common to all qanda set titles.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="qanda.title.level1.properties">
-<refmeta>
-<refentrytitle>qanda.title.level1.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>qanda.title.level1.properties</refname>
-<refpurpose>Properties for level-1 qanda set titles</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="qanda.title.level1.properties.frag">
-&lt;xsl:attribute-set name="qanda.title.level1.properties"&gt;
-  &lt;xsl:attribute name="font-size"&gt;
-    &lt;xsl:value-of select="$body.font.master * 2.0736"&gt;&lt;/xsl:value-of&gt;
-    &lt;xsl:text&gt;pt&lt;/xsl:text&gt;
-  &lt;/xsl:attribute&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The properties of level-1 qanda set titles.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="qanda.title.level2.properties">
-<refmeta>
-<refentrytitle>qanda.title.level2.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>qanda.title.level2.properties</refname>
-<refpurpose>Properties for level-2 qanda set titles</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="qanda.title.level2.properties.frag">
-&lt;xsl:attribute-set name="qanda.title.level2.properties"&gt;
-  &lt;xsl:attribute name="font-size"&gt;
-    &lt;xsl:value-of select="$body.font.master * 1.728"&gt;&lt;/xsl:value-of&gt;
-    &lt;xsl:text&gt;pt&lt;/xsl:text&gt;
-  &lt;/xsl:attribute&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The properties of level-2 qanda set titles.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="qanda.title.level3.properties">
-<refmeta>
-<refentrytitle>qanda.title.level3.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>qanda.title.level3.properties</refname>
-<refpurpose>Properties for level-3 qanda set titles</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="qanda.title.level3.properties.frag">
-&lt;xsl:attribute-set name="qanda.title.level3.properties"&gt;
-  &lt;xsl:attribute name="font-size"&gt;
-    &lt;xsl:value-of select="$body.font.master * 1.44"&gt;&lt;/xsl:value-of&gt;
-    &lt;xsl:text&gt;pt&lt;/xsl:text&gt;
-  &lt;/xsl:attribute&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The properties of level-3 qanda set titles.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="qanda.title.level4.properties">
-<refmeta>
-<refentrytitle>qanda.title.level4.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>qanda.title.level4.properties</refname>
-<refpurpose>Properties for level-4 qanda set titles</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="qanda.title.level4.properties.frag">
-&lt;xsl:attribute-set name="qanda.title.level4.properties"&gt;
-  &lt;xsl:attribute name="font-size"&gt;
-    &lt;xsl:value-of select="$body.font.master * 1.2"&gt;&lt;/xsl:value-of&gt;
-    &lt;xsl:text&gt;pt&lt;/xsl:text&gt;
-  &lt;/xsl:attribute&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The properties of level-4 qanda set titles.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="qanda.title.level5.properties">
-<refmeta>
-<refentrytitle>qanda.title.level5.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>qanda.title.level5.properties</refname>
-<refpurpose>Properties for level-5 qanda set titles</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="qanda.title.level5.properties.frag">
-&lt;xsl:attribute-set name="qanda.title.level5.properties"&gt;
-  &lt;xsl:attribute name="font-size"&gt;
-    &lt;xsl:value-of select="$body.font.master"&gt;&lt;/xsl:value-of&gt;
-    &lt;xsl:text&gt;pt&lt;/xsl:text&gt;
-  &lt;/xsl:attribute&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The properties of level-5 qanda set titles.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="qanda.title.level6.properties">
-<refmeta>
-<refentrytitle>qanda.title.level6.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>qanda.title.level6.properties</refname>
-<refpurpose>Properties for level-6 qanda set titles</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="qanda.title.level6.properties.frag">
-&lt;xsl:attribute-set name="qanda.title.level6.properties"&gt;
-  &lt;xsl:attribute name="font-size"&gt;
-    &lt;xsl:value-of select="$body.font.master"&gt;&lt;/xsl:value-of&gt;
-    &lt;xsl:text&gt;pt&lt;/xsl:text&gt;
-  &lt;/xsl:attribute&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The properties of level-6 qanda set titles.
-This property set is actually
-used for all titles below level 5.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="article.appendix.title.properties">
-<refmeta>
-<refentrytitle>article.appendix.title.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>article.appendix.title.properties</refname>
-<refpurpose>Properties for appendix titles that appear in an article</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="article.appendix.title.properties.frag">
-&lt;xsl:attribute-set name="article.appendix.title.properties" use-attribute-sets="section.title.properties                          section.title.level1.properties"&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The properties for the title of an appendix that
-appears inside an article.  The default is to use
-the properties of sect1 titles.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="abstract.properties">
-<refmeta>
-<refentrytitle>abstract.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>abstract.properties</refname>
-<refpurpose>Properties associated with the block surrounding an abstract</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="abstract.properties.frag">
-&lt;xsl:attribute-set name="abstract.properties"&gt;
-  &lt;xsl:attribute name="start-indent"&gt;0.0in&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="end-indent"&gt;0.0in&lt;/xsl:attribute&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Block styling properties for abstract.</para>
-
-<para>See also <parameter>abstract.title.properties</parameter>.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="abstract.title.properties">
-<refmeta>
-<refentrytitle>abstract.title.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>abstract.title.properties</refname>
-<refpurpose>Properties for abstract titles</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="abstract.title.properties.frag">
-&lt;xsl:attribute-set name="abstract.title.properties"&gt;
-  &lt;xsl:attribute name="font-family"&gt;&lt;xsl:value-of select="$title.fontset"&gt;&lt;/xsl:value-of&gt;&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="font-weight"&gt;bold&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="keep-with-next.within-column"&gt;always&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="keep-with-next.within-column"&gt;always&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="space-before.optimum"&gt;&lt;xsl:value-of select="concat($body.font.master, 'pt')"&gt;&lt;/xsl:value-of&gt;&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="space-before.minimum"&gt;&lt;xsl:value-of select="concat($body.font.master, 'pt * 0.8')"&gt;&lt;/xsl:value-of&gt;&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="space-before.maximum"&gt;&lt;xsl:value-of select="concat($body.font.master, 'pt * 1.2')"&gt;&lt;/xsl:value-of&gt;&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="hyphenate"&gt;false&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="text-align"&gt;center&lt;/xsl:attribute&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The properties for abstract titles.</para>
-
-<para>See also <parameter>abstract.properties</parameter>.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="index.page.number.properties">
-<refmeta>
-<refentrytitle>index.page.number.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>index.page.number.properties</refname>
-<refpurpose>Properties associated with index page numbers</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="index.page.number.properties.frag">
-&lt;xsl:attribute-set name="index.page.number.properties"&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Properties associated with page numbers in indexes. 
-Changing color to indicate the page number is a link is
-one possibility.
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="revhistory.table.properties">
-<refmeta>
-<refentrytitle>revhistory.table.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>revhistory.table.properties</refname>
-<refpurpose>The properties of table used for formatting revhistory</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="revhistory.table.properties.frag">
-&lt;xsl:attribute-set name="revhistory.table.properties"&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This property set defines appearance of revhistory table.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="revhistory.table.cell.properties">
-<refmeta>
-<refentrytitle>revhistory.table.cell.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>revhistory.table.cell.properties</refname>
-<refpurpose>The properties of table cells used for formatting revhistory</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="revhistory.table.cell.properties.frag">
-&lt;xsl:attribute-set name="revhistory.table.cell.properties"&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This property set defines appearance of individual cells in revhistory table.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="revhistory.title.properties">
-<refmeta>
-<refentrytitle>revhistory.title.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>revhistory.title.properties</refname>
-<refpurpose>The properties of revhistory title</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="revhistory.title.properties.frag">
-&lt;xsl:attribute-set name="revhistory.title.properties"&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This property set defines appearance of revhistory title.</para>
-
-</refsection>
-</refentry>
-
-</reference><reference id="profiling" xml:base="../fo/param.xml"><title>Profiling</title>
-<partintro id="profiling_partintro">
-<para>The following parameters can be used for attribute-based
-profiling of your document. For more information about profiling, see 
-<link role="tcg" xlink:href="Profiling.html">Profiling (conditional text)</link>.</para>
-</partintro>
-<refentry version="5.0" id="profile.arch">
-<refmeta>
-<refentrytitle>profile.arch</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>profile.arch</refname>
-<refpurpose>Target profile for <tag class="attribute">arch</tag>
-attribute</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="profile.arch.frag">
-&lt;xsl:param name="profile.arch"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-
-<refsection><info><title>Description</title></info>
-
-<para>The value of this parameter specifies profiles which should be
-included in the output. You can specify multiple profiles by
-separating them by semicolon. You can change separator character by
-<parameter>profile.separator</parameter>
-parameter.</para>
-
-<para>This parameter has effect only when you are using profiling
-stylesheets (<filename>profile-docbook.xsl</filename>,
-<filename>profile-chunk.xsl</filename>, &#8230;) instead of normal
-ones (<filename>docbook.xsl</filename>,
-<filename>chunk.xsl</filename>, &#8230;).</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="profile.audience">
-<refmeta>
-<refentrytitle>profile.audience</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>profile.audience</refname>
-<refpurpose>Target profile for <tag class="attribute">audience</tag>
-attribute</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="profile.audience.frag">
-&lt;xsl:param name="profile.audience"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Value of this parameter specifies profiles which should be
-included in the output. You can specify multiple profiles by
-separating them by semicolon. You can change separator character by
-<parameter>profile.separator</parameter>
-parameter.</para>
-
-<para>This parameter has effect only when you are using profiling
-stylesheets (<filename>profile-docbook.xsl</filename>,
-<filename>profile-chunk.xsl</filename>, &#8230;) instead of normal
-ones (<filename>docbook.xsl</filename>,
-<filename>chunk.xsl</filename>, &#8230;).</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="profile.condition">
-<refmeta>
-<refentrytitle>profile.condition</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>profile.condition</refname>
-<refpurpose>Target profile for <tag class="attribute">condition</tag>
-attribute</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="profile.condition.frag">
-&lt;xsl:param name="profile.condition"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The value of this parameter specifies profiles which should be
-included in the output. You can specify multiple profiles by
-separating them by semicolon. You can change separator character by
-<parameter>profile.separator</parameter>
-parameter.</para>
-
-<para>This parameter has effect only when you are using profiling
-stylesheets (<filename>profile-docbook.xsl</filename>,
-<filename>profile-chunk.xsl</filename>, &#8230;) instead of normal
-ones (<filename>docbook.xsl</filename>,
-<filename>chunk.xsl</filename>, &#8230;).</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="profile.conformance">
-<refmeta>
-<refentrytitle>profile.conformance</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>profile.conformance</refname>
-<refpurpose>Target profile for <tag class="attribute">conformance</tag>
-attribute</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="profile.conformance.frag">
-&lt;xsl:param name="profile.conformance"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The value of this parameter specifies profiles which should be
-included in the output. You can specify multiple profiles by
-separating them by semicolon. You can change separator character by
-<parameter>profile.separator</parameter>
-parameter.</para>
-
-<para>This parameter has effect only when you are using profiling
-stylesheets (<filename>profile-docbook.xsl</filename>,
-<filename>profile-chunk.xsl</filename>, &#8230;) instead of normal
-ones (<filename>docbook.xsl</filename>,
-<filename>chunk.xsl</filename>, &#8230;).</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="profile.lang">
-<refmeta>
-<refentrytitle>profile.lang</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>profile.lang</refname>
-<refpurpose>Target profile for <tag class="attribute">lang</tag>
-attribute</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="profile.lang.frag">
-&lt;xsl:param name="profile.lang"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The value of this parameter specifies profiles which should be
-included in the output. You can specify multiple profiles by
-separating them by semicolon. You can change separator character by
-<parameter>profile.separator</parameter>
-parameter.</para>
-
-<para>This parameter has effect only when you are using profiling
-stylesheets (<filename>profile-docbook.xsl</filename>,
-<filename>profile-chunk.xsl</filename>, &#8230;) instead of normal
-ones (<filename>docbook.xsl</filename>,
-<filename>chunk.xsl</filename>, &#8230;).</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="profile.os">
-<refmeta>
-<refentrytitle>profile.os</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>profile.os</refname>
-<refpurpose>Target profile for <tag class="attribute">os</tag>
-attribute</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="profile.os.frag">
-&lt;xsl:param name="profile.os"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The value of this parameter specifies profiles which should be
-included in the output. You can specify multiple profiles by
-separating them by semicolon. You can change separator character by
-<parameter>profile.separator</parameter>
-parameter.</para>
-
-<para>This parameter has effect only when you are using profiling
-stylesheets (<filename>profile-docbook.xsl</filename>,
-<filename>profile-chunk.xsl</filename>, &#8230;) instead of normal
-ones (<filename>docbook.xsl</filename>,
-<filename>chunk.xsl</filename>, &#8230;).</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="profile.revision">
-<refmeta>
-<refentrytitle>profile.revision</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>profile.revision</refname>
-<refpurpose>Target profile for <tag class="attribute">revision</tag>
-attribute</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="profile.revision.frag">
-&lt;xsl:param name="profile.revision"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The value of this parameter specifies profiles which should be
-included in the output. You can specify multiple profiles by
-separating them by semicolon. You can change separator character by
-<parameter>profile.separator</parameter>
-parameter.</para>
-
-<para>This parameter has effect only when you are using profiling
-stylesheets (<filename>profile-docbook.xsl</filename>,
-<filename>profile-chunk.xsl</filename>, &#8230;) instead of normal
-ones (<filename>docbook.xsl</filename>,
-<filename>chunk.xsl</filename>, &#8230;).</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="profile.revisionflag">
-<refmeta>
-<refentrytitle>profile.revisionflag</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>profile.revisionflag</refname>
-<refpurpose>Target profile for <tag class="attribute">revisionflag</tag>
-attribute</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="profile.revisionflag.frag">
-&lt;xsl:param name="profile.revisionflag"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The value of this parameter specifies profiles which should be
-included in the output. You can specify multiple profiles by
-separating them by semicolon. You can change separator character by
-<parameter>profile.separator</parameter>
-parameter.</para>
-
-<para>This parameter has effect only when you are using profiling
-stylesheets (<filename>profile-docbook.xsl</filename>,
-<filename>profile-chunk.xsl</filename>, &#8230;) instead of normal
-ones (<filename>docbook.xsl</filename>,
-<filename>chunk.xsl</filename>, &#8230;).</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="profile.role">
-<refmeta>
-<refentrytitle>profile.role</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>profile.role</refname>
-<refpurpose>Target profile for <tag class="attribute">role</tag>
-attribute</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="profile.role.frag">
-&lt;xsl:param name="profile.role"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The value of this parameter specifies profiles which should be
-included in the output. You can specify multiple profiles by
-separating them by semicolon. You can change separator character by
-<parameter>profile.separator</parameter>
-parameter.</para>
-
-<para>This parameter has effect only when you are using profiling
-stylesheets (<filename>profile-docbook.xsl</filename>,
-<filename>profile-chunk.xsl</filename>, &#8230;) instead of normal
-ones (<filename>docbook.xsl</filename>,
-<filename>chunk.xsl</filename>, &#8230;).</para>
-
-<warning>
-<para>Note that <tag class="attribute">role</tag> is often
-used for other purposes than profiling. For example it is commonly
-used to get emphasize in bold font:</para>
-
-<programlisting>&lt;emphasis role="bold"&gt;very important&lt;/emphasis&gt;</programlisting>
-
-<para>If you are using <tag class="attribute">role</tag> for
-these purposes do not forget to add values like <literal>bold</literal> to
-value of this parameter. If you forgot you will get document with
-small pieces missing which are very hard to track.</para>
-
-<para>For this reason it is not recommended to use <tag class="attribute">role</tag> attribute for profiling. You should
-rather use profiling specific attributes like <tag class="attribute">userlevel</tag>, <tag class="attribute">os</tag>, <tag class="attribute">arch</tag>, <tag class="attribute">condition</tag>, etc.</para>
-</warning>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="profile.security">
-<refmeta>
-<refentrytitle>profile.security</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>profile.security</refname>
-<refpurpose>Target profile for <tag class="attribute">security</tag>
-attribute</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="profile.security.frag">
-&lt;xsl:param name="profile.security"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The value of this parameter specifies profiles which should be
-included in the output. You can specify multiple profiles by
-separating them by semicolon. You can change separator character by
-<parameter>profile.separator</parameter>
-parameter.</para>
-
-<para>This parameter has effect only when you are using profiling
-stylesheets (<filename>profile-docbook.xsl</filename>,
-<filename>profile-chunk.xsl</filename>, &#8230;) instead of normal
-ones (<filename>docbook.xsl</filename>,
-<filename>chunk.xsl</filename>, &#8230;).</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="profile.status">
-<refmeta>
-<refentrytitle>profile.status</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>profile.status</refname>
-<refpurpose>Target profile for <tag class="attribute">status</tag>
-attribute</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="profile.status.frag">
-&lt;xsl:param name="profile.status"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The value of this parameter specifies profiles which should be
-included in the output. You can specify multiple profiles by
-separating them by semicolon. You can change separator character by
-<parameter>profile.separator</parameter>
-parameter.</para>
-
-<para>This parameter has effect only when you are using profiling
-stylesheets (<filename>profile-docbook.xsl</filename>,
-<filename>profile-chunk.xsl</filename>, &#8230;) instead of normal
-ones (<filename>docbook.xsl</filename>,
-<filename>chunk.xsl</filename>, &#8230;).</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="profile.userlevel">
-<refmeta>
-<refentrytitle>profile.userlevel</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>profile.userlevel</refname>
-<refpurpose>Target profile for <tag class="attribute">userlevel</tag>
-attribute</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="profile.userlevel.frag">
-&lt;xsl:param name="profile.userlevel"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The value of this parameter specifies profiles which should be
-included in the output. You can specify multiple profiles by
-separating them by semicolon. You can change separator character by
-<parameter>profile.separator</parameter>
-parameter.</para>
-
-<para>This parameter has effect only when you are using profiling
-stylesheets (<filename>profile-docbook.xsl</filename>,
-<filename>profile-chunk.xsl</filename>, &#8230;) instead of normal
-ones (<filename>docbook.xsl</filename>,
-<filename>chunk.xsl</filename>, &#8230;).</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="profile.vendor">
-<refmeta>
-<refentrytitle>profile.vendor</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>profile.vendor</refname>
-<refpurpose>Target profile for <tag class="attribute">vendor</tag>
-attribute</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="profile.vendor.frag">
-&lt;xsl:param name="profile.vendor"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The value of this parameter specifies profiles which should be
-included in the output. You can specify multiple profiles by
-separating them by semicolon. You can change separator character by
-<parameter>profile.separator</parameter>
-parameter.</para>
-
-<para>This parameter has effect only when you are using profiling
-stylesheets (<filename>profile-docbook.xsl</filename>,
-<filename>profile-chunk.xsl</filename>, &#8230;) instead of normal
-ones (<filename>docbook.xsl</filename>,
-<filename>chunk.xsl</filename>, &#8230;).</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="profile.wordsize">
-<refmeta>
-<refentrytitle>profile.wordsize</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>profile.wordsize</refname>
-<refpurpose>Target profile for <tag class="attribute">wordsize</tag>
-attribute</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="profile.wordsize.frag">
-&lt;xsl:param name="profile.wordsize"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The value of this parameter specifies profiles which should be
-included in the output. You can specify multiple profiles by
-separating them by semicolon. You can change separator character by
-<parameter>profile.separator</parameter>
-parameter.</para>
-
-<para>This parameter has effect only when you are using profiling
-stylesheets (<filename>profile-docbook.xsl</filename>,
-<filename>profile-chunk.xsl</filename>, &#8230;) instead of normal
-ones (<filename>docbook.xsl</filename>,
-<filename>chunk.xsl</filename>, &#8230;).</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="profile.attribute">
-<refmeta>
-<refentrytitle>profile.attribute</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>profile.attribute</refname>
-<refpurpose>Name of user-specified profiling attribute</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="profile.attribute.frag">
-&lt;xsl:param name="profile.attribute"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This parameter is used in conjuction with
-<parameter>profile.value</parameter>.</para>
-
-<para>This parameter has effect only when you are using profiling
-stylesheets (<filename>profile-docbook.xsl</filename>,
-<filename>profile-chunk.xsl</filename>, &#8230;) instead of normal
-ones (<filename>docbook.xsl</filename>,
-<filename>chunk.xsl</filename>, &#8230;).</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="profile.value">
-<refmeta>
-<refentrytitle>profile.value</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>profile.value</refname>
-<refpurpose>Target profile for user-specified attribute</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="profile.value.frag">
-&lt;xsl:param name="profile.value"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>When you are using this parameter you must also specify name of
-profiling attribute with parameter
-<parameter>profile.attribute</parameter>.</para>
-
-<para>The value of this parameter specifies profiles which should be
-included in the output. You can specify multiple profiles by
-separating them by semicolon. You can change separator character by
-<parameter>profile.separator</parameter>
-parameter.</para>
-
-<para>This parameter has effect only when you are using profiling
-stylesheets (<filename>profile-docbook.xsl</filename>,
-<filename>profile-chunk.xsl</filename>, &#8230;) instead of normal
-ones (<filename>docbook.xsl</filename>,
-<filename>chunk.xsl</filename>, &#8230;).</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="profile.separator">
-<refmeta>
-<refentrytitle>profile.separator</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>profile.separator</refname>
-<refpurpose>Separator character for compound profile values</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="profile.separator.frag">
-&lt;xsl:param name="profile.separator"&gt;;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Separator character used for compound profile values. See <parameter>profile.arch</parameter></para>
-
-</refsection>
-</refentry>
-
-</reference><reference id="l10n" xml:base="../fo/param.xml"><title>Localization</title>
-<refentry version="5.0" id="l10n.gentext.language">
-<refmeta>
-<refentrytitle>l10n.gentext.language</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>l10n.gentext.language</refname>
-<refpurpose>Sets the gentext language</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="l10n.gentext.language.frag">
-&lt;xsl:param name="l10n.gentext.language"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If this parameter is set to any value other than the empty string, its
-value will be used as the value for the language when generating text. Setting
-<parameter>l10n.gentext.language</parameter> overrides any settings within the
-document being formatted.</para>
-
-<para>It's much more likely that you might want to set the
-<parameter>l10n.gentext.default.language</parameter> parameter.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="l10n.gentext.default.language">
-  <refmeta>
-    <refentrytitle>l10n.gentext.default.language</refentrytitle>
-    <refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-  </refmeta>
-  <refnamediv>
-    <refname>l10n.gentext.default.language</refname>
-    <refpurpose>Sets the default language for generated text</refpurpose>
-  </refnamediv>
-
-  <refsynopsisdiv>
-<programlisting id="l10n.gentext.default.language.frag">
-&lt;xsl:param name="l10n.gentext.default.language"&gt;en&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The value of the <parameter>l10n.gentext.default.language</parameter>
-parameter is used as the language for generated text if no setting is provided
-in the source document.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="l10n.gentext.use.xref.language">
-<refmeta>
-<refentrytitle>l10n.gentext.use.xref.language</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>l10n.gentext.use.xref.language</refname>
-<refpurpose>Use the language of target when generating cross-reference text?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="l10n.gentext.use.xref.language.frag">
-&lt;xsl:param name="l10n.gentext.use.xref.language" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, the language of the target will be used when
-generating cross reference text. Usually, the <quote>current</quote>
-language is used when generating text (that is, the language of the
-element that contains the cross-reference element). But setting this parameter
-allows the language of the element <emphasis>pointed to</emphasis> to control
-the generated text.</para>
-
-<para>Consider the following example:</para>
-
-<informalexample>
-<programlisting>&lt;para lang="en"&gt;See also &lt;xref linkend="chap3"/&gt;.&lt;/para&gt;
-</programlisting>
-</informalexample>
-
-<para>Suppose that Chapter 3 happens to be written in German.
-If <parameter>l10n.gentext.use.xref.language</parameter> is non-zero, the
-resulting text will be something like this:</para>
-
-<blockquote>
-<para>See also Kapital 3.</para>
-</blockquote>
-
-<para>Where the more traditional rendering would be:</para>
-
-<blockquote>
-<para>See also Chapter 3.</para>
-</blockquote>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="l10n.lang.value.rfc.compliant">
-<refmeta>
-<refentrytitle>l10n.lang.value.rfc.compliant</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>l10n.lang.value.rfc.compliant</refname>
-<refpurpose>Make value of lang attribute RFC compliant?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="l10n.lang.value.rfc.compliant.frag">
-&lt;xsl:param name="l10n.lang.value.rfc.compliant" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, ensure that the values for all <tag class="attribute">lang</tag> attributes in HTML output are RFC
-compliant<footnote><para>Section 8.1.1, <link xlink:href="http://www.w3.org/TR/REC-html40/struct/dirlang.html#h-8.1.1">Language Codes</link>, in the HTML 4.0 Recommendation states that:
-
-<blockquote><para>[RFC1766] defines and explains the language codes
-that must be used in HTML documents.</para>
-<para>Briefly, language codes consist of a primary code and a possibly
-empty series of subcodes:
-
-<literallayout class="monospaced">language-code = primary-code ( "-" subcode )*</literallayout>
-</para>
-<para>And in RFC 1766, <link xlink:href="http://www.ietf.org/rfc/rfc1766.txt">Tags for the Identification
-of Languages</link>, the EBNF for "language tag" is given as:
-
-<literallayout class="monospaced">Language-Tag = Primary-tag *( "-" Subtag )
-Primary-tag = 1*8ALPHA
-Subtag = 1*8ALPHA</literallayout>
-</para>
-</blockquote>
-</para></footnote>.
-
-by taking any underscore characters in any <tag class="attribute">lang</tag> values found in source documents, and
-replacing them with hyphen characters in output HTML files. For
-example, <literal>zh_CN</literal> in a source document becomes
-<literal>zh-CN</literal> in the HTML output form that source.
-
-<note>
-<para>This parameter does not cause any case change in <tag class="attribute">lang</tag> values, because RFC 1766
-explicitly states that all "language tags" (as it calls them) "are
-to be treated as case insensitive".</para>
-</note>
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="writing.mode">
-<refmeta>
-<refentrytitle>writing.mode</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>writing.mode</refname>
-<refpurpose>Direction of text flow based on locale</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="writing.mode.frag">
-&lt;xsl:param name="writing.mode"&gt;
-  &lt;xsl:call-template name="gentext"&gt;
-    &lt;xsl:with-param name="key"&gt;writing-mode&lt;/xsl:with-param&gt;
-    &lt;xsl:with-param name="lang"&gt;
-      &lt;xsl:call-template name="l10n.language"&gt;
-        &lt;xsl:with-param name="target" select="/*[1]"&gt;&lt;/xsl:with-param&gt;
-      &lt;/xsl:call-template&gt;
-    &lt;/xsl:with-param&gt;
-  &lt;/xsl:call-template&gt;
-&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Sets direction of text flow and text alignment based on locale.
-The value is normally taken from the gentext file for the 
-lang attribute of the document's root element, using the 
-key name 'writing-mode' to look it up in the gentext file.
-But this param can also be
-set on the command line to override that gentext value.
-</para>
-<para>Accepted values are:
-<variablelist>
-  <varlistentry>
-    <term>lr-tb</term>
-    <listitem>
-      <para>Left-to-right text flow in each line, lines stack top to bottom.</para>
-    </listitem>
-  </varlistentry>
-  <varlistentry>
-    <term>rl-tb</term>
-    <listitem>
-      <para>Right-to-left text flow in each line, lines stack top to bottom.</para>
-    </listitem>
-  </varlistentry>
-  <varlistentry>
-    <term>tb-rl</term>
-    <listitem>
-      <para>Top-to-bottom text flow in each vertical line, lines stack right to left.
-      Supported by only a few XSL-FO processors. Not supported in HTML output.</para>
-    </listitem>
-  </varlistentry>
-  <varlistentry>
-    <term>lr</term>
-    <listitem>
-      <para>Shorthand for lr-tb.</para>
-    </listitem>
-  </varlistentry>
-  <varlistentry>
-    <term>rl</term>
-    <listitem>
-      <para>Shorthand for rl-tb.</para>
-    </listitem>
-  </varlistentry>
-  <varlistentry>
-    <term>tb</term>
-    <listitem>
-      <para>Shorthand for tb-rl.</para>
-    </listitem>
-  </varlistentry>
-</variablelist>
-</para>
-
-</refsection>
-</refentry>
-
-</reference><reference id="ebnf" xml:base="../fo/param.xml"><title>EBNF</title>
-<refentry version="5.0" id="ebnf.assignment">
-<refmeta>
-<refentrytitle>ebnf.assignment</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">rtf</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>ebnf.assignment</refname>
-<refpurpose>The EBNF production assignment operator</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="ebnf.assignment.frag">
-
-&lt;xsl:param name="ebnf.assignment"&gt;
-  &lt;fo:inline font-family="{$monospace.font.family}"&gt;
-    &lt;xsl:text&gt;::=&lt;/xsl:text&gt;
-  &lt;/fo:inline&gt;
-&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The <parameter>ebnf.assignment</parameter> parameter determines what
-text is used to show <quote>assignment</quote> in <tag>production</tag>s
-in <tag>productionset</tag>s.</para>
-
-<para>While <quote><literal>::=</literal></quote> is common, so are several
-other operators.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="ebnf.statement.terminator">
-<refmeta>
-<refentrytitle>ebnf.statement.terminator</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">rtf</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>ebnf.statement.terminator</refname>
-<refpurpose>Punctuation that ends an EBNF statement.</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="ebnf.statement.terminator.frag">
-
-&lt;xsl:param name="ebnf.statement.terminator"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The <parameter>ebnf.statement.terminator</parameter> parameter determines what
-text is used to terminate each <tag>production</tag>
-in <tag>productionset</tag>.</para>
-
-<para>Some notations end each statement with a period.</para>
-
-</refsection>
-</refentry>
-
-</reference><reference id="prepress" xml:base="../fo/param.xml"><title>Prepress</title>
-<refentry version="5.0" id="crop.marks">
-<refmeta>
-<refentrytitle>crop.marks</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>crop.marks</refname>
-<refpurpose>Output crop marks?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="crop.marks.frag">
-&lt;xsl:param name="crop.marks" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, crop marks will be added to each page. Currently this
-works only with XEP if you have <parameter>xep.extensions</parameter> set.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="crop.mark.width">
-<refmeta>
-<refentrytitle>crop.mark.width</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">length</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>crop.mark.width</refname>
-<refpurpose>Width of crop marks.</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="crop.mark.width.frag">
-&lt;xsl:param name="crop.mark.width"&gt;0.5pt&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Width of crop marks. Crop marks are controlled by
-<parameter>crop.marks</parameter> parameter.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="crop.mark.offset">
-<refmeta>
-<refentrytitle>crop.mark.offset</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">length</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>crop.mark.offset</refname>
-<refpurpose>Length of crop marks.</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="crop.mark.offset.frag">
-&lt;xsl:param name="crop.mark.offset"&gt;24pt&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Length of crop marks. Crop marks are controlled by
-<parameter>crop.marks</parameter> parameter.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="crop.mark.bleed">
-<refmeta>
-<refentrytitle>crop.mark.bleed</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">length</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>crop.mark.bleed</refname>
-<refpurpose>Length of invisible part of crop marks.</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="crop.mark.bleed.frag">
-&lt;xsl:param name="crop.mark.bleed"&gt;6pt&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Length of invisible part of crop marks. Crop marks are controlled by
-<parameter>crop.marks</parameter> parameter.</para>
-
-</refsection>
-</refentry>
-
-</reference>
-    </part>
-    <part id="manpages">
-      <?dbhtml dir="manpages"?>
-      <?dbhtml filename="index.html"?>
-      <title xml:base="../manpages/param.xml">Manpages Parameter Reference</title>
-      <partintro id="manintro">
-        
-      <para xml:base="../manpages/param.xml">This is reference documentation for all user-configurable
-      parameters in the DocBook XSL "manpages" stylesheet (for
-      generating groff/nroff output). Note that the manpages
-      stylesheet is a customization layer of the DocBook XSL HTML
-      stylesheet. Therefore, you can also use a number of <link xlink:href="../html/">HTML stylesheet parameters</link>
-      to control manpages output (in addition to the
-      manpages-specific parameters listed in this section).</para>
-    
-      </partintro>
-      <reference id="general" xml:base="../manpages/param.xml">
-  <title>Hyphenation, justification, and breaking</title>
-<refentry version="5.0" id="man.hyphenate">
-<refmeta>
-<refentrytitle>man.hyphenate</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>man.hyphenate</refname>
-<refpurpose>Enable hyphenation?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="man.hyphenate.frag">
-&lt;xsl:param name="man.hyphenate"&gt;0&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, hyphenation is enabled.</para>
-
-<note>
-<para>The default value for this parameter is zero because groff is
-not particularly smart about how it does hyphenation; it can end up
-hyphenating a lot of things that you don't want hyphenated. To
-mitigate that, the default behavior of the stylesheets is to suppress
-hyphenation of computer inlines, filenames, and URLs. (You can
-override the default behavior by setting non-zero values for the
-<parameter>man.hyphenate.urls</parameter>,
-<parameter>man.hyphenate.filenames</parameter>, and
-<parameter>man.hyphenate.computer.inlines</parameter> parameters.) But
-the best way is still to just globally disable hyphenation, as the
-stylesheets do by default.</para>
-
-<para>The only good reason to enabled hyphenation is if you have also
-enabled justification (which is disabled by default). The reason is
-that justified text can look very bad unless you also hyphenate it; to
-quote the <quote>Hypenation</quote> node from the groff info page:
-
-<blockquote>
-  <para><emphasis>Since the odds are not great for finding a set of
-  words, for every output line, which fit nicely on a line without
-  inserting excessive amounts of space between words, 'gtroff'
-  hyphenates words so that it can justify lines without inserting too
-  much space between words.</emphasis></para>
-</blockquote>
-
-So, if you set a non-zero value for the
-<parameter>man.justify</parameter> parameter (to enable
-justification), then you should probably also set a non-zero value for
-<parameter>man.hyphenate</parameter> (to enable hyphenation).</para>
-</note>
-
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="man.hyphenate.urls">
-<refmeta>
-<refentrytitle>man.hyphenate.urls</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>man.hyphenate.urls</refname>
-<refpurpose>Hyphenate URLs?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="man.hyphenate.urls.frag">
-&lt;xsl:param name="man.hyphenate.urls"&gt;0&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If zero (the default), hyphenation is suppressed for output of
-the <tag>ulink</tag> <tag class="attribute">url</tag> attribute.</para>
-
-<note>
-  <para>If hyphenation is already turned off globally (that is, if
-  <parameter>man.hyphenate</parameter> is zero, setting
-  <parameter>man.hyphenate.urls</parameter> is not necessary.</para>
-</note>
-
-<para>If <parameter>man.hyphenate.urls</parameter> is non-zero, URLs
-will not be treated specially and are subject to hyphenation just like
-other words.</para>
-
-<note>
-  <para>If you are thinking about setting a non-zero value for
-  <parameter>man.hyphenate.urls</parameter> in order to make long
-  URLs break across lines, you'd probably be better off
-  experimenting with setting the
-  <parameter>man.break.after.slash</parameter> parameter first. That
-  will cause long URLs to be broken after slashes.</para>
-</note>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="man.hyphenate.filenames">
-<refmeta>
-<refentrytitle>man.hyphenate.filenames</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>man.hyphenate.filenames</refname>
-<refpurpose>Hyphenate filenames?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="man.hyphenate.filenames.frag">
-&lt;xsl:param name="man.hyphenate.filenames"&gt;0&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If zero (the default), hyphenation is suppressed for
-<tag>filename</tag> output.</para>
-
-<note>
-  <para>If hyphenation is already turned off globally (that is, if
-  <parameter>man.hyphenate</parameter> is zero, setting
-  <parameter>man.hyphenate.filenames</parameter> is not
-  necessary.</para>
-</note>
-
-<para>If <parameter>man.hyphenate.filenames</parameter> is non-zero,
-filenames will not be treated specially and are subject to hyphenation
-just like other words.</para>
-
-<note>
-  <para>If you are thinking about setting a non-zero value for
-  <parameter>man.hyphenate.filenames</parameter> in order to make long
-  filenames/pathnames break across lines, you'd probably be better off
-  experimenting with setting the
-  <parameter>man.break.after.slash</parameter> parameter first. That
-  will cause long pathnames to be broken after slashes.</para>
-</note>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="man.hyphenate.computer.inlines">
-<refmeta>
-<refentrytitle>man.hyphenate.computer.inlines</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>man.hyphenate.computer.inlines</refname>
-<refpurpose>Hyphenate computer inlines?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="man.hyphenate.computer.inlines.frag">
-&lt;xsl:param name="man.hyphenate.computer.inlines"&gt;0&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If zero (the default), hyphenation is suppressed for
-<quote>computer inlines</quote> such as environment variables,
-constants, etc. This parameter current affects output of the following
-elements:
-<simplelist type="inline">
-  
-  <member><tag>classname</tag></member>
-  <member><tag>constant</tag></member>
-  <member><tag>envar</tag></member>
-  <member><tag>errorcode</tag></member>
-  <member><tag>option</tag></member>
-  <member><tag>replaceable</tag></member>
-  <member><tag>userinput</tag></member>
-  <member><tag>type</tag></member>
-  <member><tag>varname</tag></member>
-</simplelist>
-</para>
-
-<note>
-  <para>If hyphenation is already turned off globally (that is, if
-  <parameter>man.hyphenate</parameter> is zero, setting the
-  <parameter>man.hyphenate.computer.inlines</parameter> is not
-  necessary.</para>
-</note>
-
-<para>If <parameter>man.hyphenate.computer.inlines</parameter> is
-non-zero, computer inlines will not be treated specially and will be
-hyphenated like other words when needed.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="man.justify">
-<refmeta>
-<refentrytitle>man.justify</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>man.justify</refname>
-<refpurpose>Justify text to both right and left margins?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="man.justify.frag">
-&lt;xsl:param name="man.justify"&gt;0&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, text is justified to both the right and left
-margins (or, in roff terminology, "adjusted and filled" to both the
-right and left margins). If zero (the default), text is adjusted to
-the left margin only -- producing what is traditionally called
-"ragged-right" text.</para>
-
-<note>
-<para>The default value for this parameter is zero because justified
-text looks good only when it is also hyphenated. Without hyphenation,
-excessive amounts of space often end up getting between words, in
-order to "pad" lines out to align on the right margin.</para>
-
-<para>The problem is that groff is not particularly smart about how it
-does hyphenation; it can end up hyphenating a lot of things that you
-don't want hyphenated. So, disabling both justification and
-hyphenation ensures that hyphens won't get inserted where you don't
-want to them, and you don't end up with lines containing excessive
-amounts of space between words.</para>
-
-<para>However, if do you decide to set a non-zero value for the
-<parameter>man.justify</parameter> parameter (to enable
-justification), then you should probably also set a non-zero value for
-<parameter>man.hyphenate</parameter> (to enable hyphenation).</para>
-
-<para>Yes, these default settings run counter to how most existing man
-pages are formatted. But there are some notable exceptions, such as
-the <literal>perl</literal> man pages.</para>
-</note>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="man.break.after.slash">
-<refmeta>
-<refentrytitle>man.break.after.slash</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>man.break.after.slash</refname>
-<refpurpose>Enable line-breaking after slashes?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="man.break.after.slash.frag">
-&lt;xsl:param name="man.break.after.slash"&gt;0&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If non-zero, line-breaking after slashes is enabled. This is
-mainly useful for causing long URLs or pathnames/filenames to be
-broken up or "wrapped" across lines (though it also has the side
-effect of sometimes causing relatively short URLs and pathnames to be
-broken up across lines too).</para>
-
-<para>If zero (the default), line-breaking after slashes is
-disabled. In that case, strings containing slashes (for example, URLs
-or filenames) are not broken across lines, even if they exceed the
-maximum column widith.</para>
-
-<warning>
-  <para>If you set a non-zero value for this parameter, check your
-  man-page output carefuly afterwards, in order to make sure that the
-  setting has not introduced an excessive amount of breaking-up of URLs
-  or pathnames. If your content contains mostly short URLs or
-  pathnames, setting a non-zero value for
-  <parameter>man.break.after.slash</parameter> will probably result in
-  in a significant number of relatively short URLs and pathnames being
-  broken across lines, which is probably not what you want.</para>
-</warning>
-
-</refsection>
-</refentry>
-
-  </reference><reference id="indent" xml:base="../manpages/param.xml">
-  <title>Indentation</title>
-<refentry version="5.0" id="man.indent.width">
-<refmeta>
-<refentrytitle>man.indent.width</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">length</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>man.indent.width</refname>
-<refpurpose>Specifies width used for adjusted indents</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="man.indent.width.frag">
-&lt;xsl:param name="man.indent.width"&gt;4&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-<para>The <parameter>man.indent.width</parameter> parameter specifies
-the width used for adjusted indents. The value of
-<parameter>man.indent.width</parameter> is used for indenting of
-lists, verbatims, headings, and elsewhere, depending on whether the
-values of certain <literal>man.indent.*</literal> boolean parameters
-are non-zero.</para>
-
-<para>The value of <parameter>man.indent.width</parameter> should
-include a valid roff measurement unit (for example,
-<literal>n</literal> or <literal>u</literal>). The default value of
-<literal>4n</literal> specifies a 4-en width; when viewed on a
-console, that amounts to the width of four characters. For details
-about roff measurment units, see the <literal>Measurements</literal>
-node in the groff info page.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="man.indent.refsect">
-<refmeta>
-<refentrytitle>man.indent.refsect</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>man.indent.refsect</refname>
-<refpurpose>Adjust indentation of refsect* and refsection?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="man.indent.refsect.frag">
-&lt;xsl:param name="man.indent.refsect" select="0"&gt;&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If the value of <parameter>man.indent.refsect</parameter> is
-non-zero, the width of the left margin for
-<tag>refsect1</tag>, <tag>refsect2</tag> and
-<tag>refsect3</tag> contents and titles (and first-level,
-second-level, and third-level nested
-<tag>refsection</tag>instances) is adjusted by the value of
-the <parameter>man.indent.width</parameter> parameter. With
-<parameter>man.indent.width</parameter> set to its default value of
-<literal>3n</literal>, the main results are that:
-
-<itemizedlist>
-  <listitem>
-    <para>contents of <tag>refsect1</tag> are output with a
-    left margin of three characters instead the roff default of seven
-    or eight characters</para>
-  </listitem>
-  <listitem>
-    <para>contents of <tag>refsect2</tag> are displayed in
-    console output with a left margin of six characters instead the of
-    the roff default of seven characters</para>
-  </listitem>
-  <listitem>
-    <para> the contents of <tag>refsect3</tag> and nested
-    <tag>refsection</tag> instances are adjusted
-    accordingly.</para>
-  </listitem>
-</itemizedlist>
-
-If instead the value of <parameter>man.indent.refsect</parameter> is
-zero, no margin adjustment is done for <literal>refsect*</literal>
-output.</para>
-
-<tip>
-  <para>If your content is primarly comprised of
-  <tag>refsect1</tag> and <tag>refsect2</tag> content
-  (or the <tag>refsection</tag> equivalent)&#160;&#8211; with few or
-  no <tag>refsect3</tag> or lower nested sections , you may be
-  able to &#8220;conserve&#8221; space in your output by setting
-  <parameter>man.indent.refsect</parameter> to a non-zero value. Doing
-  so will &#8220;squeeze&#8221; the left margin in such as way as to provide an
-  additional four characters of &#8220;room&#8221; per line in
-  <tag>refsect1</tag> output. That extra room may be useful
-  if, for example, you have many verbatim sections with long lines in
-  them.</para>
-</tip>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="man.indent.blurbs">
-<refmeta>
-<refentrytitle>man.indent.blurbs</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>man.indent.blurbs</refname>
-<refpurpose>Adjust indentation of blurbs?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="man.indent.blurbs.frag">
-&lt;xsl:param name="man.indent.blurbs" select="1"&gt;&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If the value of <parameter>man.indent.blurbs</parameter> is
-non-zero, the width of the left margin for
-<tag>authorblurb</tag>, <tag>personblurb</tag>, and
-<tag>contrib</tag> output is set to the value of the
-<parameter>man.indent.width</parameter> parameter
-(<literal>3n</literal> by default). If instead the value of
-<parameter>man.indent.blurbs</parameter> is zero, the built-in roff
-default width (<literal>7.2n</literal>) is used.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="man.indent.lists">
-<refmeta>
-<refentrytitle>man.indent.lists</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>man.indent.lists</refname>
-<refpurpose>Adjust indentation of lists?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="man.indent.lists.frag">
-&lt;xsl:param name="man.indent.lists" select="1"&gt;&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If the value of <parameter>man.indent.lists</parameter> is
-non-zero, the width of the left margin for list items in
-<tag>itemizedlist</tag>,
-<tag>orderedlist</tag>,
-<tag>variablelist</tag> output (and output of some other
-lists) is set to the value of the
-<parameter>man.indent.width</parameter> parameter
-(<literal>4n</literal> by default). If instead the value of
-<parameter>man.indent.lists</parameter> is zero, the built-in roff
-default width (<literal>7.2n</literal>) is used.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="man.indent.verbatims">
-<refmeta>
-<refentrytitle>man.indent.verbatims</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>man.indent.verbatims</refname>
-<refpurpose>Adjust indentation of verbatims?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="man.indent.verbatims.frag">
-&lt;xsl:param name="man.indent.verbatims" select="1"&gt;&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If the value of <parameter>man.indent.verbatims</parameter> is
-non-zero, the width of the left margin for output of verbatim
-environments (<tag>programlisting</tag>,
-<tag>screen</tag>, and so on) is set to the value of the
-<parameter>man.indent.width</parameter> parameter
-(<literal>3n</literal> by default). If instead the value of
-<parameter>man.indent.verbatims</parameter> is zero, the built-in roff
-default width (<literal>7.2n</literal>) is used.</para>
-
-</refsection>
-</refentry>
-
-  </reference><reference id="fonts" xml:base="../manpages/param.xml">
-  <title>Fonts</title>
-<refentry version="5.0" id="man.font.funcprototype">
-<refmeta>
-<refentrytitle>man.font.funcprototype</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>man.font.funcprototype</refname>
-<refpurpose>Specifies font for funcprototype output</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="man.font.funcprototype.frag">
-  &lt;xsl:param name="man.font.funcprototype"&gt;BI&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The <parameter>man.font.funcprototype</parameter> parameter
-specifies the font for <tag>funcprototype</tag> output. It
-should be a valid roff font name, such as <literal>BI</literal> or
-<literal>B</literal>.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="man.font.funcsynopsisinfo">
-<refmeta>
-<refentrytitle>man.font.funcsynopsisinfo</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>man.font.funcsynopsisinfo</refname>
-<refpurpose>Specifies font for funcsynopsisinfo output</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="man.font.funcsynopsisinfo.frag">
-  &lt;xsl:param name="man.font.funcsynopsisinfo"&gt;B&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The <parameter>man.font.funcsynopsisinfo</parameter> parameter
-specifies the font for <tag>funcsynopsisinfo</tag> output. It
-should be a valid roff font name, such as <literal>B</literal> or
-<literal>I</literal>.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="man.font.links">
-<refmeta>
-<refentrytitle>man.font.links</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>man.font.links</refname>
-<refpurpose>Specifies font for links</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="man.font.links.frag">
-&lt;xsl:param name="man.font.links"&gt;B&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The <parameter>man.font.links</parameter> parameter
-specifies the font for output of links (<tag>ulink</tag> instances
-and any instances of any element with an <tag class="attribute">xlink:href</tag> attribute).</para>
-
-<para>The value of <parameter>man.font.links</parameter> must be
-  either <literal>B</literal> or <literal>I</literal>, or empty. If
-the value is empty, no font formatting is applied to links.</para>
-
-<para>If you set <parameter>man.endnotes.are.numbered</parameter> and/or
-<parameter>man.endnotes.list.enabled</parameter> to zero (disabled), then
-you should probably also set an empty value for
-<parameter>man.font.links</parameter>. But if
-<parameter>man.endnotes.are.numbered</parameter> is non-zero (enabled),
-you should probably keep
-<parameter>man.font.links</parameter> set to
-<literal>B</literal> or <literal>I</literal><footnote><para>The
-    main purpose of applying a font format to links in most output
-formats it to indicate that the formatted text is
-&#8220;clickable&#8221;; given that links rendered in man pages are
-not &#8220;real&#8221; hyperlinks that users can click on, it might
-seem like there is never a good reason to have font formatting for
-link contents in man output.</para>
-<para>In fact, if you suppress the
-display of inline link references (by setting
-<parameter>man.endnotes.are.numbered</parameter> to zero), there is no
-good reason to apply font formatting to links. However, if
-<parameter>man.endnotes.are.numbered</parameter> is non-zero, having
-font formatting for links (arguably) serves a purpose: It provides
-&#8220;context&#8221; information about exactly what part of the text
-is being &#8220;annotated&#8221; by the link. Depending on how you
-mark up your content, that context information may or may not
-have value.</para></footnote>.</para>
-</refsection>
-
-<refsection><info><title>Related Parameters</title></info>
-  <para><parameter>man.endnotes.list.enabled</parameter>,
-    <parameter>man.endnotes.are.numbered</parameter></para>
-</refsection>
-
-</refentry>
-
-<refentry version="5.0" id="man.font.table.headings">
-<refmeta>
-<refentrytitle>man.font.table.headings</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>man.font.table.headings</refname>
-<refpurpose>Specifies font for table headings</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="man.font.table.headings.frag">
-  &lt;xsl:param name="man.font.table.headings"&gt;B&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The <parameter>man.font.table.headings</parameter> parameter
-specifies the font for <tag>table</tag> headings. It should be
-a valid roff font, such as <literal>B</literal> or
-<literal>I</literal>.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="man.font.table.title">
-<refmeta>
-<refentrytitle>man.font.table.title</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>man.font.table.title</refname>
-<refpurpose>Specifies font for table headings</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="man.font.table.title.frag">
-  &lt;xsl:param name="man.font.table.title"&gt;B&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The <parameter>man.font.table.title</parameter> parameter
-specifies the font for <tag>table</tag> titles. It should be
-a valid roff font, such as <literal>B</literal> or
-<literal>I</literal>.</para>
-
-</refsection>
-</refentry>
-
-  </reference><reference id="synopsis" xml:base="../manpages/param.xml">
-  <title>SYNOPSIS section</title>
-<refentry version="5.0" id="man.funcsynopsis.style">
-<refmeta>
-<refentrytitle>man.funcsynopsis.style</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">list</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">ansi</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">kr</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>man.funcsynopsis.style</refname>
-<refpurpose>What style of <tag>funcsynopsis</tag> should be generated?</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-<programlisting id="man.funcsynopsis.style.frag">&lt;xsl:param name="man.funcsynopsis.style"&gt;ansi&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-<refsection><info><title>Description</title></info>
-<para>If <parameter>man.funcsynopsis.style</parameter> is
-<literal>ansi</literal>, ANSI-style function synopses are
-generated for a <tag>funcsynopsis</tag>, otherwise K&amp;R-style
-function synopses are generated.</para>
-</refsection>
-</refentry>
-
-  </reference><reference id="authors" xml:base="../manpages/param.xml">
-  <title>AUTHORS and COPYRIGHT sections</title>
-  <refentry version="5.0" id="man.authors.section.enabled">
-<refmeta>
-<refentrytitle>man.authors.section.enabled</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>man.authors.section.enabled</refname>
-<refpurpose>Display auto-generated AUTHORS section?</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-<programlisting id="man.authors.section.enabled.frag">
-&lt;xsl:param name="man.authors.section.enabled"&gt;1&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-<refsection><info><title>Description</title></info>
-
-<para>If the value of
-<parameter>man.authors.section.enabled</parameter> is non-zero
-(the default), then an <literal>AUTHORS</literal> section is
-generated near the end of each man page. The output of the
-<literal>AUTHORS</literal> section is assembled from any
-<tag>author</tag>, <tag>editor</tag>, and <tag>othercredit</tag>
-metadata found in the contents of the child <tag>info</tag> or
-<tag>refentryinfo</tag> (if any) of the <tag>refentry</tag>
-itself, or from any <tag>author</tag>, <tag>editor</tag>, and
-<tag>othercredit</tag> metadata that may appear in <tag>info</tag>
-contents of any ancestors of the <tag>refentry</tag>.</para>
-
-<para>If the value of
-<parameter>man.authors.section.enabled</parameter> is zero, the
-the auto-generated <literal>AUTHORS</literal> section is
-suppressed.</para>
-
-<para>Set the value of
-  <parameter>man.authors.section.enabled</parameter> to zero if
-  you want to have a manually created <literal>AUTHORS</literal>
-  section in your source, and you want it to appear in output
-  instead of the auto-generated <literal>AUTHORS</literal>
-  section.</para>
-</refsection>
-</refentry>
-
-  <refentry version="5.0" id="man.copyright.section.enabled">
-<refmeta>
-<refentrytitle>man.copyright.section.enabled</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>man.copyright.section.enabled</refname>
-<refpurpose>Display auto-generated COPYRIGHT section?</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-<programlisting id="man.copyright.section.enabled.frag">
-&lt;xsl:param name="man.copyright.section.enabled"&gt;1&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-<refsection><info><title>Description</title></info>
-
-<para>If the value of
-<parameter>man.copyright.section.enabled</parameter> is non-zero
-(the default), then a <literal>COPYRIGHT</literal> section is
-generated near the end of each man page. The output of the
-<literal>COPYRIGHT</literal> section is assembled from any
-<tag>copyright</tag> and <tag>legalnotice</tag> metadata found in
-the contents of the child <tag>info</tag> or
-<tag>refentryinfo</tag> (if any) of the <tag>refentry</tag>
-itself, or from any <tag>copyright</tag> and
-<tag>legalnotice</tag> metadata that may appear in <tag>info</tag>
-contents of any ancestors of the <tag>refentry</tag>.</para>
-
-<para>If the value of
-<parameter>man.copyright.section.enabled</parameter> is zero, the
-the auto-generated <literal>COPYRIGHT</literal> section is
-suppressed.</para>
-
-<para>Set the value of
-  <parameter>man.copyright.section.enabled</parameter> to zero if
-  you want to have a manually created <literal>COPYRIGHT</literal>
-  section in your source, and you want it to appear in output
-  instead of the auto-generated <literal>COPYRIGHT</literal>
-  section.</para>
-</refsection>
-</refentry>
-
-  </reference><reference id="endnotes" xml:base="../manpages/param.xml">
-  <title>Endnotes and link handling</title>
-<refentry version="5.0" id="man.endnotes.list.enabled">
-<refmeta>
-<refentrytitle>man.endnotes.list.enabled</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>man.endnotes.list.enabled</refname>
-<refpurpose>Display endnotes list at end of man page?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="man.endnotes.list.enabled.frag">
-&lt;xsl:param name="man.endnotes.list.enabled"&gt;1&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If the value of <parameter>man.endnotes.list.enabled</parameter> is
-non-zero (the default), then an endnotes list is added to the end of
-the output man page.</para>
-
-<para>If the value of <parameter>man.endnotes.list.enabled</parameter> is
-zero, the list is suppressed &#8212; unless link numbering is enabled (that
-is, if <parameter>man.endnotes.are.numbered</parameter> is non-zero), in
-which case, that setting overrides the
-<parameter>man.endnotes.list.enabled</parameter> setting, and the
-endnotes list is still displayed. The reason is that inline
-numbering of notesources associated with endnotes only makes sense
-if a (numbered) list of endnotes is also generated.</para>
-
-<note>
-  <para>Leaving
-  <parameter>man.endnotes.list.enabled</parameter> at its default
-  (non-zero) value ensures that no &#8220;out of line&#8221; information (such
-  as the URLs for hyperlinks and images) gets lost in your
-  man-page output. It just gets &#8220;rearranged&#8221;.</para>
-  <para>So if you&#8217;re thinking about disabling endnotes listing by
-    setting the value of
-    <parameter>man.endnotes.list.enabled</parameter> to zero:
-    Before you do so, first take some time to carefully consider
-    the information needs and experiences of your users. The &#8220;out
-    of line&#8221; information has value even if the presentation of it
-    in text output is not as interactive as it may be in other
-    output formats.</para>
-  <para>As far as the specific case of URLs: Even though the URLs
-    displayed in text output may not be &#8220;real&#8221; (clickable)
-    hyperlinks, many X terminals have convenience features for
-    recognizing URLs and can, for example, present users with
-    an options to open a URL in a browser with the user clicks on
-    the URL is a terminal window. And short of those, users with X
-    terminals can always manually cut and paste the URLs into a web
-    browser.</para>
-  <para>Also, note that various &#8220;man to html&#8221; tools, such as the
-    widely used <command><link xlink:href="http://users.actrix.gen.nz/michael/vhman2html.html">man2html</link></command> (<literal>VH-Man2html</literal>)
-    application, automatically mark up URLs with <literal>a@href</literal> markup
-  during conversion &#8212; resulting in &#8220;real&#8221; hyperlinks in HTML
-  output from those tools.</para>
-</note>
-
-<para>To &#8220;turn off&#8221; numbering of endnotes in the
-endnotes list, set <parameter>man.endnotes.are.numbered</parameter>
-to zero. The endnotes list will
-still be displayed; it will just be displayed without the
-numbers<footnote><para>It can still make sense to have
-the list of endnotes displayed even if you have endnotes numbering turned
-off. In that case, your endnotes list basically becomes a &#8220;list
-of references&#8221; without any association with specific text in
-your document. This is probably the best option if you find the inline
-endnotes numbering obtrusive. Your users will still have access to all the &#8220;out of line&#8221;
-such as URLs for hyperlinks.</para></footnote>
-</para>
-
-<para>The default heading for the endnotes list is
-<literal>NOTES</literal>. To change that, set a non-empty
-value for the <parameter>man.endnotes.list.heading</parameter>
-parameter.</para>
-
-<para>In the case of notesources that are links: Along with the
-URL for each link, the endnotes list includes the contents of the
-link. The list thus includes only non-empty<footnote>
-
-<para>A &#8220;non-empty&#8221; link is one that looks like
-this:<literallayout class="monospaced">  &lt;ulink url="http://docbook.sf.net/snapshot/xsl/doc/manpages/"&gt;manpages&lt;/ulink&gt;</literallayout>
-an &#8220;empty link&#8221; is on that looks like this:<literallayout class="monospaced">  &lt;ulink url="http://docbook.sf.net/snapshot/xsl/doc/manpages/"/&gt;</literallayout>
-</para></footnote> links.
-
-Empty links are never included, and never numbered. They are simply
-displayed inline, without any numbering.</para>
-
-<para>In addition, if there are multiple instances of links in a
-<tag>refentry</tag> that have the same URL, the URL is listed only
-once. The contents listed for that link in the endnotes list are
-the contents of the first link which has that URL.</para>
-
-<para>If you disable endnotes listing, you should probably also set
-<parameter>man.links.are.underlined</parameter> to zero (to disable
-link underlining).</para>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="man.endnotes.list.heading">
-<refmeta>
-<refentrytitle>man.endnotes.list.heading</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>man.endnotes.list.heading</refname>
-<refpurpose>Specifies an alternate name for endnotes list</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="man.endnotes.list.heading.frag">
-&lt;xsl:param name="man.endnotes.list.heading"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If the value of the
-<parameter>man.endnotes.are.numbered</parameter> parameter
-and/or the <parameter>man.endnotes.list.enabled</parameter>
-parameter is non-zero (the defaults for both are non-zero), a
-numbered list of endnotes is generated near the end of each man
-page. The default heading for the list of endnotes is the
-equivalent of the English word <literal>NOTES</literal> in
-the current locale. To cause an alternate heading to be displayed,
-set a non-empty value for the
-<parameter>man.endnotes.list.heading</parameter> parameter &#8212;
-for example, <literal>REFERENCES</literal>.</para>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="man.endnotes.are.numbered">
-<refmeta>
-<refentrytitle>man.endnotes.are.numbered</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>man.endnotes.are.numbered</refname>
-<refpurpose>Number endnotes?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="man.endnotes.are.numbered.frag">
-&lt;xsl:param name="man.endnotes.are.numbered"&gt;1&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If the value of <parameter>man.endnotes.are.numbered</parameter> is
-non-zero (the default), then for each non-empty<footnote>
-<para>A &#8220;non-empty&#8221; notesource is one that looks like
-this:<literallayout class="monospaced">  &lt;ulink url="http://docbook.sf.net/snapshot/xsl/doc/manpages/"&gt;manpages&lt;/ulink&gt;</literallayout>
-an &#8220;empty&#8221; notesource is on that looks like this:<literallayout class="monospaced">  &lt;ulink url="http://docbook.sf.net/snapshot/xsl/doc/manpages/"/&gt;</literallayout>
-</para></footnote> &#8220;notesource&#8221;:
-
-<itemizedlist>
-  <listitem>
-    <para>a number (in square brackets) is displayed inline after the
-    rendered inline contents (if any) of the notesource</para>
-  </listitem>
-  <listitem>
-    <para>the contents of the notesource are included in a
-      numbered list of endnotes that is generated at the end of
-      each man page; the number for each endnote corresponds to
-      the inline number for the notesource with which it is
-      associated</para>
-  </listitem>
-</itemizedlist>
-The default heading for the list of endnotes is
-<literal>NOTES</literal>. To output a different heading, set a value
-for the <parameter>man.endnotes.section.heading</parameter>
-parameter.</para>
-
-<note>
-  <para>The endnotes list is also displayed (but without
-    numbers) if the value of
-    <parameter>man.endnotes.list.enabled</parameter> is
-    non-zero.</para>
-</note>
-
-
-<para>If the value of <parameter>man.endnotes.are.numbered</parameter> is
-zero, numbering of endnotess is suppressed; only inline
-contents (if any) of the notesource are displayed inline.
-<important>
-  <para>If you are thinking about disabling endnote numbering by setting
-  the value of <parameter>man.endnotes.are.numbered</parameter> to zero,
-  before you do so, first take some time to carefully
-  consider the information needs and experiences of your users. The
-  square-bracketed numbers displayed inline after notesources may seem
-  obstrusive and aesthetically unpleasing<footnote><para>As far as notesources that are links, ytou might
-  think it would be better to just display URLs for non-empty
-  links inline, after their content, rather than displaying
-  square-bracketed numbers all over the place. But it's not better. In
-  fact, it's not even practical, because many (most) URLs for links
-  are too long to be displayed inline. They end up overflowing the
-  right margin. You can set a non-zero value for
-  <parameter>man.break.after.slash</parameter> parameter to deal with
-  that, but it could be argued that what you end up with is at least
-  as ugly, and definitely more obstrusive, then having short
-  square-bracketed numbers displayed inline.</para></footnote>,
-
-  but in a text-only output format, the
-  numbered-notesources/endnotes-listing mechanism is the only
-  practical way to handle this kind of content.</para>
-
-  <para>Also, users of &#8220;text based&#8221; browsers such as
-  <command>lynx</command> will already be accustomed to seeing inline
-  numbers for links. And various "man to html" applications, such as
-  the widely used <command><link xlink:href="http://users.actrix.gen.nz/michael/vhman2html.html">man2html</link></command> (<literal>VH-Man2html</literal>)
-  application, can automatically turn URLs into "real" HTML hyperlinks
-  in output. So leaving <parameter>man.endnotes.are.numbered</parameter>
-  at its default (non-zero) value ensures that no information is
-  lost in your man-page output. It just gets
-  &#8220;rearranged&#8221;.</para>
-</important>
-</para>
-<para>The handling of empty links is not affected by this
-parameter. Empty links are handled simply by displaying their URLs
-inline. Empty links are never auto-numbered.</para>
-
-<para>If you disable endnotes numbering, you should probably also set
-<parameter>man.font.links</parameter> to an empty value (to
-disable font formatting for links.</para>
-</refsection>
-
-<refsection><info><title>Related Parameters</title></info>
-  <para><parameter>man.endnotes.list.enabled</parameter>,
-    <parameter>man.font.links</parameter></para>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="man.base.url.for.relative.links">
-  <refmeta>
-    <refentrytitle>man.base.url.for.relative.links</refentrytitle>
-    <refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-  </refmeta>
-  <refnamediv>
-    <refname>man.base.url.for.relative.links</refname>
-    <refpurpose>Specifies a base URL for relative links</refpurpose>
-  </refnamediv>
-
-  <refsynopsisdiv>
-    <programlisting id="man.base.url.for.relative.links.frag">&lt;xsl:param name="man.base.url.for.relative.links"&gt;[set $man.base.url.for.relative.links]/&lt;/xsl:param&gt;</programlisting>
-  </refsynopsisdiv>
-
-  <refsection><info><title>Description</title></info>
-
-    <para>For any &#8220;notesource&#8221; listed in the auto-generated
-      &#8220;NOTES&#8221; section of output man pages (which is generated when
-      the value of the
-      <parameter>man.endnotes.list.enabled</parameter> parameter
-      is non-zero), if the notesource is a link source with a
-      relative URI, the URI is displayed in output with the value
-      of the
-      <parameter>man.base.url.for.relative.links</parameter>
-      parameter prepended to the value of the link URI.</para>
-
-    <note>
-      <para>A link source is an notesource that references an
-        external resource:
-        <itemizedlist>
-          <listitem>
-            <para>a <tag>ulink</tag> element with a <tag class="attribute">url</tag> attribute</para>
-          </listitem>
-          <listitem>
-            <para>any element with an <tag class="attribute">xlink:href</tag> attribute</para>
-          </listitem>
-          <listitem>
-            <para>an <tag>imagedata</tag>, <tag>audiodata</tag>, or
-              <tag>videodata</tag> element</para>
-          </listitem>
-        </itemizedlist>
-      </para>
-    </note>
-
-    <para>If you use relative URIs in link sources in your DocBook
-      <tag>refentry</tag> source, and you leave
-      <parameter>man.base.url.for.relative.links</parameter>
-      unset, the relative links will appear &#8220;as is&#8221; in the &#8220;Notes&#8221;
-      section of any man-page output generated from your source.
-      That&#8217;s probably not what you want, because such relative
-      links are only usable in the context of HTML output. So, to
-      make the links meaningful and usable in the context of
-      man-page output, set a value for
-      <parameter>man.base.url.for.relative.links</parameter> that
-      points to the online version of HTML output generated from
-      your DocBook <tag>refentry</tag> source. For
-      example:
-      <programlisting>&lt;xsl:param name="man.base.url.for.relative.links"
-        &gt;http://www.kernel.org/pub/software/scm/git/docs/&lt;/xsl:param&gt;</programlisting>
-    </para>
-
-  </refsection>
-
-  <refsection><info><title>Related Parameters</title></info>
-    <para><parameter>man.endnotes.list.enabled</parameter></para>
-  </refsection>
-
-</refentry>
-
-  </reference><reference id="lists" xml:base="../manpages/param.xml">
-  <title>Lists</title>
-<refentry version="5.0" id="man.segtitle.suppress">
-<refmeta>
-<refentrytitle>man.segtitle.suppress</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>man.segtitle.suppress</refname>
-<refpurpose>Suppress display of segtitle contents?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="man.segtitle.suppress.frag">
-&lt;xsl:param name="man.segtitle.suppress" select="0"&gt;&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If the value of <parameter>man.segtitle.suppress</parameter> is
-non-zero, then display of <tag>segtitle</tag> contents is
-suppressed in output.</para>
-
-</refsection>
-</refentry>
-
-  </reference><reference id="charmap" xml:base="../manpages/param.xml">
-  <title>Character/string substitution</title>
-<refentry version="5.0" id="man.charmap.enabled">
-<refmeta>
-<refentrytitle>man.charmap.enabled</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>man.charmap.enabled</refname>
-<refpurpose>Apply character map before final output?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="man.charmap.enabled.frag">
-&lt;xsl:param name="man.charmap.enabled" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If the value of the <parameter>man.charmap.enabled</parameter>
-parameter is non-zero, a "character map" is used to substitute certain
-Unicode symbols and special characters with appropriate roff/groff
-equivalents, just before writing each man-page file to the
-filesystem. If instead the value of
-<parameter>man.charmap.enabled</parameter> is zero, Unicode characters
-are passed through "as is".</para>
-
-<refsection><info><title>Details</title></info>
-
-<para>For converting certain Unicode symbols and special characters in
-UTF-8 or UTF-16 encoded XML source to appropriate groff/roff
-equivalents in man-page output, the DocBook XSL Stylesheets
-distribution includes a <link xlink:href="http://docbook.sourceforge.net/snapshot/xsl/manpages/charmap.groff.xsl">roff character map</link> that is compliant with the <link xlink:href="http://www.w3.org/TR/xslt20/#character-maps">XSLT character
-map</link> format as detailed in the XSLT 2.0 specification. The map
-contains more than 800 character mappings and can be considered the
-standard roff character map for the distribution.</para>
-
-<para>You can use the <parameter>man.charmap.uri</parameter>
-parameter to specify a URI for the location for an alternate roff
-character map to use in place of the standard roff character map
-provided in the distribution.</para>
-
-<para>You can also use a subset of a character map. For details,
-see the <parameter>man.charmap.use.subset</parameter>,
-<parameter>man.charmap.subset.profile</parameter>, and
-<parameter>man.charmap.subset.profile.english</parameter>
-parameters.</para>
-
-</refsection>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="man.charmap.uri">
-<refmeta>
-<refentrytitle>man.charmap.uri</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">uri</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>man.charmap.uri</refname>
-<refpurpose>URI for custom roff character map</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="man.charmap.uri.frag">
-&lt;xsl:param name="man.charmap.uri"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>For converting certain Unicode symbols and special characters in
-UTF-8 or UTF-16 encoded XML source to appropriate groff/roff
-equivalents in man-page output, the DocBook XSL Stylesheets
-distribution includes an <link xlink:href="http://www.w3.org/TR/xslt20/#character-maps">XSLT character
-map</link>. That character map can be considered the standard roff
-character map for the distribution.</para>
-
-<para>If the value of the <parameter>man.charmap.uri</parameter>
-parameter is non-empty, that value is used as the URI for the location
-for an alternate roff character map to use in place of the standard
-roff character map provided in the distribution.</para>
-
-<warning>
-<para>Do not set a value for <parameter>man.charmap.uri</parameter>
-unless you have a custom roff character map that differs from the
-standard one provided in the distribution.</para>
-</warning>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="man.charmap.use.subset">
-<refmeta>
-<refentrytitle>man.charmap.use.subset</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>man.charmap.use.subset</refname>
-<refpurpose>Use subset of character map instead of full map?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="man.charmap.use.subset.frag">
-&lt;xsl:param name="man.charmap.use.subset" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If the value of the
-<parameter>man.charmap.use.subset</parameter> parameter is non-zero,
-a subset of the roff character map is used instead of the full roff
-character map. The profile of the subset used is determined either
-by the value of the
-<parameter>man.charmap.subset.profile</parameter>
-parameter (if the source is not in English) or the
-<parameter>man.charmap.subset.profile.english</parameter>
-parameter (if the source is in English).</para>
-
-<note>
-  <para>You may want to experiment with setting a non-zero value of
-  <parameter>man.charmap.use.subset</parameter>, so that the full
-  character map is used. Depending on which XSLT engine you run,
-  setting a non-zero value for
-  <parameter>man.charmap.use.subset</parameter> may significantly
-  increase the time needed to process your documents. Or it may
-  not. For example, if you set it and run it with xsltproc, it seems
-  to dramatically increase processing time; on the other hand, if you
-  set it and run it with Saxon, it does not seem to increase
-  processing time nearly as much.</para>
-
-  <para>If processing time is not a important concern and/or you can
-  tolerate the increase in processing time imposed by using the full
-  character map, set <parameter>man.charmap.use.subset</parameter> to
-  zero.</para>
-</note>
-
-<refsection><info><title>Details</title></info>
-
-<para>For converting certain Unicode symbols and special characters in
-UTF-8 or UTF-16 encoded XML source to appropriate groff/roff
-equivalents in man-page output, the DocBook XSL Stylesheets
-distribution includes a <link xlink:href="http://docbook.sourceforge.net/snapshot/xsl/manpages/charmap.groff.xsl">roff character map</link> that is compliant with the <link xlink:href="http://www.w3.org/TR/xslt20/#character-maps">XSLT character
-map</link> format as detailed in the XSLT 2.0 specification. The map
-contains more than 800 character mappings and can be considered the
-standard roff character map for the distribution.</para>
-
-<note>
-<para>You can use the <parameter>man.charmap.uri</parameter>
-parameter to specify a URI for the location for an alternate roff
-character map to use in place of the standard roff character map
-provided in the distribution.</para>
-</note>
-
-<para>Because it is not terrifically efficient to use the standard
-800-character character map in full -- and for most (or all) users,
-never necessary to use it in full -- the DocBook XSL Stylesheets
-support a mechanism for using, within any given character map, a
-subset of character mappings instead of the full set. You can use the
-<parameter>man.charmap.subset.profile</parameter> or
-<parameter>man.charmap.subset.profile.english</parameter>
-parameter to tune the profile of that subset to use.</para>
-
-</refsection>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="man.charmap.subset.profile">
-<refmeta>
-<refentrytitle>man.charmap.subset.profile</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>man.charmap.subset.profile</refname>
-<refpurpose>Profile of character map subset</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="man.charmap.subset.profile.frag">
-&lt;xsl:param name="man.charmap.subset.profile"&gt;
-@*[local-name() = 'block'] = 'Miscellaneous Technical' or
-(@*[local-name() = 'block'] = 'C1 Controls And Latin-1 Supplement (Latin-1 Supplement)' and
- (@*[local-name() = 'class'] = 'symbols' or
-  @*[local-name() = 'class'] = 'letters')
-) or
-@*[local-name() = 'block'] = 'Latin Extended-A'
-or
-(@*[local-name() = 'block'] = 'General Punctuation' and
- (@*[local-name() = 'class'] = 'spaces' or
-  @*[local-name() = 'class'] = 'dashes' or
-  @*[local-name() = 'class'] = 'quotes' or
-  @*[local-name() = 'class'] = 'bullets'
- )
-) or
-@*[local-name() = 'name'] = 'HORIZONTAL ELLIPSIS' or
-@*[local-name() = 'name'] = 'WORD JOINER' or
-@*[local-name() = 'name'] = 'SERVICE MARK' or
-@*[local-name() = 'name'] = 'TRADE MARK SIGN' or
-@*[local-name() = 'name'] = 'ZERO WIDTH NO-BREAK SPACE'
-&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If the value of the
-<parameter>man.charmap.use.subset</parameter> parameter is non-zero,
-and your DocBook source is not written in English (that
-  is, if the <tag class="attribute">lang</tag> or <tag class="attribute">xml:lang</tag> attribute on the root element
-  in your DocBook source or on the first <tag>refentry</tag>
-  element in your source has a value other than
-  <literal>en</literal>), then the character-map subset specified
-  by the <parameter>man.charmap.subset.profile</parameter>
-  parameter is used instead of the full roff character map.</para>
-
-<para>Otherwise, if the <tag class="attribute">lang</tag> or <tag class="attribute">xml:lang</tag> attribute on the root
-  element in your DocBook
-  source or on the first <tag>refentry</tag> element in your source
-  has the value <literal>en</literal> or if it has no <tag class="attribute">lang</tag> or <tag class="attribute">xml:lang</tag> attribute, then the character-map
-  subset specified by the
-  <parameter>man.charmap.subset.profile.english</parameter>
-  parameter is used instead of
-  <parameter>man.charmap.subset.profile</parameter>.</para>
-
-<para>The difference between the two subsets is that
-  <parameter>man.charmap.subset.profile</parameter> provides
-  mappings for characters in Western European languages that are
-  not part of the Roman (English) alphabet (ASCII character set).</para>
-
-<para>The value of <parameter>man.charmap.subset.profile</parameter>
-is a string representing an XPath expression that matches attribute
-names and values for <tag namespace="http://docbook.sf.net/xmlns/unichar/1.0">output-character</tag>
-elements in the character map.</para>
-
-<para>The attributes supported in the <link xlink:href="http://docbook.sourceforge.net/snapshot/xsl/manpages/charmap.groff.xsl">standard roff character map included in the distribution</link> are:
-<variablelist>
-  <varlistentry>
-    <term>character</term>
-    <listitem>
-      <simpara>a raw Unicode character or numeric Unicode
-      character-entity value (either in decimal or hex); all
-      characters have this attribute</simpara>
-    </listitem>
-  </varlistentry>
-  <varlistentry>
-    <term>name</term>
-    <listitem>
-      <simpara>a standard full/long ISO/Unicode character name (e.g.,
-      "OHM SIGN"); all characters have this attribute</simpara>
-    </listitem>
-  </varlistentry>
-  <varlistentry>
-    <term>block</term>
-    <listitem>
-      <simpara>a standard Unicode "block" name (e.g., "General
-      Punctuation"); all characters have this attribute. For the full
-      list of Unicode block names supported in the standard roff
-      character map, see <xref linkend="BlocksAndClasses"/>.</simpara>
-    </listitem>
-  </varlistentry>
-  <varlistentry>
-    <term>class</term>
-    <listitem>
-      <simpara>a class of characters (e.g., "spaces"). Not all
-      characters have this attribute; currently, it is used only with
-      certain characters within the "C1 Controls And Latin-1
-      Supplement" and "General Punctuation" blocks. For details, see
-      <xref linkend="BlocksAndClasses"/>.</simpara>
-    </listitem>
-  </varlistentry>
-  <varlistentry>
-    <term>entity</term>
-    <listitem>
-      <simpara>an ISO entity name (e.g., "ohm"); not all characters
-      have this attribute, because not all characters have ISO entity
-      names; for example, of the 800 or so characters in the standard
-      roff character map included in the distribution, only around 300
-      have ISO entity names.
-      </simpara>
-    </listitem>
-  </varlistentry>
-  <varlistentry>
-    <term>string</term>
-    <listitem>
-      <simpara>a string representing an roff/groff escape-code (with
-      "@esc@" used in place of the backslash), or a simple ASCII
-      string; all characters in the roff character map have this
-      attribute</simpara>
-    </listitem>
-  </varlistentry>
-</variablelist>
-</para>
-<para>The value of <parameter>man.charmap.subset.profile</parameter>
-is evaluated as an XPath expression at run-time to select a portion of
-the roff character map to use. You can tune the subset used by adding
-or removing parts. For example, if you need to use a wide range of
-mathematical operators in a document, and you want to have them
-converted into roff markup properly, you might add the following:
-
-<literallayout class="monospaced">  @*[local-name() = 'block'] ='MathematicalOperators' </literallayout>
-
-That will cause a additional set of around 67 additional "math"
-characters to be converted into roff markup. </para>
-
-<note>
-<para>Depending on which XSLT engine you use, either the EXSLT
-<function>dyn:evaluate</function> extension function (for xsltproc or
-Xalan) or <function>saxon:evaluate</function> extension function (for
-Saxon) are used to dynamically evaluate the value of
-<parameter>man.charmap.subset.profile</parameter> at run-time. If you
-don't use xsltproc, Saxon, Xalan -- or some other XSLT engine that
-supports <function>dyn:evaluate</function> -- you must either set the
-value of the <parameter>man.charmap.use.subset</parameter> parameter
-to zero and process your documents using the full character map
-instead, or set the value of the
-<parameter>man.charmap.enabled</parameter> parameter to zero instead
-(so that character-map processing is disabled completely.</para>
-</note>
-
-<para>An alternative to using
-<parameter>man.charmap.subset.profile</parameter> is to create your
-own custom character map, and set the value of
-<parameter>man.charmap.uri</parameter> to the URI/filename for
-that. If you use a custom character map, you will probably want to
-include in it just the characters you want to use, and so you will
-most likely also want to set the value of
-<parameter>man.charmap.use.subset</parameter> to zero.</para>
-<para>You can create a
-custom character map by making a copy of the <link xlink:href="http://docbook.sourceforge.net/snapshot/xsl/manpages/charmap.groff.xsl">standard roff character map</link> provided in the distribution, and
-then adding to, changing, and/or deleting from that.</para>
-
-<caution>
-<para>If you author your DocBook XML source in UTF-8 or UTF-16
-encoding and aren't sure what OSes or environments your man-page
-output might end up being viewed on, and not sure what version of
-nroff/groff those environments might have, you should be careful about
-what Unicode symbols and special characters you use in your source and
-what parts you add to the value of
-<parameter>man.charmap.subset.profile</parameter>.</para>
-<para>Many of the escape codes used are specific to groff and using
-them may not provide the expected output on an OS or environment that
-uses nroff instead of groff.</para>
-<para>On the other hand, if you intend for your man-page output to be
-viewed only on modern systems (for example, GNU/Linux systems, FreeBSD
-systems, or Cygwin environments) that have a good, up-to-date groff,
-then you can safely include a wide range of Unicode symbols and
-special characters in your UTF-8 or UTF-16 encoded DocBook XML source
-and add any of the supported Unicode block names to the value of
-<parameter>man.charmap.subset.profile</parameter>.</para>
-</caution>
-
-
-<para>For other details, see the documentation for the
-<parameter>man.charmap.use.subset</parameter> parameter.</para>
-
-<refsection id="BlocksAndClasses"><info><title>Supported Unicode block names and "class" values</title></info>
-  
-
-  <para>Below is the full list of Unicode block names and "class"
-  values supported in the standard roff stylesheet provided in the
-  distribution, along with a description of which codepoints from the
-  Unicode range corresponding to that block name or block/class
-  combination are supported.</para>
-
-  <itemizedlist>
-    <listitem>
-      <para><link xlink:href="http://zvon.org/other/charSearch/PHP/search.php?searchType=103&amp;id=C1%20Controls%20and%20Latin-1%20Supplement%20(Latin-1%20Supplement)">C1 Controls And Latin-1 Supplement (Latin-1 Supplement)</link> (x00a0 to x00ff)
-      <itemizedlist><info><title>class values</title></info>
-        
-        <listitem>
-          <para>symbols</para>
-        </listitem>
-        <listitem>
-          <para>letters</para>
-        </listitem>
-      </itemizedlist></para>
-    </listitem>
-    <listitem>
-      <para><link xlink:href="http://zvon.org/other/charSearch/PHP/search.php?searchType=103&amp;id=Latin%20Extended-A">Latin Extended-A</link> (x0100 to x017f, partial)</para>
-    </listitem>
-    <listitem>
-      <para><link xlink:href="http://zvon.org/other/charSearch/PHP/search.php?searchType=103&amp;id=Spacing%20Modifier%20Letters">Spacing Modifier Letters</link> (x02b0 to x02ee, partial)</para>
-    </listitem>
-    <listitem>
-      <para><link xlink:href="http://zvon.org/other/charSearch/PHP/search.php?searchType=103&amp;id=Greek%20and%20Coptic">Greek and Coptic</link> (x0370 to x03ff, partial)</para>
-    </listitem>
-    <listitem>
-      <para><link xlink:href="http://zvon.org/other/charSearch/PHP/search.php?searchType=103&amp;id=General%20Punctuation">General Punctuation</link> (x2000 to x206f, partial)
-      <itemizedlist><info><title>class values</title></info>
-        
-        <listitem>
-          <para><link xlink:href="http://zvon.org/other/charSearch/PHP/search.php?searchType=103&amp;start=8192&amp;end=8203">spaces</link></para>
-        </listitem>
-        <listitem>
-          <para><link xlink:href="http://zvon.org/other/charSearch/PHP/search.php?searchType=103&amp;start=8208&amp;end=8213">dashes</link></para>
-        </listitem>
-        <listitem>
-          <para>quotes</para>
-        </listitem>
-        <listitem>
-          <para>daggers</para>
-        </listitem>
-        <listitem>
-          <para>bullets</para>
-        </listitem>
-        <listitem>
-          <para>leaders</para>
-        </listitem>
-        <listitem>
-          <para>primes</para>
-        </listitem>
-      </itemizedlist>
-      </para>
-    </listitem>
-    <listitem>
-      <para><link xlink:href="http://zvon.org/other/charSearch/PHP/search.php?searchType=103&amp;id=Superscripts%20and%20Subscripts">Superscripts and Subscripts</link> (x2070 to x209f)</para>
-    </listitem>
-    <listitem>
-      <para><link xlink:href="http://zvon.org/other/charSearch/PHP/search.php?searchType=103&amp;id=Currency%20Symbols">Currency Symbols</link> (x20a0 to x20b1)</para>
-    </listitem>
-    <listitem>
-      <para><link xlink:href="http://zvon.org/other/charSearch/PHP/search.php?searchType=103&amp;id=Letterlike%20Symbols">Letterlike Symbols</link> (x2100 to x214b)</para>
-    </listitem>
-    <listitem>
-      <para><link xlink:href="http://zvon.org/other/charSearch/PHP/search.php?searchType=103&amp;id=Number%20Forms">Number Forms</link> (x2150 to x218f)</para>
-    </listitem>
-    <listitem>
-      <para><link xlink:href="http://zvon.org/other/charSearch/PHP/search.php?searchType=103&amp;id=Arrows">Arrows</link> (x2190 to x21ff, partial)</para>
-    </listitem>
-    <listitem>
-      <para><link xlink:href="http://zvon.org/other/charSearch/PHP/search.php?searchType=103&amp;id=Mathematical%20Operators">Mathematical Operators</link> (x2200 to x22ff, partial)</para>
-    </listitem>
-    <listitem>
-      <para><link xlink:href="http://zvon.org/other/charSearch/PHP/search.php?searchType=103&amp;id=Control%20Pictures">Control Pictures</link> (x2400 to x243f)</para>
-    </listitem>
-    <listitem>
-      <para><link xlink:href="http://zvon.org/other/charSearch/PHP/search.php?searchType=103&amp;id=Enclosed%20Alphanumerics">Enclosed Alphanumerics</link> (x2460 to x24ff)</para>
-    </listitem>
-    <listitem>
-      <para><link xlink:href="http://zvon.org/other/charSearch/PHP/search.php?searchType=103&amp;id=Geometric%20Shapes">Geometric Shapes</link> (x25a0 to x25f7, partial)</para>
-    </listitem>
-    <listitem>
-      <para><link xlink:href="http://zvon.org/other/charSearch/PHP/search.php?searchType=103&amp;id=Miscellaneous%20Symbols">Miscellaneous Symbols</link> (x2600 to x26ff, partial)</para>
-    </listitem>
-    <listitem>
-      <para><link xlink:href="http://zvon.org/other/charSearch/PHP/search.php?searchType=103&amp;id=Dingbats">Dingbats</link> (x2700 to x27be, partial)</para>
-    </listitem>
-    <listitem>
-      <para><link xlink:href="http://zvon.org/other/charSearch/PHP/search.php?searchType=103&amp;id=Alphabetic%20Presentation%20Forms">Alphabetic Presentation Forms</link> (xfb00 to xfb04 only)</para>
-    </listitem>
-  </itemizedlist>
-</refsection>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="man.charmap.subset.profile.english">
-<refmeta>
-<refentrytitle>man.charmap.subset.profile.english</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>man.charmap.subset.profile.english</refname>
-<refpurpose>Profile of character map subset</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="man.charmap.subset.profile.english.frag">
-&lt;xsl:param name="man.charmap.subset.profile.english"&gt;
-@*[local-name() = 'block'] = 'Miscellaneous Technical' or
-(@*[local-name() = 'block'] = 'C1 Controls And Latin-1 Supplement (Latin-1 Supplement)' and
- @*[local-name() = 'class'] = 'symbols')
-or
-(@*[local-name() = 'block'] = 'General Punctuation' and
- (@*[local-name() = 'class'] = 'spaces' or
-  @*[local-name() = 'class'] = 'dashes' or
-  @*[local-name() = 'class'] = 'quotes' or
-  @*[local-name() = 'class'] = 'bullets'
- )
-) or
-@*[local-name() = 'name'] = 'HORIZONTAL ELLIPSIS' or
-@*[local-name() = 'name'] = 'WORD JOINER' or
-@*[local-name() = 'name'] = 'SERVICE MARK' or
-@*[local-name() = 'name'] = 'TRADE MARK SIGN' or
-@*[local-name() = 'name'] = 'ZERO WIDTH NO-BREAK SPACE'
-&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If the value of the
-  <parameter>man.charmap.use.subset</parameter> parameter is
-  non-zero, and your DocBook source is written in English (that
-  is, if its <tag class="attribute">lang</tag> or <tag class="attribute">xml:lang</tag> attribute on the root element
-  in your DocBook source or on the first <tag>refentry</tag>
-  element in your source has the value <literal>en</literal> or if
-  it has no <tag class="attribute">lang</tag> or <tag class="attribute">xml:lang</tag> attribute), then the
-  character-map subset specified by the
-  <parameter>man.charmap.subset.profile.english</parameter>
-  parameter is used instead of the full roff character map.</para>
-
-<para>Otherwise, if the <tag class="attribute">lang</tag> or <tag class="attribute">xml:lang</tag> attribute
-  on the root element in your DocBook source or on the first
-  <tag>refentry</tag> element in your source has a value other
-  than <literal>en</literal>, then the character-map subset
-  specified by the
-  <parameter>man.charmap.subset.profile</parameter> parameter is
-  used instead of
-  <parameter>man.charmap.subset.profile.english</parameter>.</para>
-
-<para>The difference between the two subsets is that
-  <parameter>man.charmap.subset.profile</parameter> provides
-  mappings for characters in Western European languages that are
-  not part of the Roman (English) alphabet (ASCII character set).</para>
-
-<para>The value of <parameter>man.charmap.subset.profile.english</parameter>
-is a string representing an XPath expression that matches attribute
-names and values for <tag namespace="http://docbook.sf.net/xmlns/unichar/1.0">output-character</tag> elements in the character map.</para>
-
-<para>For other details, see the documentation for the
-<parameter>man.charmap.subset.profile.english</parameter> and
-<parameter>man.charmap.use.subset</parameter> parameters.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="man.string.subst.map.local.pre">
-<refmeta>
-<refentrytitle>man.string.subst.map.local.pre</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>man.string.subst.map.local.pre</refname>
-<refpurpose>Specifies &#8220;local&#8221; string substitutions</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="man.string.subst.map.local.pre.frag">
-  &lt;xsl:param name="man.string.subst.map.local.pre"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Use the <parameter>man.string.subst.map.local.pre</parameter>
-parameter to specify any &#8220;local&#8221; string substitutions to perform over
-the entire roff source for each man page <emphasis>before</emphasis>
-performing the string substitutions specified by the <parameter>man.string.subst.map</parameter> parameter.</para>
-
-<para>For details about the format of this parameter, see the
-documentation for the <parameter>man.string.subst.map</parameter>
-parameter.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="man.string.subst.map">
-<refmeta>
-<refentrytitle>man.string.subst.map</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">rtf</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>man.string.subst.map</refname>
-<refpurpose>Specifies a set of string substitutions</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="man.string.subst.map.frag">
-&lt;xsl:param name="man.string.subst.map"&gt;
-
-  &lt;!-- * remove no-break marker at beginning of line (stylesheet artifact) --&gt; 
-  &lt;ss:substitution oldstring="&#9618;&#9600;" newstring="&#9618;"&gt;&lt;/ss:substitution&gt;
-  &lt;!-- * replace U+2580 no-break marker (stylesheet-added) w/ no-break space --&gt;
-  &lt;ss:substitution oldstring="&#9600;" newstring="\ "&gt;&lt;/ss:substitution&gt;
-
-  &lt;!-- ==================================================================== --&gt;
-
-  &lt;!-- * squeeze multiple newlines before a roff request  --&gt;
-  &lt;ss:substitution oldstring="
-
-." newstring="
-."&gt;&lt;/ss:substitution&gt;
-  &lt;!-- * remove any .sp instances that directly precede a .PP  --&gt;
-  &lt;ss:substitution oldstring=".sp
-.PP" newstring=".PP"&gt;&lt;/ss:substitution&gt;
-  &lt;!-- * remove any .sp instances that directly follow a .PP  --&gt;
-  &lt;ss:substitution oldstring=".sp
-.sp" newstring=".sp"&gt;&lt;/ss:substitution&gt;
-  &lt;!-- * squeeze multiple .sp instances into a single .sp--&gt;
-  &lt;ss:substitution oldstring=".PP
-.sp" newstring=".PP"&gt;&lt;/ss:substitution&gt;
-  &lt;!-- * squeeze multiple newlines after start of no-fill (verbatim) env. --&gt;
-  &lt;ss:substitution oldstring=".nf
-
-" newstring=".nf
-"&gt;&lt;/ss:substitution&gt;
-  &lt;!-- * squeeze multiple newlines after REstoring margin --&gt;
-  &lt;ss:substitution oldstring=".RE
-
-" newstring=".RE
-"&gt;&lt;/ss:substitution&gt;
-  &lt;!-- * U+2591 is a marker we add before and after every Parameter in --&gt;
-  &lt;!-- * Funcprototype output --&gt;
-  &lt;ss:substitution oldstring="&#9617;" newstring=" "&gt;&lt;/ss:substitution&gt;
-  &lt;!-- * U+2592 is a marker we add for the newline before output of &lt;sbr&gt;; --&gt;
-  &lt;ss:substitution oldstring="&#9618;" newstring="
-"&gt;&lt;/ss:substitution&gt;
-  &lt;!-- * --&gt;
-  &lt;!-- * Now deal with some other characters that are added by the --&gt;
-  &lt;!-- * stylesheets during processing. --&gt;
-  &lt;!-- * --&gt;
-  &lt;!-- * bullet --&gt;
-  &lt;ss:substitution oldstring="&#8226;" newstring="\(bu"&gt;&lt;/ss:substitution&gt;
-  &lt;!-- * left double quote --&gt;
-  &lt;ss:substitution oldstring="&#8220;" newstring="\(lq"&gt;&lt;/ss:substitution&gt;
-  &lt;!-- * right double quote --&gt;
-  &lt;ss:substitution oldstring="&#8221;" newstring="\(rq"&gt;&lt;/ss:substitution&gt;
-  &lt;!-- * left single quote --&gt;
-  &lt;ss:substitution oldstring="&#8216;" newstring="\(oq"&gt;&lt;/ss:substitution&gt;
-  &lt;!-- * right single quote --&gt;
-  &lt;ss:substitution oldstring="&#8217;" newstring="\(cq"&gt;&lt;/ss:substitution&gt;
-  &lt;!-- * copyright sign --&gt;
-  &lt;ss:substitution oldstring="&#169;" newstring="\(co"&gt;&lt;/ss:substitution&gt;
-  &lt;!-- * registered sign --&gt;
-  &lt;ss:substitution oldstring="&#174;" newstring="\(rg"&gt;&lt;/ss:substitution&gt;
-  &lt;!-- * ...servicemark... --&gt;
-  &lt;!-- * There is no groff equivalent for it. --&gt;
-  &lt;ss:substitution oldstring="&#8480;" newstring="(SM)"&gt;&lt;/ss:substitution&gt;
-  &lt;!-- * ...trademark... --&gt;
-  &lt;!-- * We don't do "\(tm" because for console output, --&gt;
-  &lt;!-- * groff just renders that as "tm"; that is: --&gt;
-  &lt;!-- * --&gt;
-  &lt;!-- *   Product&amp;#x2122; -&gt; Producttm --&gt;
-  &lt;!-- * --&gt;
-  &lt;!-- * So we just make it to "(TM)" instead; thus: --&gt;
-  &lt;!-- * --&gt;
-  &lt;!-- *   Product&amp;#x2122; -&gt; Product(TM) --&gt;
-  &lt;ss:substitution oldstring="&#8482;" newstring="(TM)"&gt;&lt;/ss:substitution&gt;
-
-&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The <parameter>man.string.subst.map</parameter> parameter
-contains <link linkend="map">a map</link> that specifies a set of
-string substitutions to perform over the entire roff source for each
-man page, either just before generating final man-page output (that
-is, before writing man-page files to disk) or, if the value of the
-<parameter>man.charmap.enabled</parameter> parameter is non-zero,
-before applying the roff character map.</para>
-
-<para>You can use <parameter>man.string.subst.map</parameter> as a
-&#8220;lightweight&#8221; character map to perform &#8220;essential&#8221; substitutions --
-that is, substitutions that are <emphasis>always</emphasis> performed,
-even if the value of the <parameter>man.charmap.enabled</parameter>
-parameter is zero. For example, you can use it to replace quotation
-marks or other special characters that are generated by the DocBook
-XSL stylesheets for a particular locale setting (as opposed to those
-characters that are actually in source XML documents), or to replace
-any special characters that may be automatically generated by a
-particular customization of the DocBook XSL stylesheets.</para>
-
-<warning>
-  <para>Do you not change value of the
-  <parameter>man.string.subst.map</parameter> parameter unless you are
-  sure what you are doing. First consider adding your
-  string-substitution mappings to either or both of the following
-  parameters:
-  <variablelist>
-    <varlistentry>
-      <term><parameter>man.string.subst.map.local.pre</parameter></term>
-      <listitem><para>applied before
-      <parameter>man.string.subst.map</parameter></para></listitem>
-    </varlistentry>
-    <varlistentry>
-      <term><parameter>man.string.subst.map.local.post</parameter></term>
-      <listitem><para>applied after
-      <parameter>man.string.subst.map</parameter></para></listitem>
-    </varlistentry>
-  </variablelist>
-  By default, both of those parameters contain no
-  string substitutions. They are intended as a means for you to
-  specify your own local string-substitution mappings.</para>
-
-  <para>If you remove any of default mappings from the value of the
-  <parameter>man.string.subst.map</parameter> parameter, you are
-  likely to end up with broken output. And be very careful about adding
-  anything to it; it&#8217;s used for doing string substitution over the
-  entire roff source of each man page &#8211; it causes target strings to be
-  replaced in roff requests and escapes, not just in the visible
-  contents of the page.</para>
-
-</warning>
-
-<refsection id="map">
-  <info>
-    <title>Contents of the substitution map</title>
-  </info>
-  <para>The string-substitution map contains one or more
-  <tag>ss:substitution</tag> elements, each of which has two
-  attributes:
-  <variablelist>
-    <varlistentry>
-      <term>oldstring</term>
-      <listitem>
-        <simpara>string to replace</simpara>
-      </listitem>
-    </varlistentry>
-    <varlistentry>
-      <term>newstring</term>
-      <listitem>
-        <simpara>string with which to replace <tag class="attribute">oldstring</tag></simpara>
-      </listitem>
-    </varlistentry>
-  </variablelist>
-  It may also include XML comments (that is, delimited with
-  "<literal>&lt;!--</literal>" and "<literal>--&gt;</literal>").
-  </para>
-</refsection>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="man.string.subst.map.local.post">
-<refmeta>
-<refentrytitle>man.string.subst.map.local.post</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>man.string.subst.map.local.post</refname>
-<refpurpose>Specifies &#8220;local&#8221; string substitutions</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="man.string.subst.map.local.post.frag">
-&lt;xsl:param name="man.string.subst.map.local.post"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Use the <parameter>man.string.subst.map.local.post</parameter>
-parameter to specify any &#8220;local&#8221; string substitutions to perform over
-the entire roff source for each man page <emphasis>after</emphasis>
-performing the string substitutions specified by the <parameter>man.string.subst.map</parameter> parameter.</para>
-
-<para>For details about the format of this parameter, see the
-documentation for the <parameter>man.string.subst.map</parameter>
-parameter.</para>
-
-</refsection>
-</refentry>
-
-  </reference><reference id="refmeta" xml:base="../manpages/param.xml">
-  <title>Refentry metadata gathering</title>
-<refentry version="5.0" id="refentry.meta.get.quietly">
-<refmeta>
-<refentrytitle>refentry.meta.get.quietly</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>refentry.meta.get.quietly</refname>
-<refpurpose>Suppress notes and warnings when gathering refentry metadata?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="refentry.meta.get.quietly.frag">
-&lt;xsl:param name="refentry.meta.get.quietly" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If zero (the default), notes and warnings about &#8220;missing&#8221; markup
-are generated during gathering of refentry metadata. If non-zero, the
-metadata is gathered &#8220;quietly&#8221; -- that is, the notes and warnings are
-suppressed.</para>
-
-<tip>
-  <para>If you are processing a large amount of <tag>refentry</tag>
-  content, you may be able to speed up processing significantly by
-  setting a non-zero value for
-  <parameter>refentry.meta.get.quietly</parameter>.</para>
-</tip>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="refentry.date.profile">
-<refmeta>
-<refentrytitle>refentry.date.profile</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>refentry.date.profile</refname>
-<refpurpose>Specifies profile for refentry "date" data</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="refentry.date.profile.frag">
-&lt;xsl:param name="refentry.date.profile"&gt;
-  (($info[//date])[last()]/date)[1]|
-  (($info[//pubdate])[last()]/pubdate)[1]
-&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The value of <parameter>refentry.date.profile</parameter> is a
-string representing an XPath expression. It is evaluated at run-time
-and used only if <parameter>refentry.date.profile.enabled</parameter>
-is non-zero. Otherwise, the <tag>refentry</tag> metadata-gathering
-logic "hard coded" into the stylesheets is used.</para>
-
-<para> The <literal>man(7)</literal> man page describes this content
-as "the date of the last revision". In man pages, it is the content
-that is usually displayed in the center footer.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="refentry.date.profile.enabled">
-<refmeta>
-<refentrytitle>refentry.date.profile.enabled</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>refentry.date.profile.enabled</refname>
-<refpurpose>Enable refentry "date" profiling?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="refentry.date.profile.enabled.frag">
-&lt;xsl:param name="refentry.date.profile.enabled"&gt;0&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If the value of
-<parameter>refentry.date.profile.enabled</parameter> is non-zero, then
-during <tag>refentry</tag> metadata gathering, the info profile
-specified by the customizable
-<parameter>refentry.date.profile</parameter> parameter is used.</para>
-
-<para>If instead the value of
-<parameter>refentry.date.profile.enabled</parameter> is zero (the
-default), then "hard coded" logic within the DocBook XSL stylesheets
-is used for gathering <tag>refentry</tag> "date" data.</para>
-
-<para>If you find that the default <tag>refentry</tag>
-metadata-gathering behavior is causing incorrect "date" data to show
-up in your output, then consider setting a non-zero value for
-<parameter>refentry.date.profile.enabled</parameter> and adjusting the
-value of <parameter>refentry.date.profile</parameter> to cause correct
-data to be gathered. </para>
-
-<para>Note that the terms "source" and "date" have special meanings in
-this context. For details, see the documentation for the
-<parameter>refentry.date.profile</parameter> parameter.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="refentry.manual.profile">
-<refmeta>
-<refentrytitle>refentry.manual.profile</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>refentry.manual.profile</refname>
-<refpurpose>Specifies profile for refentry "manual" data</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="refentry.manual.profile.frag">
-&lt;xsl:param name="refentry.manual.profile"&gt;
-  (($info[//title])[last()]/title)[1]|
-  ../title/node()
-&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The value of <parameter>refentry.manual.profile</parameter> is
-a string representing an XPath expression. It is evaluated at
-run-time and used only if
-<parameter>refentry.manual.profile.enabled</parameter> is
-non-zero. Otherwise, the <tag>refentry</tag> metadata-gathering logic
-"hard coded" into the stylesheets is used.</para>
-
-<para>In man pages, this content is usually displayed in the middle of
-the header of the page. The <literal>man(7)</literal> man page
-describes this as "the title of the manual (e.g., <citetitle>Linux
-Programmer's Manual</citetitle>)". Here are some examples from
-existing man pages:
-<itemizedlist>
-  <listitem>
-    <para><citetitle>dpkg utilities</citetitle>
-    (<command>dpkg-name</command>)</para>
-  </listitem>
-  <listitem>
-    <para><citetitle>User Contributed Perl Documentation</citetitle>
-    (<command>GET</command>)</para>
-  </listitem>
-  <listitem>
-    <para><citetitle>GNU Development Tools</citetitle>
-    (<command>ld</command>)</para>
-  </listitem>
-  <listitem>
-    <para><citetitle>Emperor Norton Utilities</citetitle>
-    (<command>ddate</command>)</para>
-  </listitem>
-  <listitem>
-    <para><citetitle>Debian GNU/Linux manual</citetitle>
-    (<command>faked</command>)</para>
-  </listitem>
-  <listitem>
-    <para><citetitle>GIMP Manual Pages</citetitle>
-    (<command>gimp</command>)</para>
-  </listitem>
-  <listitem>
-    <para><citetitle>KDOC Documentation System</citetitle>
-    (<command>qt2kdoc</command>)</para>
-  </listitem>
-</itemizedlist>
-</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="refentry.manual.profile.enabled">
-<refmeta>
-<refentrytitle>refentry.manual.profile.enabled</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>refentry.manual.profile.enabled</refname>
-<refpurpose>Enable refentry "manual" profiling?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="refentry.manual.profile.enabled.frag">
-&lt;xsl:param name="refentry.manual.profile.enabled"&gt;0&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If the value of
-<parameter>refentry.manual.profile.enabled</parameter> is
-non-zero, then during <tag>refentry</tag> metadata gathering, the info
-profile specified by the customizable
-<parameter>refentry.manual.profile</parameter> parameter is
-used.</para>
-
-<para>If instead the value of
-<parameter>refentry.manual.profile.enabled</parameter> is zero (the
-default), then "hard coded" logic within the DocBook XSL stylesheets
-is used for gathering <tag>refentry</tag> "manual" data.</para>
-
-<para>If you find that the default <tag>refentry</tag>
-metadata-gathering behavior is causing incorrect "manual" data to show
-up in your output, then consider setting a non-zero value for
-<parameter>refentry.manual.profile.enabled</parameter> and adjusting
-the value of <parameter>refentry.manual.profile</parameter> to cause
-correct data to be gathered. </para>
-
-<para>Note that the term "manual" has a special meanings in this
-context. For details, see the documentation for the
-<parameter>refentry.manual.profile</parameter> parameter.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="refentry.source.name.suppress">
-<refmeta>
-<refentrytitle>refentry.source.name.suppress</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>refentry.source.name.suppress</refname>
-<refpurpose>Suppress "name" part of refentry "source" contents?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="refentry.source.name.suppress.frag">
-&lt;xsl:param name="refentry.source.name.suppress"&gt;0&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If the value of
-<parameter>refentry.source.name.suppress</parameter> is non-zero, then
-during <tag>refentry</tag> metadata gathering, no "source name" data
-is added to the <tag>refentry</tag> "source" contents. Instead (unless
-<parameter>refentry.version.suppress</parameter> is also non-zero),
-only "version" data is added to the "source" contents.</para>
-
-<para>If you find that the <tag>refentry</tag> metadata gathering
-mechanism is causing unwanted "source name" data to show up in your
-output -- for example, in the footer (or possibly header) of a man
-page -- then you might consider setting a non-zero value for
-<parameter>refentry.source.name.suppress</parameter>.</para>
-
-<para>Note that the terms "source", "source name", and "version" have
-special meanings in this context. For details, see the documentation
-for the <parameter>refentry.source.name.profile</parameter>
-parameter.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="refentry.source.name.profile">
-<refmeta>
-<refentrytitle>refentry.source.name.profile</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>refentry.source.name.profile</refname>
-<refpurpose>Specifies profile for refentry "source name" data</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="refentry.source.name.profile.frag">
-&lt;xsl:param name="refentry.source.name.profile"&gt;
-  (($info[//productname])[last()]/productname)[1]|
-  (($info[//corpname])[last()]/corpname)[1]|
-  (($info[//corpcredit])[last()]/corpcredit)[1]|
-  (($info[//corpauthor])[last()]/corpauthor)[1]|
-  (($info[//orgname])[last()]/orgname)[1]|
-  (($info[//publishername])[last()]/publishername)[1]
-&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The value of <parameter>refentry.source.name.profile</parameter>
-is a string representing an XPath expression. It is evaluated at
-run-time and used only if
-<parameter>refentry.source.name.profile.enabled</parameter> is
-non-zero. Otherwise, the <tag>refentry</tag> metadata-gathering logic
-"hard coded" into the stylesheets is used.</para>
-
-<para>A "source name" is one part of a (potentially) two-part
-<replaceable>Name</replaceable>&#160;<replaceable>Version</replaceable>
-"source" field. In man pages, it is usually displayed in the left
-footer of the page. It typically indicates the software system or
-product that the item documented in the man page belongs to. The
-<literal>man(7)</literal> man page describes it as "the source of
-the command", and provides the following examples:
-<itemizedlist>
-  <listitem>
-    <para>For binaries, use something like: GNU, NET-2, SLS
-    Distribution, MCC Distribution.</para>
-  </listitem>
-  <listitem>
-    <para>For system calls, use the version of the kernel that you
-    are currently looking at: Linux 0.99.11.</para>
-  </listitem>
-  <listitem>
-    <para>For library calls, use the source of the function: GNU, BSD
-    4.3, Linux DLL 4.4.1.</para>
-  </listitem>
-</itemizedlist>
-</para>
-
-<para>In practice, there are many pages that simply have a Version
-number in the "source" field. So, it looks like what we have is a
-two-part field,
-<replaceable>Name</replaceable>&#160;<replaceable>Version</replaceable>,
-where:
-<variablelist>
-  <varlistentry>
-    <term>Name</term>
-    <listitem>
-      <para>product name (e.g., BSD) or org. name (e.g., GNU)</para>
-    </listitem>
-  </varlistentry>
-  <varlistentry>
-    <term>Version</term>
-    <listitem>
-      <para>version number</para>
-    </listitem>
-  </varlistentry>
-</variablelist>
-Each part is optional. If the <replaceable>Name</replaceable> is a
-product name, then the <replaceable>Version</replaceable> is probably
-the version of the product. Or there may be no
-<replaceable>Name</replaceable>, in which case, if there is a
-<replaceable>Version</replaceable>, it is probably the version
-of the item itself, not the product it is part of. Or, if the
-<replaceable>Name</replaceable> is an organization name, then there
-probably will be no <replaceable>Version</replaceable>.</para>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="refentry.source.name.profile.enabled">
-<refmeta>
-<refentrytitle>refentry.source.name.profile.enabled</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>refentry.source.name.profile.enabled</refname>
-<refpurpose>Enable refentry "source name" profiling?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="refentry.source.name.profile.enabled.frag">
-&lt;xsl:param name="refentry.source.name.profile.enabled"&gt;0&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If the value of
-<parameter>refentry.source.name.profile.enabled</parameter> is
-non-zero, then during <tag>refentry</tag> metadata gathering, the info
-profile specified by the customizable
-<parameter>refentry.source.name.profile</parameter> parameter is
-used.</para>
-
-<para>If instead the value of
-<parameter>refentry.source.name.profile.enabled</parameter> is zero (the
-default), then "hard coded" logic within the DocBook XSL stylesheets
-is used for gathering <tag>refentry</tag> "source name" data.</para>
-
-<para>If you find that the default <tag>refentry</tag>
-metadata-gathering behavior is causing incorrect "source name" data to
-show up in your output, then consider setting a non-zero value for
-<parameter>refentry.source.name.profile.enabled</parameter> and
-adjusting the value of
-<parameter>refentry.source.name.profile</parameter> to cause correct
-data to be gathered. </para>
-
-<para>Note that the terms "source" and "source name" have special
-meanings in this context. For details, see the documentation for the
-<parameter>refentry.source.name.profile</parameter> parameter.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="refentry.version.suppress">
-<refmeta>
-<refentrytitle>refentry.version.suppress</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>refentry.version.suppress</refname>
-<refpurpose>Suppress "version" part of refentry "source" contents?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="refentry.version.suppress.frag">
-&lt;xsl:param name="refentry.version.suppress"&gt;0&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If the value of <parameter>refentry.version.suppress</parameter>
-is non-zero, then during <tag>refentry</tag> metadata gathering, no
-"version" data is added to the <tag>refentry</tag> "source"
-contents. Instead (unless
-<parameter>refentry.source.name.suppress</parameter> is also
-non-zero), only "source name" data is added to the "source"
-contents.</para>
-
-<para>If you find that the <tag>refentry</tag> metadata gathering
-mechanism is causing unwanted "version" data to show up in your output
--- for example, in the footer (or possibly header) of a man page --
-then you might consider setting a non-zero value for
-<parameter>refentry.version.suppress</parameter>.</para>
-
-<para>Note that the terms "source", "source name", and "version" have
-special meanings in this context. For details, see the documentation
-for the <parameter>refentry.source.name.profile</parameter>
-parameter.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="refentry.version.profile">
-<refmeta>
-<refentrytitle>refentry.version.profile</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>refentry.version.profile</refname>
-<refpurpose>Specifies profile for refentry "version" data</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="refentry.version.profile.frag">
-&lt;xsl:param name="refentry.version.profile"&gt;
-  (($info[//productnumber])[last()]/productnumber)[1]|
-  (($info[//edition])[last()]/edition)[1]|
-  (($info[//releaseinfo])[last()]/releaseinfo)[1]
-&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The value of <parameter>refentry.version.profile</parameter> is
-a string representing an XPath expression. It is evaluated at
-run-time and used only if
-<parameter>refentry.version.profile.enabled</parameter> is
-non-zero. Otherwise, the <tag>refentry</tag> metadata-gathering logic
-"hard coded" into the stylesheets is used.</para>
-
-<para>A "source.name" is one part of a (potentially) two-part
-<replaceable>Name</replaceable>&#160;<replaceable>Version</replaceable>
-"source" field. For more details, see the documentation for the
-<parameter>refentry.source.name.profile</parameter> parameter.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="refentry.version.profile.enabled">
-<refmeta>
-<refentrytitle>refentry.version.profile.enabled</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>refentry.version.profile.enabled</refname>
-<refpurpose>Enable refentry "version" profiling?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="refentry.version.profile.enabled.frag">
-&lt;xsl:param name="refentry.version.profile.enabled"&gt;0&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If the value of
-<parameter>refentry.version.profile.enabled</parameter> is
-non-zero, then during <tag>refentry</tag> metadata gathering, the info
-profile specified by the customizable
-<parameter>refentry.version.profile</parameter> parameter is
-used.</para>
-
-<para>If instead the value of
-<parameter>refentry.version.profile.enabled</parameter> is zero (the
-default), then "hard coded" logic within the DocBook XSL stylesheets
-is used for gathering <tag>refentry</tag> "version" data.</para>
-
-<para>If you find that the default <tag>refentry</tag>
-metadata-gathering behavior is causing incorrect "version" data to show
-up in your output, then consider setting a non-zero value for
-<parameter>refentry.version.profile.enabled</parameter> and adjusting
-the value of <parameter>refentry.version.profile</parameter> to cause
-correct data to be gathered. </para>
-
-<para>Note that the terms "source" and "version" have special
-meanings in this context. For details, see the documentation for the
-<parameter>refentry.version.profile</parameter> parameter.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="refentry.manual.fallback.profile">
-<refmeta>
-<refentrytitle>refentry.manual.fallback.profile</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>refentry.manual.fallback.profile</refname>
-<refpurpose>Specifies profile of "fallback" for refentry "manual" data</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="refentry.manual.fallback.profile.frag">
-&lt;xsl:param name="refentry.manual.fallback.profile"&gt;
-refmeta/refmiscinfo[not(@class = 'date')][1]/node()&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The value of
-<parameter>refentry.manual.fallback.profile</parameter> is a string
-representing an XPath expression. It is evaluated at run-time and
-used only if no "manual" data can be found by other means (that is,
-either using the <tag>refentry</tag> metadata-gathering logic "hard
-coded" in the stylesheets, or the value of
-<parameter>refentry.manual.profile</parameter>, if it is
-enabled).</para>
-
-<important>
-<para>Depending on which XSLT engine you run, either the EXSLT
-<function>dyn:evaluate</function> extension function (for xsltproc or
-Xalan) or <function>saxon:evaluate</function> extension function (for
-Saxon) are used to dynamically evaluate the value of
-<parameter>refentry.manual.fallback.profile</parameter> at
-run-time. If you don't use xsltproc, Saxon, Xalan -- or some other
-XSLT engine that supports <function>dyn:evaluate</function> -- you
-must manually disable fallback processing by setting an empty value
-for the <parameter>refentry.manual.fallback.profile</parameter>
-parameter.</para>
-</important>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="refentry.source.fallback.profile">
-<refmeta>
-<refentrytitle>refentry.source.fallback.profile</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>refentry.source.fallback.profile</refname>
-<refpurpose>Specifies profile of "fallback" for refentry "source" data</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="refentry.source.fallback.profile.frag">
-&lt;xsl:param name="refentry.source.fallback.profile"&gt;
-refmeta/refmiscinfo[not(@class = 'date')][1]/node()&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The value of
-<parameter>refentry.source.fallback.profile</parameter> is a string
-representing an XPath expression. It is evaluated at run-time and used
-only if no "source" data can be found by other means (that is, either
-using the <tag>refentry</tag> metadata-gathering logic "hard coded" in
-the stylesheets, or the value of the
-<parameter>refentry.source.name.profile</parameter> and
-<parameter>refentry.version.profile</parameter> parameters, if those
-are enabled).</para>
-
-<important>
-<para>Depending on which XSLT engine you run, either the EXSLT
-<function>dyn:evaluate</function> extension function (for xsltproc or
-Xalan) or <function>saxon:evaluate</function> extension function (for
-Saxon) are used to dynamically evaluate the value of
-<parameter>refentry.source.fallback.profile</parameter> at
-run-time. If you don't use xsltproc, Saxon, Xalan -- or some other
-XSLT engine that supports <function>dyn:evaluate</function> -- you
-must manually disable fallback processing by setting an empty value
-for the <parameter>refentry.source.fallback.profile</parameter>
-parameter.</para>
-</important>
-
-</refsection>
-</refentry>
-
-  </reference><reference id="th" xml:base="../manpages/param.xml">
-  <title>Page header/footer</title>
-<refentry version="5.0" id="man.th.extra1.suppress">
-<refmeta>
-<refentrytitle>man.th.extra1.suppress</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>man.th.extra1.suppress</refname>
-<refpurpose>Suppress extra1 part of header/footer?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="man.th.extra1.suppress.frag">
-&lt;xsl:param name="man.th.extra1.suppress"&gt;0&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If the value of <parameter>man.th.extra1.suppress</parameter> is
-non-zero, then the <literal>extra1</literal> part of the
-<literal>.TH</literal> title line header/footer is suppressed.</para>
-
-<para>The content of the <literal>extra1</literal> field is almost
-always displayed in the center footer of the page and is, universally,
-a date.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="man.th.extra2.suppress">
-<refmeta>
-<refentrytitle>man.th.extra2.suppress</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>man.th.extra2.suppress</refname>
-<refpurpose>Suppress extra2 part of header/footer?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="man.th.extra2.suppress.frag">
-&lt;xsl:param name="man.th.extra2.suppress"&gt;0&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If the value of <parameter>man.th.extra2.suppress</parameter> is
-non-zero, then the <literal>extra2</literal> part of the
-<literal>.TH</literal> title line header/footer is suppressed.</para>
-
-<para>The content of the <literal>extra2</literal> field is usually
-displayed in the left footer of the page and is typically "source"
-data, often in the form
-<replaceable>Name</replaceable>&#160;<replaceable>Version</replaceable>;
-for example, "GTK+ 1.2" (from the <literal>gtk-options(7)</literal>
-man page).</para>
-
-<note>
-  <para>You can use the
-  <parameter>refentry.source.name.suppress</parameter> and
-  <parameter>refentry.version.suppress</parameter> parameters to
-  independently suppress the <replaceable>Name</replaceable> and
-  <replaceable>Version</replaceable> parts of the
-  <literal>extra2</literal> field.</para>
-</note>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="man.th.extra3.suppress">
-<refmeta>
-<refentrytitle>man.th.extra3.suppress</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>man.th.extra3.suppress</refname>
-<refpurpose>Suppress extra3 part of header/footer?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="man.th.extra3.suppress.frag">
-&lt;xsl:param name="man.th.extra3.suppress"&gt;0&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If the value of <parameter>man.th.extra3.suppress</parameter> is
-non-zero, then the <literal>extra3</literal> part of the
-<literal>.TH</literal> title line header/footer is
-suppressed.</para>
-
-<para>The content of the <literal>extra3</literal> field is usually
-displayed in the middle header of the page and is typically a "manual
-name"; for example, "GTK+ User's Manual" (from the
-<literal>gtk-options(7)</literal> man page).</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="man.th.title.max.length">
-<refmeta>
-<refentrytitle>man.th.title.max.length</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">integer</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>man.th.title.max.length</refname>
-<refpurpose>Maximum length of title in header/footer</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="man.th.title.max.length.frag">
-&lt;xsl:param name="man.th.title.max.length"&gt;20&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Specifies the maximum permitted length of the title part of the
-man-page <literal>.TH</literal> title line header/footer. If the title
-exceeds the maxiumum specified, it is truncated down to the maximum
-permitted length.</para>
-
-<refsection><info><title>Details</title></info>
-  
-
-<para>Every man page generated using the DocBook stylesheets has a
-title line, specified using the <literal>TH</literal> roff
-macro. Within that title line, there is always, at a minimum, a title,
-followed by a section value (representing a man "section" -- usually
-just a number).</para>
-
-<para>The title and section are displayed, together, in the visible
-header of each page. Where in the header they are displayed depends on
-OS the man page is viewed on, and on what version of nroff/groff/man
-is used for viewing the page. But, at a minimum and across all
-systems, the title and section are displayed on the right-hand column
-of the header. On many systems -- those with a modern groff, including
-Linux systems -- they are displayed twice: both in the left and right
-columns of the header.</para>
-
-<para>So if the length of the title exceeds a certain percentage of
-the column width in which the page is viewed, the left and right
-titles can end up overlapping, making them unreadable, or breaking to
-another line, which doesn't look particularly good.</para>
-
-<para>So the stylesheets provide the
-<parameter>man.th.title.max.length</parameter> parameter as a means
-for truncating titles that exceed the maximum length that can be
-viewing properly in a page header.</para>
-
-<para>The default value is reasonable but somewhat arbitrary. If you
-have pages with long titles, you may want to experiment with changing
-the value in order to achieve the correct aesthetic results.</para>
-</refsection>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="man.th.extra2.max.length">
-<refmeta>
-<refentrytitle>man.th.extra2.max.length</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">integer</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>man.th.extra2.max.length</refname>
-<refpurpose>Maximum length of extra2 in header/footer</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="man.th.extra2.max.length.frag">
-&lt;xsl:param name="man.th.extra2.max.length"&gt;30&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Specifies the maximum permitted length of the
-<literal>extra2</literal> part of the man-page part of the
-<literal>.TH</literal> title line header/footer. If the
-<literal>extra2</literal> content exceeds the maxiumum specified, it
-is truncated down to the maximum permitted length.</para>
-
-<para>The content of the <literal>extra2</literal> field is usually
-displayed in the left footer of the page and is typically "source"
-data indicating the software system or product that the item
-documented in the man page belongs to, often in the form
-<replaceable>Name</replaceable>&#160;<replaceable>Version</replaceable>;
-for example, "GTK+ 1.2" (from the <literal>gtk-options(7)</literal>
-man page).</para>
-
-<para>The default value for this parameter is reasonable but somewhat
-arbitrary. If you are processing pages with long "source" information,
-you may want to experiment with changing the value in order to achieve
-the correct aesthetic results.</para>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="man.th.extra3.max.length">
-<refmeta>
-<refentrytitle>man.th.extra3.max.length</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">integer</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>man.th.extra3.max.length</refname>
-<refpurpose>Maximum length of extra3 in header/footer</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="man.th.extra3.max.length.frag">
-&lt;xsl:param name="man.th.extra3.max.length"&gt;30&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Specifies the maximum permitted length of the
-<literal>extra3</literal> part of the man-page <literal>.TH</literal>
-title line header/footer. If the <literal>extra3</literal> content
-exceeds the maxiumum specified, it is truncated down to the maximum
-permitted length.</para>
-
-<para>The content of the <literal>extra3</literal> field is usually
-displayed in the middle header of the page and is typically a "manual
-name"; for example, "GTK+ User's Manual" (from the
-<literal>gtk-options(7)</literal> man page).</para>
-
-<para>The default value for this parameter is reasonable but somewhat
-arbitrary. If you are processing pages with long "manual names" -- or
-especially if you are processing pages that have both long "title"
-parts (command/function, etc. names) <emphasis>and</emphasis> long
-manual names -- you may want to experiment with changing the value in
-order to achieve the correct aesthetic results.</para>
-</refsection>
-</refentry>
-
-  </reference><reference id="output" xml:base="../manpages/param.xml">
-  <title>Output</title>
-<refentry version="5.0" id="man.output.manifest.enabled">
-  <refmeta>
-    <refentrytitle>man.output.manifest.enabled</refentrytitle>
-    <refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-  </refmeta>
-  <refnamediv>
-    <refname>man.output.manifest.enabled</refname>
-    <refpurpose>Generate a manifest file?</refpurpose>
-  </refnamediv>
-
-  <refsynopsisdiv>
-    <programlisting id="man.output.manifest.enabled.frag">&lt;xsl:param name="man.output.manifest.enabled" select="0"&gt;&lt;/xsl:param&gt;</programlisting>
-  </refsynopsisdiv>
-
-  <refsection><info><title>Description</title></info>
-
-    <para>If non-zero, a list of filenames for man pages generated by
-    the stylesheet transformation is written to the file named by the
-    <parameter>man.output.manifest.filename</parameter> parameter.</para>
-
-  </refsection>
-</refentry>
-
-<refentry version="5.0" id="man.output.manifest.filename">
-  <refmeta>
-    <refentrytitle>man.output.manifest.filename</refentrytitle>
-    <refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-  </refmeta>
-  <refnamediv>
-    <refname>man.output.manifest.filename</refname>
-    <refpurpose>Name of manifest file</refpurpose>
-  </refnamediv>
-
-  <refsynopsisdiv>
-    <programlisting id="man.output.manifest.filename.frag">&lt;xsl:param name="man.output.manifest.filename"&gt;MAN.MANIFEST&lt;/xsl:param&gt;</programlisting>
-  </refsynopsisdiv>
-
-  <refsection><info><title>Description</title></info>
-
-    <para>The <parameter>man.output.manifest.filename</parameter> parameter
-    specifies the name of the file to which the manpages manifest file
-    is written (if the value of the
-    <parameter>man.output.manifest.enabled</parameter> parameter is
-    non-zero).</para>
-
-  </refsection>
-</refentry>
-
-<refentry version="5.0" id="man.output.in.separate.dir">
-<refmeta>
-<refentrytitle>man.output.in.separate.dir</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>man.output.in.separate.dir</refname>
-<refpurpose>Output man-page files in separate output directory?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="man.output.in.separate.dir.frag">
-&lt;xsl:param name="man.output.in.separate.dir" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If the value of <literal>man.output.in.separate.dir</literal>
-parameter is non-zero, man-page files are output in a separate
-directory, specified by the <parameter>man.output.base.dir</parameter>
-parameter; otherwise, if the value of
-<literal>man.output.in.separate.dir</literal> is zero, man-page files
-are not output in a separate directory.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="man.output.lang.in.name.enabled">
-<refmeta>
-<refentrytitle>man.output.lang.in.name.enabled</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>man.output.lang.in.name.enabled</refname>
-<refpurpose>Include $LANG value in man-page filename/pathname?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="man.output.lang.in.name.enabled.frag">
-&lt;xsl:param name="man.output.lang.in.name.enabled" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-  <para>The <parameter>man.output.lang.in.name.enabled</parameter>
-  parameter specifies whether a <literal>$lang</literal> value is
-  included in man-page filenames and pathnames.</para>
-
-  <para>If the value of
-  <parameter>man.output.lang.in.name.enabled</parameter> is non-zero,
-  man-page files are output with the <literal>$lang</literal> value
-  included in their filenames or pathnames as follows;
-
-  <itemizedlist>
-    <listitem>
-      <para>if <parameter>man.output.subdirs.enabled</parameter> is
-      non-zero, each file is output to, e.g., a
-      <filename>man/<replaceable>$lang</replaceable>/man8/foo.8</filename>
-      pathname</para>
-    </listitem>
-    <listitem>
-      <para>if <parameter>man.output.subdirs.enabled</parameter> is
-      zero, each file is output with a
-      <literal>foo.<replaceable>$lang</replaceable>.8</literal>
-      filename</para>
-    </listitem>
-  </itemizedlist>
-  </para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="man.output.base.dir">
-<refmeta>
-<refentrytitle>man.output.base.dir</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">uri</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>man.output.base.dir</refname>
-<refpurpose>Specifies separate output directory</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="man.output.base.dir.frag">&lt;xsl:param name="man.output.base.dir"&gt;man/&lt;/xsl:param&gt;</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The <parameter>man.output.base.dir</parameter> parameter
-specifies the base directory into which man-page files are output. The
-<parameter>man.output.subdirs.enabled</parameter> parameter controls
-whether the files are output in subdirectories within the base
-directory.</para>
-
-<note>
-  <para>The values of the <parameter>man.output.base.dir</parameter>
-  and <parameter>man.output.subdirs.enabled</parameter> parameters are
-  used only if the value of
-  <parameter>man.output.in.separate.dir</parameter> parameter is
-  non-zero. If the value of the
-  <parameter>man.output.in.separate.dir</parameter> is zero, man-page
-  files are not output in a separate directory.</para>
-</note>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="man.output.subdirs.enabled">
-<refmeta>
-<refentrytitle>man.output.subdirs.enabled</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>man.output.subdirs.enabled</refname>
-<refpurpose>Output man-page files in subdirectories within base output directory?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="man.output.subdirs.enabled.frag">
-&lt;xsl:param name="man.output.subdirs.enabled" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The <parameter>man.output.subdirs.enabled</parameter> parameter
-controls whether man-pages files are output in subdirectories within
-the base directory specified by the directory specified by the
-<parameter>man.output.base.dir</parameter> parameter.</para>
-
-<note>
-  <para>The values of the <parameter>man.output.base.dir</parameter>
-  and <parameter>man.output.subdirs.enabled</parameter> parameters are
-  used only if the value of
-  <parameter>man.output.in.separate.dir</parameter> parameter is
-  non-zero. If the value of the
-  <parameter>man.output.in.separate.dir</parameter> is zero, man-page
-  files are not output in a separate directory.</para>
-</note>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="man.output.quietly">
-<refmeta>
-<refentrytitle>man.output.quietly</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>man.output.quietly</refname>
-<refpurpose>Suppress filename messages emitted when generating output?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="man.output.quietly.frag">
-&lt;xsl:param name="man.output.quietly" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If zero (the default), for each man-page file created, a message
-with the name of the file is emitted. If non-zero, the files are
-output "quietly" -- that is, the filename messages are
-suppressed.</para>
-
-<tip>
-  <para>If you are processing a large amount of <tag>refentry</tag>
-  content, you may be able to speed up processing significantly by
-  setting a non-zero value for
-  <parameter>man.output.quietly</parameter>.</para>
-</tip>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="man.output.encoding">
-<refmeta>
-<refentrytitle>man.output.encoding</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>man.output.encoding</refname>
-<refpurpose>Encoding used for man-page output</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="man.output.encoding.frag">
-&lt;xsl:param name="man.output.encoding"&gt;UTF-8&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This parameter specifies the encoding to use for files generated
-by the manpages stylesheet. Not all processors support specification
-of this parameter.</para>
-
-<important>
-  <para>If the value of the <parameter>man.charmap.enabled</parameter>
-  parameter is non-zero (the default), keeping the
-  <parameter>man.output.encoding</parameter> parameter at its default
-  value (<literal>UTF-8</literal>) or setting it to
-  <literal>UTF-16</literal> <emphasis role="bold">does not cause your
-  man pages to be output in raw UTF-8 or UTF-16</emphasis> -- because
-  any Unicode characters for which matches are found in the enabled
-  character map will be replaced with roff escape sequences before the
-  final man-page files are generated.</para>
-
-  <para>So if you want to generate "real" UTF-8 man pages, without any
-  character substitution being performed on your content, you need to
-  set <parameter>man.charmap.enabled</parameter> to zero (which will
-  completely disable character-map processing). </para>
-
-  <para>You may also need to set
-  <parameter>man.charmap.enabled</parameter> to zero if you want to
-  output man pages in an encoding other than <literal>UTF-8</literal>
-  or <literal>UTF-16</literal>. Character-map processing is based on
-  Unicode character values and may not work with other output
-  encodings.</para>
-</important>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="man.output.better.ps.enabled">
-<refmeta>
-<refentrytitle>man.output.better.ps.enabled</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>man.output.better.ps.enabled</refname>
-<refpurpose>Enable enhanced print/PostScript output?</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-<programlisting id="man.output.better.ps.enabled.frag">
-&lt;xsl:param name="man.output.better.ps.enabled"&gt;0&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-<refsection><info><title>Description</title></info>
-
-<para>If the value of the
-<parameter>man.output.better.ps.enabled</parameter> parameter is
-non-zero, certain markup is embedded in each generated man page
-such that PostScript output from the <command>man -Tps</command>
-command for that page will include a number of enhancements
-designed to improve the quality of that output.</para>
-
-<para>If <parameter>man.output.better.ps.enabled</parameter> is
-zero (the default), no such markup is embedded in generated man
-pages, and no enhancements are included in the PostScript
-output generated from those man pages by the <command>man
- -Tps</command> command.</para>
-
-<warning>
-  <para>The enhancements provided by this parameter rely on
-    features that are specific to groff (GNU troff) and that are
-    not part of &#8220;classic&#8221; AT&amp;T troff or any of its
-    derivatives. Therefore, any man pages you generate with this
-    parameter enabled will be readable only on systems on which
-    the groff (GNU troff) program is installed, such as GNU/Linux
-    systems. The pages <emphasis role="bold">will not not be
-      readable on systems on with the classic troff (AT&amp;T
-      troff) command is installed</emphasis>.</para>
-</warning>
-
-<para>The value of this parameter only affects PostScript output
-  generated from the <command>man</command> command. It has no
-  effect on output generated using the FO backend.</para>
-
-<tip>
-  <para>You can generate PostScript output for any man page by
-    running the following command:</para>
-  <programlisting>  man <replaceable>FOO</replaceable> -Tps &gt; <replaceable>FOO</replaceable>.ps</programlisting>
-  <para>You can then generate PDF output by running the following
-    command:</para>
-  <programlisting>  ps2pdf <replaceable>FOO</replaceable>.ps</programlisting>
-</tip>
-
-</refsection>
-</refentry>
-
-  </reference><reference id="other" xml:base="../manpages/param.xml">
-  <title>Other</title>
-<refentry version="5.0" id="man.table.footnotes.divider">
-<refmeta>
-<refentrytitle>man.table.footnotes.divider</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>man.table.footnotes.divider</refname>
-<refpurpose>Specifies divider string that appears before table footnotes</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="man.table.footnotes.divider.frag">
-&lt;xsl:param name="man.table.footnotes.divider"&gt;----&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>In each table that contains footenotes, the string specified by
-the <parameter>man.table.footnotes.divider</parameter> parameter is
-output before the list of footnotes for the table.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="man.subheading.divider.enabled">
-<refmeta>
-<refentrytitle>man.subheading.divider.enabled</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>man.subheading.divider.enabled</refname>
-<refpurpose>Add divider comment to roff source before/after subheadings?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="man.subheading.divider.enabled.frag">
-&lt;xsl:param name="man.subheading.divider.enabled"&gt;0&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If the value of the
-<parameter>man.subheading.divider.enabled</parameter> parameter is
-non-zero, the contents of the
-<parameter>man.subheading.divider</parameter> parameter are used to
-add a "divider" before and after subheadings in the roff
-output. <emphasis role="bold">The divider is not visisble in the
-rendered man page</emphasis>; it is added as a comment, in the source,
-simply for the purpose of increasing reability of the source.</para>
-
-<para>If <parameter>man.subheading.divider.enabled</parameter> is zero
-(the default), the subheading divider is suppressed.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="man.subheading.divider">
-<refmeta>
-<refentrytitle>man.subheading.divider</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>man.subheading.divider</refname>
-<refpurpose>Specifies string to use as divider comment before/after subheadings</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="man.subheading.divider.frag">
-&lt;xsl:param name="man.subheading.divider"&gt;========================================================================&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If the value of the
-<parameter>man.subheading.divider.enabled</parameter> parameter is
-non-zero, the contents of the
-<parameter>man.subheading.divider</parameter> parameter are used to
-add a "divider" before and after subheadings in the roff
-output. <emphasis role="bold">The divider is not visisble in the
-rendered man page</emphasis>; it is added as a comment, in the source,
-simply for the purpose of increasing reability of the source.</para>
-
-<para>If <parameter>man.subheading.divider.enabled</parameter> is zero
-(the default), the subheading divider is suppressed.</para>
-
-</refsection>
-</refentry>
-
-  </reference>
-    </part>
-    <part id="roundtrip">
-      <?dbhtml dir="roundtrip"?>
-      <?dbhtml filename="index.html"?>
-      <title xml:base="../roundtrip/param.xml">Roundtrip Parameter Reference</title>
-      <partintro id="roundtripintro">
-        
-      <para xml:base="../roundtrip/param.xml">This is reference documentation for all user-configurable
-      parameters in the DocBook &#8220;Roundtrip&#8221; Stylesheets (for
-      transforming DocBook to WordML, OpenDocument, and Apple Pages,
-      and for converting from those formats back to DocBook).</para>
-    
-      </partintro>
-      
-  
-<refentry version="5.0" id="wordml.template" xml:base="../roundtrip/param.xml">
-<refmeta>
-<refentrytitle>wordml.template</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">uri</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>wordml.template</refname>
-<refpurpose>Specify the template WordML document</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="wordml.template.frag">
-&lt;xsl:param name="wordml.template"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The <parameter>wordml.template</parameter> parameter specifies a WordML document to use as a template for the generated document.  The template document is used to define the (extensive) headers for the generated document, in particular the paragraph and character styles that are used to format the various elements.  Any content in the template document is ignored.</para>
-
-<para>A template document is used in order to allow maintenance of the paragraph and character styles to be done using Word itself, rather than these XSL stylesheets.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="pages.template" xml:base="../roundtrip/param.xml">
-<refmeta>
-<refentrytitle>pages.template</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">uri</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>pages.template</refname>
-<refpurpose>Specify the template Pages document</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="pages.template.frag">
-&lt;xsl:param name="pages.template"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>The <parameter>pages.template</parameter> parameter specifies a Pages (the Apple word processing application) document to use as a template for the generated document.  The template document is used to define the (extensive) headers for the generated document, in particular the paragraph and character styles that are used to format the various elements.  Any content in the template document is ignored.</para>
-
-<para>A template document is used in order to allow maintenance of the paragraph and character styles to be done using Pages itself, rather than these XSL stylesheets.</para>
-
-</refsection>
-</refentry>
-
-  
-    </part>
-    <part id="slides"><title>Slides Parameter Reference</title>
-      <?dbhtml dir="slides"?>
-      <?dbhtml filename="index.html"?>
-      <partintro id="slidesintro">
-        <para>This is reference documentation for all
-          user-configurable parameters in the DocBook XSL Slides
-          stylesheets (for generating HTML and PDF slide
-          presentations).</para>
-        <note>
-          <para>The Slides stylesheet for HTML output is a
-            customization layer of the DocBook XSL HTML
-            stylesheet; the Slides stylesheet for FO output is a
-            customization layer of the DocBook XSL FO stylesheet.
-            Therefore, in addition to the slides-specific
-            parameters listed in this section, you can also use a
-            number of <link xlink:href="../html">HTML stylesheet
-              parameters</link> and <link xlink:href="../fo">FO
-              stylesheet parameters</link> to control Slides
-            output.</para>
-        </note>
-      </partintro>
-      <reference id="xhtml" xml:base="../slides/xhtml/param.xml">
-  <title>XHTML: General Params</title>
-
-<refentry version="5.0" id="disable.collapsible">
-<refmeta>
-<refentrytitle>disable.collapsible</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>disable.collapsible</refname>
-<refpurpose>Specifies whether collapsible rendering is enabled</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-  <programlisting id="disable.collapsible.frag">
-    &lt;xsl:param name="disable.collapsible"&gt;0&lt;/xsl:param&gt;
-  </programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This parameter specifies whether elements marked as
-  collapsible are generated as such in the output document.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="disable.incremental">
-<refmeta>
-<refentrytitle>disable.incremental</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>disable.incremental</refname>
-<refpurpose>Specifies whether incremental rendering is enabled</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-  <programlisting id="disable.incremental.frag">
-    &lt;xsl:param name="disable.incremental"&gt;0&lt;/xsl:param&gt;
-  </programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This parameter specifies whether elements marked as
-  incremental are generated as such in the output document.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="generate.copyright">
-<refmeta>
-<refentrytitle>generate.copyright</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>generate.copyright</refname>
-<refpurpose>Specifies whether copyright is generated</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-  <programlisting id="generate.copyright.frag">
-    &lt;xsl:param name="generate.copyright"&gt;1&lt;/xsl:param&gt;
-  </programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This parameter specifies whether the copyright info is generated
-  in the footer area.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="generate.foilgroup.numbered.toc">
-<refmeta>
-<refentrytitle>generate.foilgroup.numbered.toc</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>generate.foilgroup.numbered.toc</refname>
-<refpurpose>Specifies whether foilgroups have a numbered TOC</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-  <programlisting id="generate.foilgroup.numbered.toc.frag">
-    &lt;xsl:param name="generate.foilgroup.numbered.toc"&gt;1&lt;/xsl:param&gt;
-  </programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If TOC generation is turned on, this parameter specifies
-  whether foilgroups have a numbered TOC. If disabled, TOC items
-  will be bulleted, not numbered.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="generate.foilgroup.toc">
-<refmeta>
-<refentrytitle>generate.foilgroup.toc</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>generate.foilgroup.toc</refname>
-<refpurpose>Specifies whether foilgroups have a TOC</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-  <programlisting id="generate.foilgroup.toc.frag">
-    &lt;xsl:param name="generate.foilgroup.toc"&gt;1&lt;/xsl:param&gt;
-  </programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This parameter specifies whether foilgroups will
-  contain a table of contents of the included foils.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="generate.handoutnotes">
-<refmeta>
-<refentrytitle>generate.handoutnotes</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>generate.handoutnotes</refname>
-<refpurpose>Specifies whether handoutnotes are generated</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-  <programlisting id="generate.handoutnotes.frag">
-    &lt;xsl:param name="generate.handoutnotes"&gt;0&lt;/xsl:param&gt;
-  </programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This parameter specifies whether handoutnotes shall
-  be generated to the output.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="generate.pubdate">
-<refmeta>
-<refentrytitle>generate.pubdate</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>generate.pubdate</refname>
-<refpurpose>Specifies whether the pubdate is generated</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-  <programlisting id="generate.pubdate.frag">
-    &lt;xsl:param name="generate.pubdate"&gt;1&lt;/xsl:param&gt;
-  </programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This parameter specifies whether the publication date is generated
-  in the footer area.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="generate.speakernotes">
-<refmeta>
-<refentrytitle>generate.speakernotes</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>generate.speakernotes</refname>
-<refpurpose>Specifies whether speakernotes are generated</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-  <programlisting id="generate.speakernotes.frag">
-    &lt;xsl:param name="generate.speakernotes"&gt;0&lt;/xsl:param&gt;
-  </programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This parameter specifies whether speakernotes shall
-  be generated to the output.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="generate.titlepage">
-<refmeta>
-<refentrytitle>generate.titlepage</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>generate.titlepage</refname>
-<refpurpose>Specifies whether titlepage is generated</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-  <programlisting id="generate.titlepage.frag">
-    &lt;xsl:param name="generate.titlepage"&gt;1&lt;/xsl:param&gt;
-  </programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This parameter specifies whether titlepage is generated
-  for the presentation.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="mml.embedding.mode">
-<refmeta>
-<refentrytitle>mml.embedding.mode</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">list</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">inline</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">object</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">image</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">link</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">iframe</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">embed</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>mml.embedding.mode</refname>
-<refpurpose>Specifies how inline MathML is processed</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-  <programlisting id="mml.embedding.mode.frag">
-    &lt;xsl:param name="mml.embedding.mode"&gt;inline&lt;/xsl:param&gt;
-  </programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This parameter specifies how inline MathML formulas
-  are embedded into the output document.</para>
-
-<variablelist>
-  <varlistentry>
-    <term>inline</term>
-    <listitem>
-      <para>Content is copied over inline with its namespace.</para>
-    </listitem>
-  </varlistentry>
-  <varlistentry>
-    <term>object</term>
-    <listitem>
-      <para>Content is extracted into an externel file and referenced
-        by an <markup>object</markup> element.</para>
-    </listitem>
-  </varlistentry>
-  <varlistentry>
-    <term>image</term>
-    <listitem>
-      <para>Content is extracted into an externel file and referenced
-        by an <markup>img</markup> element.</para>
-    </listitem>
-  </varlistentry>
-  <varlistentry>
-    <term>link</term>
-    <listitem>
-      <para>Content is extracted into an externel file and referenced
-        by an <markup>a</markup> element.</para>
-    </listitem>
-  </varlistentry>
-  <varlistentry>
-    <term>iframe</term>
-    <listitem>
-      <para>Content is extracted into an externel file and referenced
-        by an <markup>iframe</markup> element.</para>
-    </listitem>
-  </varlistentry>
-  <varlistentry>
-    <term>embed</term>
-    <listitem>
-      <para>Content is extracted into an externel file and referenced
-        by an <markup>embed</markup> element.</para>
-    </listitem>
-  </varlistentry>
-</variablelist>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="svg.embedding.mode">
-<refmeta>
-<refentrytitle>svg.embedding.mode</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">list</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">inline</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">object</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">image</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">link</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">iframe</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">embed</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>svg.embedding.mode</refname>
-<refpurpose>Specifies how inline SVG is processed</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-  <programlisting id="svg.embedding.mode.frag">
-    &lt;xsl:param name="svg.embedding.mode"&gt;object&lt;/xsl:param&gt;
-  </programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This parameter specifies how inline SVG graphics
-  are embedded into the output document.</para>
-
-<variablelist>
-  <varlistentry>
-    <term>inline</term>
-    <listitem>
-      <para>Content is copied over inline with its namespace.</para>
-    </listitem>
-  </varlistentry>
-  <varlistentry>
-    <term>object</term>
-    <listitem>
-      <para>Content is extracted into an externel file and referenced
-        by an <markup>object</markup> element.</para>
-    </listitem>
-  </varlistentry>
-  <varlistentry>
-    <term>image</term>
-    <listitem>
-      <para>Content is extracted into an externel file and referenced
-        by an <markup>img</markup> element.</para>
-    </listitem>
-  </varlistentry>
-  <varlistentry>
-    <term>link</term>
-    <listitem>
-      <para>Content is extracted into an externel file and referenced
-        by an <markup>a</markup> element.</para>
-    </listitem>
-  </varlistentry>
-  <varlistentry>
-    <term>iframe</term>
-    <listitem>
-      <para>Content is extracted into an externel file and referenced
-        by an <markup>iframe</markup> element.</para>
-    </listitem>
-  </varlistentry>
-  <varlistentry>
-    <term>embed</term>
-    <listitem>
-      <para>Content is extracted into an externel file and referenced
-        by an <markup>embed</markup> element.</para>
-    </listitem>
-  </varlistentry>
-</variablelist>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="user.css">
-<refmeta>
-<refentrytitle>user.css</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">filename</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>user.css</refname>
-<refpurpose>Specifies the path to user-supplied CSS</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-  <programlisting id="user.css.frag">
-    &lt;xsl:param name="user.css"&gt;user.css&lt;/xsl:param&gt;
-  </programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This parameter specifies the path from where the
-  CSS styling is read.  This file can be used to
-  add additional styling to the slides.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="wrap.slidecontent">
-<refmeta>
-<refentrytitle>wrap.slidecontent</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>wrap.slidecontent</refname>
-<refpurpose>Specifies whether the foil content is wrapped into a div</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-  <programlisting id="wrap.slidecontent.frag">
-    &lt;xsl:param name="wrap.slidecontent"&gt;0&lt;/xsl:param&gt;
-  </programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This parameter specifies whether the foil content is wrapped into
-  a div so that additional styling can be applied.</para>
-
-</refsection>
-</refentry>
-
-</reference><reference id="s5" xml:base="../slides/xhtml/param.xml">
-  <title>XHTML: S5 Params</title>
-
-<refentry version="5.0" id="s5.controls">
-<refmeta>
-<refentrytitle>s5.controls</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>s5.controls</refname>
-<refpurpose>Specifies whether S5 controls are visible</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-  <programlisting id="s5.controls.frag">
-    &lt;xsl:param name="s5.controls"&gt;0&lt;/xsl:param&gt;
-  </programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This parameter specifies whether S5 navigation controls are
-  visible by default.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="s5.defaultview">
-<refmeta>
-<refentrytitle>s5.defaultview</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">list</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">slideshow</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">outline</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>s5.defaultview</refname>
-<refpurpose>Specifies the default S5 view</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-  <programlisting id="s5.defaultview.frag">
-    &lt;xsl:param name="s5.defaultview"&gt;slideshow&lt;/xsl:param&gt;
-  </programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This parameter specifies, which is the default view
-  in the generated S5 presentation.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="s5.opera.css">
-<refmeta>
-<refentrytitle>s5.opera.css</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">filename</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>s5.opera.css</refname>
-<refpurpose>Specifies the name of the S5 Opera-specific CSS file</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-  <programlisting id="s5.opera.css.frag">
-    &lt;xsl:param name="s5.opera.css"&gt;opera.css&lt;/xsl:param&gt;
-  </programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This parameter specifies the name of the S5 Opera-specific
-  CSS file.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="s5.outline.css">
-<refmeta>
-<refentrytitle>s5.outline.css</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">filename</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>s5.outline.css</refname>
-<refpurpose>Specifies the name of the S5 outline CSS file</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-  <programlisting id="s5.outline.css.frag">
-    &lt;xsl:param name="s5.outline.css"&gt;outline.css&lt;/xsl:param&gt;
-  </programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This parameter specifies the name of the S5 outline CSS file.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="s5.path.prefix">
-<refmeta>
-<refentrytitle>s5.path.prefix</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">uri</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>s5.path.prefix</refname>
-<refpurpose>Specifies the path to S5 files</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-  <programlisting id="s5.path.prefix.frag">
-    &lt;xsl:param name="s5.path.prefix"&gt;files/s5/ui/default/&lt;/xsl:param&gt;
-  </programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This parameter specifies the path where S5 CSS and
-  JavaScript files reside. All the CSS and JavaScript paths
-  will be generated relative to this directory.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="s5.print.css">
-<refmeta>
-<refentrytitle>s5.print.css</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">filename</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>s5.print.css</refname>
-<refpurpose>Specifies the name of the S5 print CSS file</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-  <programlisting id="s5.print.css.frag">
-    &lt;xsl:param name="s5.print.css"&gt;print.css&lt;/xsl:param&gt;
-  </programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This parameter specifies the name of the S5 print CSS file.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="s5.slides.css">
-<refmeta>
-<refentrytitle>s5.slides.css</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">filename</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>s5.slides.css</refname>
-<refpurpose>Specifies the name of the S5 slides CSS file</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-  <programlisting id="s5.slides.css.frag">
-    &lt;xsl:param name="s5.slides.css"&gt;slides.css&lt;/xsl:param&gt;
-  </programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This parameter specifies the name of the S5 slides CSS file.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="s5.slides.js">
-<refmeta>
-<refentrytitle>s5.slides.js</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">filename</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>s5.slides.js</refname>
-<refpurpose>Specifies the name of the S5 slides JavaScript file</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-  <programlisting id="s5.slides.js.frag">
-    &lt;xsl:param name="s5.slides.js"&gt;slides.js&lt;/xsl:param&gt;
-  </programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This parameter specifies the name of the S5 slides JavaScript
-  file.</para>
-
-</refsection>
-</refentry>
-
-</reference><reference id="slidy" xml:base="../slides/xhtml/param.xml">
-  <title>XHTML: Slidy Params</title>
-
-<refentry version="5.0" id="slidy.duration">
-<refmeta>
-<refentrytitle>slidy.duration</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">integer</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>slidy.duration</refname>
-<refpurpose>Specifies the duration of the presentation</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-  <programlisting id="slidy.duration.frag">
-    &lt;xsl:param name="slidy.duration"&gt;0&lt;/xsl:param&gt;
-  </programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This parameter specifies the duration of the presentation
-  in minutes. A JavaScript clock will count down to help the
-  speaker in not running out of time. Can be disabled if set to 0.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="slidy.path.prefix">
-<refmeta>
-<refentrytitle>slidy.path.prefix</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">uri</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>slidy.path.prefix</refname>
-<refpurpose>Specifies the path to Slidy files</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-  <programlisting id="slidy.path.prefix.frag">
-    &lt;xsl:param name="slidy.path.prefix"&gt;files/slidy/&lt;/xsl:param&gt;
-  </programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This parameter specifies the path where Slidy CSS and
-  JavaScript files reside. All the CSS and JavaScript paths
-  will be generated relative to this directory.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="slidy.slidy.css">
-<refmeta>
-<refentrytitle>slidy.slidy.css</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">filename</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>slidy.slidy.css</refname>
-<refpurpose>Specifies the name of the main Slidy CSS file</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-  <programlisting id="slidy.slidy.css.frag">
-    &lt;xsl:param name="slidy.slidy.css"&gt;styles/slidy.css&lt;/xsl:param&gt;
-  </programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This parameter specifies the name of the main Slidy CSS file.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="slidy.slidy.js">
-<refmeta>
-<refentrytitle>slidy.slidy.js</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">filename</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>slidy.slidy.js</refname>
-<refpurpose>Specifies the name of the Slidy JavaScript file</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-  <programlisting id="slidy.slidy.js.frag">
-    &lt;xsl:param name="slidy.slidy.js"&gt;scripts/slidy.js&lt;/xsl:param&gt;
-  </programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This parameter specifies the name of the Slidy JavaScript file.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="slidy.user.css">
-<refmeta>
-<refentrytitle>slidy.user.css</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">filename</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>slidy.user.css</refname>
-<refpurpose>Specifies the name of the Slidy user CSS file</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-  <programlisting id="slidy.user.css.frag">
-    &lt;xsl:param name="slidy.user.css"&gt;styles/w3c-blue.css&lt;/xsl:param&gt;
-  </programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This parameter specifies the name of the Slidy user CSS file.</para>
-
-</refsection>
-</refentry>
-
-</reference>
-      <reference id="fo" xml:base="../slides/fo/param.xml">
-  <title>FO: General Params</title>
-
-<refentry version="5.0" id="foil.title.master">
-<refmeta>
-<refentrytitle>foil.title.master</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">number</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>foil.title.master</refname>
-<refpurpose>Specifies unitless font size to use for foil titles</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="foil.title.master.frag">
-&lt;xsl:param name="foil.title.master"&gt;36&lt;/xsl:param&gt;
-&lt;!-- Inconsistant use of point size? --&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Specifies a unitless font size to use for foil titles; used in
-combination with the <parameter>foil.title.size</parameter>
-parameter.</para>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="foil.title.size">
-<refmeta>
-<refentrytitle>foil.title.size</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">length</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>foil.title.size</refname>
-<refpurpose>Specifies font size to use for foil titles, including units</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-  <programlisting id="foil.title.size.frag">
-    &lt;xsl:param name="foil.title.size"&gt;
-      &lt;xsl:value-of select="$foil.title.master"&gt;&lt;/xsl:value-of&gt;&lt;xsl:text&gt;pt&lt;/xsl:text&gt;
-    &lt;/xsl:param&gt;
-  </programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This parameter combines the value of the
-<parameter>foil.title.master</parameter> parameter with a unit
-specification. The default unit is <literal>pt</literal>
-(points).</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="generate.copyright">
-<refmeta>
-<refentrytitle>generate.copyright</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>generate.copyright</refname>
-<refpurpose>Specifies whether copyright is generated</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-  <programlisting id="generate.copyright.frag">
-    &lt;xsl:param name="generate.copyright"&gt;1&lt;/xsl:param&gt;
-  </programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This parameter specifies whether the copyright info is generated
-  in the footer area.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="generate.foilgroup.numbered.toc">
-<refmeta>
-<refentrytitle>generate.foilgroup.numbered.toc</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>generate.foilgroup.numbered.toc</refname>
-<refpurpose>Specifies whether foilgroups have a numbered TOC</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-  <programlisting id="generate.foilgroup.numbered.toc.frag">
-    &lt;xsl:param name="generate.foilgroup.numbered.toc"&gt;1&lt;/xsl:param&gt;
-  </programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>If TOC generation is turned on, this parameter specifies
-  whether foilgroups have a numbered TOC. If disabled, TOC items
-  will be bulleted, not numbered.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="generate.foilgroup.toc">
-<refmeta>
-<refentrytitle>generate.foilgroup.toc</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>generate.foilgroup.toc</refname>
-<refpurpose>Specifies whether foilgroups have a TOC</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-  <programlisting id="generate.foilgroup.toc.frag">
-    &lt;xsl:param name="generate.foilgroup.toc"&gt;1&lt;/xsl:param&gt;
-  </programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This parameter specifies whether foilgroups will
-  contain a table of contents of the included foils.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="generate.handoutnotes">
-<refmeta>
-<refentrytitle>generate.handoutnotes</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>generate.handoutnotes</refname>
-<refpurpose>Specifies whether handoutnotes are generated</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-  <programlisting id="generate.handoutnotes.frag">
-    &lt;xsl:param name="generate.handoutnotes"&gt;0&lt;/xsl:param&gt;
-  </programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This parameter specifies whether handoutnotes shall
-  be generated to the output.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="generate.page.number">
-<refmeta>
-<refentrytitle>generate.page.number</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">list</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">full<alt>1/2</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">compact<alt>1</alt></refmiscinfo>
-<refmiscinfo class="other" otherclass="value">no</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>generate.page.number</refname>
-<refpurpose>Specifies whether page numbers are generated</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-  <programlisting id="generate.page.number.frag">
-    &lt;xsl:param name="generate.page.number"&gt;compact&lt;/xsl:param&gt;
-  </programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This parameter specifies how page numbers are generated in
-  the footer area.</para>
-
-<variablelist>
-  <varlistentry>
-    <term>no</term>
-    <listitem>
-      <para>No page numbers generated at all.</para>
-    </listitem>
-  </varlistentry>
-  <varlistentry>
-    <term>full</term>
-    <listitem>
-      <para>Current page number, a slash and the total number of pages</para>
-    </listitem>
-  </varlistentry>
-  <varlistentry>
-    <term>compact</term>
-    <listitem>
-      <para>Current page number only</para>
-    </listitem>
-  </varlistentry>
-  <varlistentry>
-    <term>no</term>
-    <listitem>
-      <para>No page numbers generated at all.</para>
-    </listitem>
-  </varlistentry>
-</variablelist>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="generate.pubdate">
-<refmeta>
-<refentrytitle>generate.pubdate</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>generate.pubdate</refname>
-<refpurpose>Specifies whether the pubdate is generated</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-  <programlisting id="generate.pubdate.frag">
-    &lt;xsl:param name="generate.pubdate"&gt;1&lt;/xsl:param&gt;
-  </programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This parameter specifies whether the publication date is generated
-  in the footer area.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="generate.speakernotes">
-<refmeta>
-<refentrytitle>generate.speakernotes</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>generate.speakernotes</refname>
-<refpurpose>Specifies whether speakernotes are generated</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-  <programlisting id="generate.speakernotes.frag">
-    &lt;xsl:param name="generate.speakernotes"&gt;0&lt;/xsl:param&gt;
-  </programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This parameter specifies whether speakernotes shall
-  be generated to the output.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="generate.titlepage">
-<refmeta>
-<refentrytitle>generate.titlepage</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>generate.titlepage</refname>
-<refpurpose>Specifies whether titlepage is generated</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-  <programlisting id="generate.titlepage.frag">
-    &lt;xsl:param name="generate.titlepage"&gt;1&lt;/xsl:param&gt;
-  </programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This parameter specifies whether titlepage is generated
-  for the presentation.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="mml.embedding.mode">
-<refmeta>
-<refentrytitle>mml.embedding.mode</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">list</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">inline</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">external-graphic</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">instream-foreign-object</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>mml.embedding.mode</refname>
-<refpurpose>Specifies how inline MathML is processed</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-  <programlisting id="mml.embedding.mode.fo.frag">
-    &lt;xsl:param name="mml.embedding.mode"&gt;external-graphic&lt;/xsl:param&gt;
-  </programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This parameter specifies how inline MathML formulas
-  are embedded into the output document.</para>
-
-<variablelist>
-  <varlistentry>
-    <term>inline</term>
-    <listitem>
-      <para>Content is copied over inline with its namespace.</para>
-    </listitem>
-  </varlistentry>
-  <varlistentry>
-    <term>external-graphic</term>
-    <listitem>
-      <para>Content is extracted into an externel file and referenced
-	by an <markup>external-graphic</markup> element.</para>
-    </listitem>
-  </varlistentry>
-  <varlistentry>
-    <term>instream-foreign-object</term>
-    <listitem>
-      <para>Content is copied over with its namespace inside an
-	<markup>instream-foreign-object</markup> element.</para>
-    </listitem>
-  </varlistentry>
-</variablelist>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="slide.font.family">
-<refmeta>
-<refentrytitle>slide.font.family</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">list</refmiscinfo>
-<refmiscinfo class="other" otherclass="list-type">open</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">serif</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">sans-serif</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">monospace</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>slide.font.family</refname>
-<refpurpose>Specifies font family to use for slide bodies</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="slide.font.family.frag">
-&lt;xsl:param name="slide.font.family"&gt;Helvetica&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Specifies the font family to use for slides bodies.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="slide.title.font.family">
-<refmeta>
-<refentrytitle>slide.title.font.family</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">list</refmiscinfo>
-<refmiscinfo class="other" otherclass="list-type">open</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">serif</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">sans-serif</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">monospace</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>slide.title.font.family</refname>
-<refpurpose>Specifies font family to use for slide titles</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="slide.title.font.family.frag">
-&lt;xsl:param name="slide.title.font.family"&gt;Helvetica&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>Specifies the font family to use for slides titles.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="svg.embedding.mode">
-<refmeta>
-<refentrytitle>svg.embedding.mode</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">list</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">external-graphic</refmiscinfo>
-<refmiscinfo class="other" otherclass="value">instream-foreign-object</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>svg.embedding.mode</refname>
-<refpurpose>Specifies how inline SVG is processed</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-  <programlisting id="svg.embedding.mode.fo.frag">
-    &lt;xsl:param name="svg.embedding.mode"&gt;instream-foreign-object&lt;/xsl:param&gt;
-  </programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This parameter specifies how inline SVG graphics
-  are embedded into the output document.</para>
-
-<variablelist>
-  <varlistentry>
-    <term>inline</term>
-    <listitem>
-      <para>Content is copied over inline with its namespace.</para>
-    </listitem>
-  </varlistentry>
-  <varlistentry>
-    <term>external-graphic</term>
-    <listitem>
-      <para>Content is extracted into an externel file and referenced
-        by an <markup>external-graphic</markup> element.</para>
-    </listitem>
-  </varlistentry>
-  <varlistentry>
-    <term>instream-foreign-object</term>
-    <listitem>
-      <para>Content is copied over with its namespace inside an
-        <markup>instream-foreign-object</markup> element.</para>
-    </listitem>
-  </varlistentry>
-</variablelist>
-
-</refsection>
-</refentry>
-
-</reference><reference id="propsets" xml:base="../slides/fo/param.xml">
-  <title>FO: Property Sets</title>
-<refentry version="5.0" id="foil.header.properties">
-<refmeta>
-<refentrytitle>foil.header.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>foil.header.properties</refname>
-<refpurpose>Specifies properties for foil header area</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-  <programlisting id="foil.header.properties.frag">
-    &lt;xsl:attribute-set name="foil.header.properties"&gt;
-      &lt;xsl:attribute name="background-color"&gt;white&lt;/xsl:attribute&gt;
-      &lt;xsl:attribute name="color"&gt;black&lt;/xsl:attribute&gt;
-      &lt;xsl:attribute name="font-weight"&gt;bold&lt;/xsl:attribute&gt;
-      &lt;xsl:attribute name="text-align"&gt;center&lt;/xsl:attribute&gt;
-      &lt;xsl:attribute name="font-family"&gt;
-        &lt;xsl:value-of select="$slide.title.font.family"&gt;&lt;/xsl:value-of&gt;
-      &lt;/xsl:attribute&gt;
-      &lt;xsl:attribute name="space-after"&gt;12pt&lt;/xsl:attribute&gt;
-    &lt;/xsl:attribute-set&gt;
-  </programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This parameter specifies properties for the foil header area.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="foil.master.properties">
-<refmeta>
-<refentrytitle>foil.master.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>foil.master.properties</refname>
-<refpurpose>Specifies properties for foil master</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-  <programlisting id="foil.master.properties.frag">
-    &lt;xsl:attribute-set name="foil.master.properties"&gt;
-      &lt;xsl:attribute name="page-width"&gt;
-        &lt;xsl:value-of select="$page.width"&gt;&lt;/xsl:value-of&gt;
-      &lt;/xsl:attribute&gt;
-      &lt;xsl:attribute name="page-height"&gt;
-        &lt;xsl:value-of select="$page.height"&gt;&lt;/xsl:value-of&gt;
-      &lt;/xsl:attribute&gt;
-      &lt;xsl:attribute name="margin-top"&gt;
-        &lt;xsl:value-of select="$page.margin.top"&gt;&lt;/xsl:value-of&gt;
-      &lt;/xsl:attribute&gt;
-      &lt;xsl:attribute name="margin-bottom"&gt;
-        &lt;xsl:value-of select="$page.margin.bottom"&gt;&lt;/xsl:value-of&gt;
-      &lt;/xsl:attribute&gt;
-      &lt;xsl:attribute name="margin-left"&gt;
-        &lt;xsl:value-of select="$page.margin.inner"&gt;&lt;/xsl:value-of&gt;
-      &lt;/xsl:attribute&gt;
-      &lt;xsl:attribute name="margin-right"&gt;
-        &lt;xsl:value-of select="$page.margin.outer"&gt;&lt;/xsl:value-of&gt;
-      &lt;/xsl:attribute&gt;
-    &lt;/xsl:attribute-set&gt;
-  </programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This parameter specifies properties for the foil master.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="foil.page-sequence.properties">
-<refmeta>
-<refentrytitle>foil.page-sequence.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>foil.page-sequence.properties</refname>
-<refpurpose>Specifies properties for foil page-sequence</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-  <programlisting id="foil.page-sequence.properties.frag">
-    &lt;xsl:attribute-set name="foil.page-sequence.properties"&gt;
-      &lt;xsl:attribute name="hyphenate"&gt;
-        &lt;xsl:value-of select="$hyphenate"&gt;&lt;/xsl:value-of&gt;
-      &lt;/xsl:attribute&gt;
-    &lt;/xsl:attribute-set&gt;
-  </programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This parameter specifies properties for foil page-sequence.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="foil.properties">
-<refmeta>
-<refentrytitle>foil.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>foil.properties</refname>
-<refpurpose>Specifies properties for all foils</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-  <programlisting id="foil.properties.frag">
-    &lt;xsl:attribute-set name="foil.properties"&gt;
-      &lt;xsl:attribute name="font-family"&gt;
-        &lt;xsl:value-of select="$slide.font.family"&gt;&lt;/xsl:value-of&gt;
-      &lt;/xsl:attribute&gt;
-      &lt;xsl:attribute name="margin-{$direction.align.start}"&gt;1in&lt;/xsl:attribute&gt;
-      &lt;xsl:attribute name="margin-{$direction.align.end}"&gt;1in&lt;/xsl:attribute&gt;
-      &lt;xsl:attribute name="font-size"&gt;
-        &lt;xsl:value-of select="$body.font.size"&gt;&lt;/xsl:value-of&gt;
-      &lt;/xsl:attribute&gt;
-    &lt;/xsl:attribute-set&gt;
-  </programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This parameter specifies properties that are applied to all foils.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="foil.region-after.properties">
-<refmeta>
-<refentrytitle>foil.region-after.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>foil.region-after.properties</refname>
-<refpurpose>Specifies properties for foil region-after</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-  <programlisting id="foil.region-after.properties.frag">
-    &lt;xsl:attribute-set name="foil.region-after.properties"&gt;
-      &lt;xsl:attribute name="extent"&gt;
-        &lt;xsl:value-of select="$region.after.extent"&gt;&lt;/xsl:value-of&gt;
-      &lt;/xsl:attribute&gt;
-      &lt;xsl:attribute name="display-align"&gt;after&lt;/xsl:attribute&gt;
-    &lt;/xsl:attribute-set&gt;
-  </programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This parameter specifies properties for the foil region-after.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="foil.region-before.properties">
-<refmeta>
-<refentrytitle>foil.region-before.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>foil.region-before.properties</refname>
-<refpurpose>Specifies properties for foil region-before</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-  <programlisting id="foil.region-before.properties.frag">
-    &lt;xsl:attribute-set name="foil.region-before.properties"&gt;
-      &lt;xsl:attribute name="extent"&gt;
-        &lt;xsl:value-of select="$region.before.extent"&gt;&lt;/xsl:value-of&gt;
-      &lt;/xsl:attribute&gt;
-      &lt;xsl:attribute name="display-align"&gt;
-        &lt;xsl:value-of select="'before'"&gt;&lt;/xsl:value-of&gt;
-      &lt;/xsl:attribute&gt;
-    &lt;/xsl:attribute-set&gt;
-  </programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This parameter specifies properties for the foil region-before.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="foil.region-body.properties">
-<refmeta>
-<refentrytitle>foil.region-body.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>foil.region-body.properties</refname>
-<refpurpose>Specifies properties for foil region-body</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-  <programlisting id="foil.region-body.properties.frag">
-    &lt;xsl:attribute-set name="foil.region-body.properties"&gt;
-      &lt;xsl:attribute name="margin-bottom"&gt;
-        &lt;xsl:value-of select="$body.margin.bottom"&gt;&lt;/xsl:value-of&gt;
-      &lt;/xsl:attribute&gt;
-      &lt;xsl:attribute name="margin-top"&gt;
-        &lt;xsl:value-of select="$body.margin.top"&gt;&lt;/xsl:value-of&gt;
-      &lt;/xsl:attribute&gt;
-      &lt;xsl:attribute name="column-count"&gt;
-        &lt;xsl:value-of select="$column.count.body"&gt;&lt;/xsl:value-of&gt;
-      &lt;/xsl:attribute&gt;
-    &lt;/xsl:attribute-set&gt;
-  </programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This parameter specifies properties for the foil region-body.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="foil.subtitle.properties">
-<refmeta>
-<refentrytitle>foil.subtitle.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>foil.subtitle.properties</refname>
-<refpurpose>Specifies properties for all foil subtitles</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-  <programlisting id="foil.subtitle.properties.frag">
-    &lt;xsl:attribute-set name="foil.subtitle.properties"&gt;
-      &lt;xsl:attribute name="font-family"&gt;
-        &lt;xsl:value-of select="$slide.title.font.family"&gt;&lt;/xsl:value-of&gt;
-      &lt;/xsl:attribute&gt;
-      &lt;xsl:attribute name="text-align"&gt;center&lt;/xsl:attribute&gt;
-      &lt;xsl:attribute name="font-size"&gt;
-        &lt;xsl:value-of select="$foil.title.master * 0.8"&gt;&lt;/xsl:value-of&gt;&lt;xsl:text&gt;pt&lt;/xsl:text&gt;
-      &lt;/xsl:attribute&gt;
-      &lt;xsl:attribute name="space-after"&gt;12pt&lt;/xsl:attribute&gt;
-    &lt;/xsl:attribute-set&gt;
-  </programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This parameter specifies properties that are applied to all foil subtitles.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="foil.title.properties">
-<refmeta>
-<refentrytitle>foil.title.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>foil.title.properties</refname>
-<refpurpose>Specifies properties for foil title</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-  <programlisting id="foil.title.properties.frag">
-    &lt;xsl:attribute-set name="foil.title.properties"&gt;
-      &lt;xsl:attribute name="font-size"&gt;
-        &lt;xsl:value-of select="$foil.title.size"&gt;&lt;/xsl:value-of&gt;
-      &lt;/xsl:attribute&gt;
-    &lt;/xsl:attribute-set&gt;
-  </programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This parameter specifies properties for the foil title.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="foil.footer.properties">
-<refmeta>
-<refentrytitle>foil.footer.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>foil.footer.properties</refname>
-<refpurpose>Specifies properties for slides footer</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-  <programlisting id="foil.footer.properties.frag">
-    &lt;xsl:attribute-set name="foil.footer.properties"&gt;&lt;/xsl:attribute-set&gt;
-  </programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This parameter specifies properties for the foil footer.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="handoutnotes.properties">
-<refmeta>
-<refentrytitle>handoutnotes.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>  
-<refnamediv>
-<refname>footnote.properties</refname>
-<refpurpose>Properties applied to handoutnotes
-</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="handoutnotes.properties.frag">
-&lt;xsl:attribute-set name="handoutnotes.properties"&gt;&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This attribute set is applied to handoutnotes.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="slides.properties">
-<refmeta>
-<refentrytitle>slides.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>slides.properties</refname>
-<refpurpose>Specifies properties for all slides</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-  <programlisting id="slides.properties.frag">
-    &lt;xsl:attribute-set name="slides.properties"&gt;
-      &lt;xsl:attribute name="font-family"&gt;
-        &lt;xsl:value-of select="$slide.font.family"&gt;&lt;/xsl:value-of&gt;
-      &lt;/xsl:attribute&gt;
-    &lt;/xsl:attribute-set&gt;
-  </programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This parameter specifies properties that are applied to all slides.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="slides.titlepage.master.properties">
-<refmeta>
-<refentrytitle>slides.titlepage.master.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>slides.titlepage.master.properties</refname>
-<refpurpose>Specifies properties for slides titlepage master</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-  <programlisting id="slides.titlepage.master.properties.frag">
-    &lt;xsl:attribute-set name="slides.titlepage.master.properties"&gt;
-      &lt;xsl:attribute name="page-width"&gt;
-        &lt;xsl:value-of select="$page.width"&gt;&lt;/xsl:value-of&gt;
-      &lt;/xsl:attribute&gt;
-      &lt;xsl:attribute name="page-height"&gt;
-        &lt;xsl:value-of select="$page.height"&gt;&lt;/xsl:value-of&gt;
-      &lt;/xsl:attribute&gt;
-      &lt;xsl:attribute name="margin-top"&gt;
-        &lt;xsl:value-of select="$page.margin.top"&gt;&lt;/xsl:value-of&gt;
-      &lt;/xsl:attribute&gt;
-      &lt;xsl:attribute name="margin-bottom"&gt;
-        &lt;xsl:value-of select="$page.margin.bottom"&gt;&lt;/xsl:value-of&gt;
-      &lt;/xsl:attribute&gt;
-      &lt;xsl:attribute name="margin-left"&gt;
-        &lt;xsl:value-of select="$page.margin.inner"&gt;&lt;/xsl:value-of&gt;
-      &lt;/xsl:attribute&gt;
-      &lt;xsl:attribute name="margin-right"&gt;
-        &lt;xsl:value-of select="$page.margin.outer"&gt;&lt;/xsl:value-of&gt;
-      &lt;/xsl:attribute&gt;
-    &lt;/xsl:attribute-set&gt;
-  </programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This parameter specifies properties for the slides titlepage master.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="slides.titlepage.region-body.properties">
-<refmeta>
-<refentrytitle>slides.titlepage.region-body.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>slides.titlepage.region-body.properties</refname>
-<refpurpose>Specifies properties for slides titlepage region-body</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-  <programlisting id="slides.titlepage.region-body.properties.frag">
-    &lt;xsl:attribute-set name="slides.titlepage.region-body.properties"&gt;
-      &lt;xsl:attribute name="margin-bottom"&gt;0pt&lt;/xsl:attribute&gt;
-      &lt;xsl:attribute name="margin-top"&gt;0pt&lt;/xsl:attribute&gt;
-      &lt;xsl:attribute name="column-count"&gt;
-        &lt;xsl:value-of select="$column.count.body"&gt;&lt;/xsl:value-of&gt;
-      &lt;/xsl:attribute&gt;
-    &lt;/xsl:attribute-set&gt;
-  </programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This parameter specifies properties for the slides titlepage region-body.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="slides.titlepage.corpauthor.properties">
-<refmeta>
-<refentrytitle>slides.titlepage.corpauthor.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>slides.titlepage.corpauthor.properties</refname>
-<refpurpose>Specifies properties for slides titlepage title</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-  <programlisting id="slides.titlepage.corpauthor.properties.frag">
-    &lt;xsl:attribute-set name="slides.titlepage.corpauthor.properties"&gt;
-      &lt;xsl:attribute name="text-align"&gt;center&lt;/xsl:attribute&gt;
-      &lt;xsl:attribute name="space-after"&gt;1em&lt;/xsl:attribute&gt;
-      &lt;xsl:attribute name="font-size"&gt;20.736pt&lt;/xsl:attribute&gt;
-    &lt;/xsl:attribute-set&gt;
-  </programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This parameter specifies properties for the corpauthor on the default
-  titlepage.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="slides.titlepage.title.properties">
-<refmeta>
-<refentrytitle>slides.titlepage.title.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>slides.titlepage.title.properties</refname>
-<refpurpose>Specifies properties for slides titlepage title</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-  <programlisting id="slides.titlepage.title.properties.frag">
-    &lt;xsl:attribute-set name="slides.titlepage.title.properties"&gt;
-      &lt;xsl:attribute name="text-align"&gt;center&lt;/xsl:attribute&gt;
-      &lt;xsl:attribute name="space-after"&gt;1em&lt;/xsl:attribute&gt;
-      &lt;xsl:attribute name="padding-top"&gt;1.5in&lt;/xsl:attribute&gt;
-      &lt;xsl:attribute name="keep-with-next"&gt;always&lt;/xsl:attribute&gt;
-      &lt;xsl:attribute name="font-size"&gt;
-	&lt;xsl:value-of select="$foil.title.size"&gt;&lt;/xsl:value-of&gt;
-      &lt;/xsl:attribute&gt;
-      &lt;xsl:attribute name="font-weight"&gt;bold&lt;/xsl:attribute&gt;
-      &lt;xsl:attribute name="font-family"&gt;
-	&lt;xsl:value-of select="$slide.title.font.family"&gt;&lt;/xsl:value-of&gt;
-      &lt;/xsl:attribute&gt;
-    &lt;/xsl:attribute-set&gt;
-  </programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This parameter specifies properties for the title on the default
-  titlepage.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="slides.titlepage.subtitle.properties">
-<refmeta>
-<refentrytitle>slides.titlepage.subtitle.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>slides.titlepage.subtitle.properties</refname>
-<refpurpose>Specifies properties for slides titlepage title</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-  <programlisting id="slides.titlepage.subtitle.properties.frag">
-    &lt;xsl:attribute-set name="slides.titlepage.subtitle.properties"&gt;
-      &lt;xsl:attribute name="text-align"&gt;center&lt;/xsl:attribute&gt;
-      &lt;xsl:attribute name="space-after"&gt;1em&lt;/xsl:attribute&gt;
-      &lt;xsl:attribute name="font-family"&gt;
-	&lt;xsl:value-of select="$slide.title.font.family"&gt;&lt;/xsl:value-of&gt;
-      &lt;/xsl:attribute&gt;
-    &lt;/xsl:attribute-set&gt;
-  </programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This parameter specifies properties for the subtitle on the default
-  titlepage.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="slides.titlepage.author.properties">
-<refmeta>
-<refentrytitle>slides.titlepage.author.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>slides.titlepage.author.properties</refname>
-<refpurpose>Specifies properties for slides titlepage title</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-  <programlisting id="slides.titlepage.author.properties.frag">
-    &lt;xsl:attribute-set name="slides.titlepage.author.properties"&gt;
-      &lt;xsl:attribute name="text-align"&gt;center&lt;/xsl:attribute&gt;
-      &lt;xsl:attribute name="space-after"&gt;1em&lt;/xsl:attribute&gt;
-      &lt;xsl:attribute name="font-size"&gt;20.736pt&lt;/xsl:attribute&gt;
-    &lt;/xsl:attribute-set&gt;
-  </programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This parameter specifies properties for the author on the default
-  titlepage.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="slides.titlepage.pubdate.properties">
-<refmeta>
-<refentrytitle>slides.titlepage.pubdate.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>slides.titlepage.pubdate.properties</refname>
-<refpurpose>Specifies properties for slides titlepage title</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-  <programlisting id="slides.titlepage.pubdate.properties.frag">
-    &lt;xsl:attribute-set name="slides.titlepage.pubdate.properties"&gt;
-      &lt;xsl:attribute name="text-align"&gt;center&lt;/xsl:attribute&gt;
-      &lt;xsl:attribute name="space-after"&gt;1em&lt;/xsl:attribute&gt;
-      &lt;xsl:attribute name="font-size"&gt;17.28pt&lt;/xsl:attribute&gt;
-    &lt;/xsl:attribute-set&gt;
-  </programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This parameter specifies properties for the pubdate on the default
-  titlepage.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="slides.titlepage.authorgroup.properties">
-<refmeta>
-<refentrytitle>slides.titlepage.authorgroup.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>slides.titlepage.authorgroup.properties</refname>
-<refpurpose>Specifies properties for slides titlepage title</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-  <programlisting id="slides.titlepage.authorgroup.properties.frag">
-    &lt;xsl:attribute-set name="slides.titlepage.authorgroup.properties"&gt;&lt;/xsl:attribute-set&gt;
-  </programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This parameter specifies properties for the authorgroup on the default
-  titlepage.</para>
-
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="speakernotes.properties">
-<refmeta>
-<refentrytitle>speakernotes.properties</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>  
-<refnamediv>
-<refname>footnote.properties</refname>
-<refpurpose>Properties applied to speakernotes
-</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="speakernotes.properties.frag">
-&lt;xsl:attribute-set name="speakernotes.properties"&gt;&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-
-<para>This attribute set is applied to speakernotes.</para>
-
-</refsection>
-</refentry>
-
-</reference>
-    </part>
-    <part id="website">
-      <?dbhtml dir="website"?>
-      <?dbhtml filename="index.html"?>
-      <title xml:base="../website/param.xml">Website Parameter Reference</title>
-      <partintro id="websiteintro">
-        
-  <para xml:base="../website/param.xml">This is reference documentation for all user-configurable
-    parameters in the DocBook XSL Website stylesheet (for
-    generating websites from DocBook XML sources). Note that the
-    Website stylesheet is a customization layer of the DocBook XSL
-    HTML stylesheet.  Therefore, in addition to the
-    Website-specific parameters listed in this section, you can
-    also use a number of <link xlink:href="../html/">HTML
-     stylesheet parameters</link> to control Website output.</para>
-
-      </partintro>
-      <reference id="general" xml:base="../website/param.xml">
-<title>General Parameters</title>
-<refentry version="5.0" id="autolayout-file">
-<refmeta>
-<refentrytitle>autolayout-file</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">filename</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>autolayout-file</refname>
-<refpurpose>Identifies the autolayout.xml file</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="autolayout-file.frag">
-&lt;xsl:param name="autolayout-file"&gt;autolayout.xml&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-<para>When the source pages are spread over several directories, this
-parameter can be set (for example, from the command line of a batch-mode
-XSLT processor) to indicate the location of the autolayout.xml file.</para>
-<para>FIXME: for browser-based use, there needs to be a PI for this...
-</para>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="body.attributes">
-<refmeta>
-<refentrytitle>body.attributes</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">attribute set</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>body.attributes</refname>
-<refpurpose>DEPRECATED</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="body.attributes.frag">
-&lt;xsl:attribute-set name="body.attributes"&gt;
-  &lt;xsl:attribute name="bgcolor"&gt;white&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="text"&gt;black&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="link"&gt;#0000FF&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="vlink"&gt;#840084&lt;/xsl:attribute&gt;
-  &lt;xsl:attribute name="alink"&gt;#0000FF&lt;/xsl:attribute&gt;
-&lt;/xsl:attribute-set&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-<para>DEPRECATED</para>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="currentpage.marker">
-<refmeta>
-<refentrytitle>currentpage.marker</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>currentpage.marker</refname>
-<refpurpose>The text symbol used to mark the current page</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="currentpage.marker.frag">
-&lt;xsl:param name="currentpage.marker"&gt;@&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-<para>Character to use as identifying the current page in </para>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="dry-run">
-<refmeta>
-<refentrytitle>dry-run</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>dry-run</refname>
-<refpurpose>Indicates that no files should be produced</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-  <programlisting id="dry-run.frag">
-    &lt;xsl:param name="dry-run" select="0"&gt;&lt;/xsl:param&gt;
-  </programlisting>
-</refsynopsisdiv>
-<refsection><info><title>Description</title></info>
-<para>When using the XSLT processor to manage dependencies and construct
-the website, this parameter can be used to suppress the generation of
-new and updated files. Effectively, this allows you to see what the
-stylesheet would do, without actually making any changes.</para>
-<para>Only applies when XSLT-based chunking is being used.</para>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="feedback.href">
-<refmeta>
-<refentrytitle>feedback.href</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">uri</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>feedback.href</refname>
-<refpurpose>HREF (URI) for feedback link</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="feedback.href.frag">
-&lt;xsl:param name="feedback.href"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-<para>The <varname>feedback.href</varname> value is used as the value
-for the <tag class="attribute">href</tag> attribute on the feedback
-link. If <varname>feedback.href</varname>
-is empty, no feedback link is generated.</para>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="feedback.link.text">
-<refmeta>
-<refentrytitle>feedback.link.text</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>feedback.link.text</refname>
-<refpurpose>The text of the feedback link</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="feedback.link.text.frag">
-&lt;xsl:param name="feedback.link.text"&gt;Feedback&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-<para>The contents of this variable is used as the text of the feedback
-link if <varname>feedback.href</varname> is not empty. If
-<varname>feedback.href</varname> is empty, no feedback link is
-generated.</para>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="feedback.with.ids">
-<refmeta>
-<refentrytitle>feedback.with.ids</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>feedback.with.ids</refname>
-<refpurpose>Toggle use of IDs in feedback</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="feedback.with.ids.frag">
-&lt;xsl:param name="feedback.with.ids" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-<para>If <varname>feedback.with.ids</varname> is non-zero, the ID of the
-current page will be added to the feedback link. This can be used, for
-example, if the <varname>feedback.href</varname> is a CGI script.</para>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="filename-prefix">
-<refmeta>
-<refentrytitle>filename-prefix</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>filename-prefix</refname>
-<refpurpose>Prefix added to all filenames</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="filename-prefix.frag">
-&lt;xsl:param name="filename-prefix"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-<para>To produce the <quote>text-only</quote> (that is, non-tabular) layout
-of a website simultaneously with the tabular layout, the filenames have to
-be distinguished. That's accomplished by adding the
-<varname>filename-prefix</varname> to the front of each filename.</para>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="footer.hr">
-<refmeta>
-<refentrytitle>footer.hr</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>footer.hr</refname>
-<refpurpose>Toggle &lt;HR&gt; before footer</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="footer.hr.frag">
-&lt;xsl:param name="footer.hr" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-<para>If non-zero, an &lt;HR&gt; is generated at the bottom of each web page,
-before the footer.</para>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="header.hr">
-<refmeta>
-<refentrytitle>header.hr</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>header.hr</refname>
-<refpurpose>Toggle &lt;HR&gt; after header</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="header.hr.frag">
-&lt;xsl:param name="header.hr" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-<para>If non-zero, an &lt;HR&gt; is generated at the bottom of each web page,
-before the footer.</para>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="output-root">
-<refmeta>
-<refentrytitle>output-root</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">filename</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>output-root</refname>
-<refpurpose>Specifies the root directory of the website</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="output-root.frag">
-&lt;xsl:param name="output-root"&gt;.&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-<para>When using the XSLT processor to manage dependencies and construct
-the website, this parameter can be used to indicate the root directory
-where the resulting pages are placed.</para>
-<para>Only applies when XSLT-based chunking is being used.</para>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="rebuild-all">
-<refmeta>
-<refentrytitle>rebuild-all</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>rebuild-all</refname>
-<refpurpose>Indicates that all files should be produced</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="rebuild-all.frag">
-&lt;xsl:param name="rebuild-all" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-<para>When using the XSLT processor to manage dependencies and construct
-the website, this parameter can be used to regenerate the whole website,
-updating even pages that don't appear to need to be updated.</para>
-<para>The dependency extension only looks at the source documents. So
-if you change something in the stylesheet, for example, that has a global
-effect, you can use this parameter to force the stylesheet to rebuild the
-whole website.
-</para>
-<para>Only applies when XSLT-based chunking is being used.</para>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="sequential.links">
-<refmeta>
-<refentrytitle>sequential.links</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>sequential.links</refname>
-<refpurpose>Make sequentional links?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="sequential.links.frag">
-&lt;xsl:param name="sequential.links" select="0"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-<para>FIXME</para>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="suppress.homepage.title">
-<refmeta>
-<refentrytitle>suppress.homepage.title</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>suppress.homepage.title</refname>
-<refpurpose>Suppress title on homepage?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="suppress.homepage.title.frag">
-&lt;xsl:param name="suppress.homepage.title" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-<para>FIXME:If non-zero, the title on the homepage is suppressed?</para>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="table.spacer.image">
-<refmeta>
-<refentrytitle>table.spacer.image</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">filename</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>table.spacer.image</refname>
-<refpurpose>Invisible pixel for tabular accessibility</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="table.spacer.image.frag">
-&lt;xsl:param name="table.spacer.image"&gt;graphics/spacer.gif&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-<para>This is the 1x1 pixel, transparent pixel used for <link xlink:href="http://diveintoaccessibility.org/day_10_presenting_your_main_content_first.html">the table trick</link> to increase the accessibility of the tabular
-website presentation.</para>
-</refsection>
-</refentry>
-
-</reference><reference id="nav" xml:base="../website/param.xml">
-<title>Navigation Parameters</title>
-<refentry version="5.0" id="banner.before.navigation">
-<refmeta>
-<refentrytitle>banner.before.navigation</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>banner.before.navigation</refname>
-<refpurpose>Put banner before navigation?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="banner.before.navigation.frag">
-&lt;xsl:param name="banner.before.navigation" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-<para>FIXME</para>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="navbgcolor">
-<refmeta>
-<refentrytitle>navbgcolor</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">color</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>navbgcolor</refname>
-<refpurpose>The background color of the navigation TOC</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="navbgcolor.frag">
-&lt;xsl:param name="navbgcolor"&gt;#4080FF&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-<para>The background color of the navigation TOC.</para>
-<para>Only applies with the tabular presentation is being used.</para>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="navbodywidth">
-<refmeta>
-<refentrytitle>navbodywidth</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">length</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>navbodywidth</refname>
-<refpurpose>Specifies the width of the navigation table body</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="navbodywidth.frag">
-&lt;xsl:param name="navbodywidth"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-<para>The width of the body column.</para>
-<para>Only applies with the tabular presentation is being used.</para>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="nav.table.summary">
-<refmeta>
-<refentrytitle>nav.table.summary</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>nav.table.summary</refname>
-<refpurpose>HTML Table summary attribute value for navigation tables</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="nav.table.summary.frag">
-&lt;xsl:param name="nav.table.summary"&gt;Navigation&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-<para>The value of this parameter is used as the value of the table
-summary attribute for the navigation table.</para>
-<para>Only applies with the tabular presentation is being used.</para>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="navtocwidth">
-<refmeta>
-<refentrytitle>navtocwidth</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">length</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>navtocwidth</refname>
-<refpurpose>Specifies the width of the navigation table TOC</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="navtocwidth.frag">
-&lt;xsl:param name="navtocwidth"&gt;220&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-<para>The width, in pixels, of the navigation column.</para>
-<para>Only applies with the tabular presentation is being used.</para>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="textbgcolor">
-<refmeta>
-<refentrytitle>textbgcolor</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">color</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>textbgcolor</refname>
-<refpurpose>The background color of the table body</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="textbgcolor.frag">
-&lt;xsl:param name="textbgcolor"&gt;white&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-<para>The background color of the table body.</para>
-<para>Only applies with the tabular presentation is being used.</para>
-</refsection>
-</refentry>
-
-</reference><reference id="toc" xml:base="../website/param.xml">
-<title>ToC Parameters</title>
-<refentry version="5.0" id="toc.blank.graphic">
-<refmeta>
-<refentrytitle>toc.blank.graphic</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>toc.blank.graphic</refname>
-<refpurpose>Use graphic for "blanks" in TOC?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="toc.blank.graphic.frag">
-&lt;xsl:param name="toc.blank.graphic" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-<para>If non-zero, "blanks" in the the TOC will be accomplished
-with the graphic identified by <varname>toc.spacer.image</varname>.
-</para>
-<para>Only applies with the tabular presentation is being used.</para>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="toc.blank.image">
-<refmeta>
-<refentrytitle>toc.blank.image</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">filename</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>toc.blank.image</refname>
-<refpurpose>The image for "blanks" in the TOC</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="toc.blank.image.frag">
-&lt;xsl:param name="toc.blank.image"&gt;graphics/blank.gif&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-<para>If <varname>toc.blank.graphic</varname> is non-zero, this image
-will be used to for "blanks" in the TOC.</para>
-<para>Only applies with the tabular presentation is being used.</para>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="toc.blank.text">
-<refmeta>
-<refentrytitle>toc.blank.text</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>toc.blank.text</refname>
-<refpurpose>The text for "blanks" in the TOC</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="toc.blank.text.frag">
-&lt;xsl:param name="toc.blank.text"&gt;&#160;&#160;&#160;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-<para>If <varname>toc.blank.graphic</varname> is zero, this text string
-will be used for "blanks" in the TOC.</para>
-<para>Only applies with the tabular presentation is being used.</para>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="toc.pointer.graphic">
-<refmeta>
-<refentrytitle>toc.pointer.graphic</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>toc.pointer.graphic</refname>
-<refpurpose>Use graphic for TOC pointer?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="toc.pointer.graphic.frag">
-&lt;xsl:param name="toc.pointer.graphic" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-<para>If non-zero, the "pointer" in the TOC will be displayed
-with the graphic identified by <varname>toc.pointer.image</varname>.
-</para>
-<para>Only applies with the tabular presentation is being used.</para>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="toc.pointer.image">
-<refmeta>
-<refentrytitle>toc.pointer.image</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">filename</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>toc.pointer.image</refname>
-<refpurpose>The image for the "pointer" in the TOC</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="toc.pointer.image.frag">
-&lt;xsl:param name="toc.pointer.image"&gt;graphics/arrow.gif&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-<para>If <varname>toc.pointer.graphic</varname> is non-zero, this image
-will be used for the "pointer" in the TOC.</para>
-<para>Only applies with the tabular presentation is being used.</para>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="toc.pointer.text">
-<refmeta>
-<refentrytitle>toc.pointer.text</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>toc.pointer.text</refname>
-<refpurpose>The text for the "pointer" in the TOC</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="toc.pointer.text.frag">
-&lt;xsl:param name="toc.pointer.text"&gt;&#160;&gt;&#160;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-<para>If <varname>toc.pointer.graphic</varname> is zero, this text string
-will be used to display the "pointer" in the TOC.</para>
-<para>Only applies with the tabular presentation is being used.</para>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="toc.spacer.graphic">
-<refmeta>
-<refentrytitle>toc.spacer.graphic</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">boolean</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>toc.spacer.graphic</refname>
-<refpurpose>Use graphic for TOC spacer?</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="toc.spacer.graphic.frag">
-&lt;xsl:param name="toc.spacer.graphic" select="1"&gt;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-<para>If non-zero, the indentation in the TOC will be accomplished
-with the graphic identified by <varname>toc.spacer.image</varname>.
-</para>
-<para>Only applies with the tabular presentation is being used.</para>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="toc.spacer.image">
-<refmeta>
-<refentrytitle>toc.spacer.image</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">filename</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>toc.spacer.image</refname>
-<refpurpose>The image for spacing the TOC</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="toc.spacer.image.frag">
-&lt;xsl:param name="toc.spacer.image"&gt;graphics/blank.gif&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-<para>If <varname>toc.spacer.graphic</varname> is non-zero, this image
-will be used to indent the TOC.</para>
-<para>Only applies with the tabular presentation is being used.</para>
-</refsection>
-</refentry>
-
-<refentry version="5.0" id="toc.spacer.text">
-<refmeta>
-<refentrytitle>toc.spacer.text</refentrytitle>
-<refmiscinfo class="other" otherclass="datatype">string</refmiscinfo>
-</refmeta>
-<refnamediv>
-<refname>toc.spacer.text</refname>
-<refpurpose>The text for spacing the TOC</refpurpose>
-</refnamediv>
-
-<refsynopsisdiv>
-<programlisting id="toc.spacer.text.frag">
-&lt;xsl:param name="toc.spacer.text"&gt;&#160;&#160;&#160;&lt;/xsl:param&gt;
-</programlisting>
-</refsynopsisdiv>
-
-<refsection><info><title>Description</title></info>
-<para>If <varname>toc.spacer.graphic</varname> is zero, this text string
-will be used to indent the TOC.</para>
-<para>Only applies with the tabular presentation is being used.</para>
-</refsection>
-</refentry>
-
-</reference>
-    </part>
-   <!-- Prepare WebHelp output
-    <part xml:id="webhelp">
-      <?dbhtml dir="webhelp"?>
-      <?dbhtml filename="index.html"?>
-      <xi:include href="../webhelp/param.xml" xpointer="xpointer(/book/info/title)" />
-      <partintro xml:id="webhelpintro">
-        <xi:include href="../webhelp/param.xml" xpointer="xpointer(/book/info/abstract/node())" />
-      </partintro>
-      <xi:include href="../webhelp/param.xml" xpointer="xpointer(/book/reference)" />
-    </part>
-   -->
-  </book>
- 
-  <book id="pi"><title>DocBook XSL Stylesheets User&#160;Reference:&#160;PIs</title>
-    <?dbhtml dir="pi"?>
-    <?dbhtml filename="index.html"?>
-    <info>
-      <abstract>
-        <para>This is generated reference documentation for all
-          user-specifiable processing instructions in the DocBook
-          XSL stylesheets.
-          <note>
-            <para>You add these PIs at particular points in a document to
-              cause specific &#8220;exceptions&#8221; to formatting/output behavior. To
-              make global changes in formatting/output behavior across an
-              entire document, it&#8217;s better to do it by setting an
-              appropriate stylesheet parameter (if there is one).</para>
-          </note>
-        </para>
-      </abstract>
-    </info>
-    <part id="pi-html">
-      <info xml:base="../html/pi.xml"><title>HTML Processing Instruction Reference</title>
-    <releaseinfo role="meta">
-      $Id: pi.xsl 9022 2011-07-14 19:21:36Z bobstayton $
-    </releaseinfo>
-  </info>
-  <partintro id="partintro" xml:base="../html/pi.xml">
-    <title>Introduction</title>
-    
-<para>This is generated reference documentation for all
-      user-specifiable processing instructions (PIs) in the DocBook
-      XSL stylesheets for HTML output.
-      <note>
-        
-<para>You add these PIs at particular points in a document to
-          cause specific &#8220;exceptions&#8221; to formatting/output behavior. To
-          make global changes in formatting/output behavior across an
-          entire document, it&#8217;s better to do it by setting an
-          appropriate stylesheet parameter (if there is one).</para>
-
-      </note>
-    </para>
-
-  </partintro>
-
-<refentry id="dbhtml_background-color" xml:base="../html/pi.xml">
-<refnamediv>
-<refname>dbhtml_background-color</refname>
-<refpurpose>Sets background color for an image</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-
-    <synopsis><tag class="xmlpi">dbhtml background-color="<replaceable>color</replaceable>"</tag></synopsis>
-  
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-    
-<para>Use the <tag class="xmlpi">dbhtml background-color</tag> PI before or
-      after an image (<tag>graphic</tag>, <tag>inlinegraphic</tag>,
-      <tag>imagedata</tag>, or <tag>videodata</tag> element) as a
-      sibling to the element, to set a background color for the
-      image.</para>
-
-  </refsect1><refsect1><title>Parameters</title>
-    
-<variablelist>
-      <varlistentry><term>background-color="<replaceable>color</replaceable>"</term>
-        <listitem>
-          
-<para>An HTML color value</para>
-
-        </listitem>
-      </varlistentry>
-    </variablelist>
-
-  </refsect1><refsect1 role="tcg"><title>Related Information in <link xlink:href="http://www.sagehill.net/docbookxsl/">DocBook XSL: The Complete Guide</link></title>
-    
-<para><link role="tcg" xlink:href="BGcolor.html">Background color</link></para>
-
-  </refsect1></refentry>
-
-<refentry id="dbhtml_bgcolor" xml:base="../html/pi.xml">
-<refnamediv>
-<refname>dbhtml_bgcolor</refname>
-<refpurpose>Sets background color on a CALS table row or table cell</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-
-    <synopsis><tag class="xmlpi">dbhtml bgcolor="<replaceable>color</replaceable>"</tag></synopsis>
-  
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-    
-<para>Use the <tag class="xmlpi">dbhtml bgcolor</tag> PI as child of a CALS table row
-      or cell to set a background color for that table row or cell.</para>
-
-  </refsect1><refsect1><title>Parameters</title>
-    
-<variablelist>
-      <varlistentry><term>bgcolor="<replaceable>color</replaceable>"</term>
-        <listitem>
-          
-<para>An HTML color value</para>
-
-        </listitem>
-      </varlistentry>
-    </variablelist>
-
-  </refsect1><refsect1 role="tcg"><title>Related Information in <link xlink:href="http://www.sagehill.net/docbookxsl/">DocBook XSL: The Complete Guide</link></title>
-    
-<para><link role="tcg" xlink:href="BGtableColor.html#CellBGColor">Cell background color</link></para>
-
-  </refsect1></refentry>
-
-<refentry id="dbhtml_cellpadding" xml:base="../html/pi.xml">
-<refnamediv>
-<refname>dbhtml_cellpadding</refname>
-<refpurpose>Specifies cellpadding in CALS table or qandaset output</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-
-    <synopsis><tag class="xmlpi">dbhtml cellpadding="<replaceable>number</replaceable>"</tag></synopsis>
-  
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-    
-<para>Use the <tag class="xmlpi">dbhtml cellpadding</tag> PI as a child of a
-      CALS <tag>table</tag> or <tag>qandaset</tag> to specify the value
-      for the HTML <literal>cellpadding</literal> attribute in the
-      output HTML table.</para>
-
-  </refsect1><refsect1><title>Parameters</title>
-    
-<variablelist>
-      <varlistentry><term>cellpadding="<replaceable>number</replaceable>"</term>
-        <listitem>
-          
-<para>Specifies the cellpadding</para>
-
-        </listitem>
-      </varlistentry>
-    </variablelist>
-
-  </refsect1><refsect1 role="params"><title>Related Global Parameters</title>
-    
-<para><parameter>html.cellpadding</parameter></para>
-
-  </refsect1><refsect1 role="tcg"><title>Related Information in <link xlink:href="http://www.sagehill.net/docbookxsl/">DocBook XSL: The Complete Guide</link></title>
-    
-<para><link role="tcg" xlink:href="CellSpacing.html">Cell spacing and cell padding</link>,
-      <link role="tcg" xlink:href="QandAformat.html">Q and A formatting</link></para>
-
-  </refsect1></refentry>
-
-<refentry id="dbhtml_cellspacing" xml:base="../html/pi.xml">
-<refnamediv>
-<refname>dbhtml_cellspacing</refname>
-<refpurpose>Specifies cellspacing in CALS table or qandaset output</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-
-    <synopsis><tag class="xmlpi">dbhtml cellspacing="<replaceable>number</replaceable>"</tag></synopsis>
-  
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-    
-<para>Use the <tag class="xmlpi">dbhtml cellspacing</tag> PI as a child of a
-      CALS <tag>table</tag> or <tag>qandaset</tag> to specify the value
-      for the HTML <literal>cellspacing</literal> attribute in the
-      output HTML table.</para>
-
-  </refsect1><refsect1><title>Parameters</title>
-    
-<variablelist>
-      <varlistentry><term>cellspacing="<replaceable>number</replaceable>"</term>
-        <listitem>
-          
-<para>Specifies the cellspacing</para>
-
-        </listitem>
-      </varlistentry>
-    </variablelist>
-
-  </refsect1><refsect1 role="params"><title>Related Global Parameters</title>
-    
-<para><parameter>html.cellspacing</parameter></para>
-
-  </refsect1><refsect1 role="tcg"><title>Related Information in <link xlink:href="http://www.sagehill.net/docbookxsl/">DocBook XSL: The Complete Guide</link></title>
-    
-<para><link role="tcg" xlink:href="CellSpacing.html">Cell spacing and cell padding</link>,
-      <link role="tcg" xlink:href="QandAformat.html">Q and A formatting</link></para>
-
-    </refsect1></refentry>
-
-<refentry id="dbhtml_class" xml:base="../html/pi.xml">
-<refnamediv>
-<refname>dbhtml_class</refname>
-<refpurpose>Set value of the class attribute for a CALS table row</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-
-    <synopsis><tag class="xmlpi">dbhtml class="<replaceable>name</replaceable>"</tag></synopsis>
-  
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-    
-<para>Use the <tag class="xmlpi">dbhtml class</tag> PI as a child of a
-      <tag>row</tag> to specify a <literal>class</literal>
-      attribute and value in the HTML output for that row.</para>
-
-  </refsect1><refsect1><title>Parameters</title>
-    
-<variablelist>
-      <varlistentry><term>class="<replaceable>name</replaceable>"</term>
-        <listitem>
-          
-<para>Specifies the class name</para>
-
-        </listitem>
-      </varlistentry>
-    </variablelist>
-
-  </refsect1><refsect1 role="tcg"><title>Related Information in <link xlink:href="http://www.sagehill.net/docbookxsl/">DocBook XSL: The Complete Guide</link></title>
-    
-<para><link role="tcg" xlink:href="CSSTableCells.html">Table styles in HTML output</link></para>
-
-  </refsect1></refentry>
-
-<refentry id="dbhtml_dir" xml:base="../html/pi.xml">
-<refnamediv>
-<refname>dbhtml_dir</refname>
-<refpurpose>Specifies a directory name in which to write files</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-
-    <synopsis><tag class="xmlpi">dbhtml dir="<replaceable>path</replaceable>"</tag></synopsis>
-  
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-    
-<para>When chunking output, use the <tag class="xmlpi">dbhtml dir</tag> PI
-      as a child of a chunk source to cause the output of that
-      chunk to be written to the specified directory; also, use it
-      as a child of a <tag>mediaobject</tag> to specify a
-      directory into which any long-description files for that
-      <tag>mediaobject</tag> will be written.</para>
-
-
-
-<para>The output directory specification is inherited by all
-chunks of the descendants of the element.  If descendants need
-to go to a different directory, then add another 
-<tag class="xmlpi">dbhtml dir</tag> processing
-instruction as a child of the source element
-for that chunk, and specify the path relative to the
-ancestor path.</para>
-
-
-
-<para>For example, to put most chunk files into 
-<filename class="directory">shared</filename>
-but one chapter into 
-<filename class="directory">exception</filename>
-at the same level, use:</para>
-
-
-<programlisting>&lt;book&gt;
-  &lt;?dbhtml dir="shared"?&gt;
-  ...
-  &lt;chapter&gt;
-    &lt;?dbhtml dir="../exception"?&gt;
-  &lt;/chapter&gt;
-&lt;/book&gt;
-</programlisting>
-
-
-  </refsect1><refsect1><title>Parameters</title>
-    
-<variablelist>
-      <varlistentry><term>dir="<replaceable>path</replaceable>"</term>
-        <listitem>
-          
-<para>Specifies the pathname for the directory</para>
-
-        </listitem>
-      </varlistentry>
-    </variablelist>
-
-  </refsect1><refsect1 role="params"><title>Related Global Parameters</title>
-    
-<para><parameter>base.dir</parameter></para>
-
-  </refsect1><refsect1 role="tcg"><title>Related Information in <link xlink:href="http://www.sagehill.net/docbookxsl/">DocBook XSL: The Complete Guide</link></title>
-    
-<para><link role="tcg" xlink:href="Chunking.html#dbhtmlDirPI">dbhtml dir processing instruction</link></para>
-
-  </refsect1></refentry>
-
-<refentry id="dbhtml_filename" xml:base="../html/pi.xml">
-<refnamediv>
-<refname>dbhtml_filename</refname>
-<refpurpose>Specifies a filename for a chunk</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-
-    <synopsis><tag class="xmlpi">dbhtml filename="<replaceable>filename</replaceable>"</tag></synopsis>
-  
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-
-<para>When chunking output, use the <tag class="xmlpi">dbhtml filename</tag>
-      PI as a child of a chunk source to specify a filename for
-      the output file for that chunk. Include the filename suffix.</para>
-
-
-
-<para>You cannot include a directory path in the filename value,
-or your links may not work.  Add a 
-<tag class="xmlpi">dbhtml dir</tag> processing instruction
-to specify the output directory. You can also combine the two
-specifications in one processing instruction: 
-<tag class="xmlpi">dbhtml dir="mydir" filename="myfile.html"</tag>.</para>
-
-
-  </refsect1><refsect1><title>Parameters</title>
-    
-<variablelist>
-      <varlistentry><term>filename="<replaceable>path</replaceable>"</term>
-        <listitem>
-          
-<para>Specifies the filename for the file</para>
-
-        </listitem>
-      </varlistentry>
-    </variablelist>
-
-  </refsect1><refsect1 role="params"><title>Related Global Parameters</title>
-    
-<para><parameter>use.id.as.filename</parameter></para>
-
-  </refsect1><refsect1 role="tcg"><title>Related Information in <link xlink:href="http://www.sagehill.net/docbookxsl/">DocBook XSL: The Complete Guide</link></title>
-    
-<para><link role="tcg" xlink:href="Chunking.html#DbhtmlFilenames">dbhtml filenames</link></para>
-
-  </refsect1></refentry>
-
-<refentry id="dbhtml_funcsynopsis-style" xml:base="../html/pi.xml">
-<refnamediv>
-<refname>dbhtml_funcsynopsis-style</refname>
-<refpurpose>Specifies presentation style for a funcsynopsis</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-
-    <synopsis><tag class="xmlpi">dbhtml funcsynopsis-style="kr"|"ansi"</tag></synopsis>
-  
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-    
-<para>Use the <tag class="xmlpi">dbhtml funcsynopsis-style</tag> PI as a child of
-      a <tag>funcsynopsis</tag> or anywhere within a funcsynopsis
-      to control the presentation style for output of all
-      <tag>funcprototype</tag> instances within that funcsynopsis.</para>
-
-  </refsect1><refsect1><title>Parameters</title>
-    
-<variablelist>
-      <varlistentry><term>funcsynopsis-style="kr"</term>
-        <listitem>
-          
-<para>Displays <tag>funcprototype</tag> output in K&amp;R style</para>
-
-        </listitem>
-      </varlistentry>
-      <varlistentry><term>funcsynopsis-style="ansi"</term>
-        <listitem>
-          
-<para>Displays <tag>funcprototype</tag> output in ANSI style</para>
-
-        </listitem>
-      </varlistentry>
-    </variablelist>
-
-  </refsect1><refsect1 role="params"><title>Related Global Parameters</title>
-    
-<para><parameter>funcsynopsis.style</parameter></para>
-
-  </refsect1></refentry>
-
-<refentry id="dbhtml_img.src.path" xml:base="../html/pi.xml">
-<refnamediv>
-<refname>dbhtml_img.src.path</refname>
-<refpurpose>Specifies a path to the location of an image file</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-
-    <synopsis><tag class="xmlpi">dbhtml img.src.path="<replaceable>path</replaceable>"</tag></synopsis>
-  
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-    
-<para>Use the <tag class="xmlpi">dbhtml img.src.path</tag> PI before or
-      after an image (<tag>graphic</tag>,
-      <tag>inlinegraphic</tag>, <tag>imagedata</tag>, or
-      <tag>videodata</tag> element) as a sibling to the element,
-      to specify a path to the location of the image; in HTML
-      output, the value specified for the
-      <code>img.src.path</code> attribute is prepended to the
-      filename.</para>
-
-  </refsect1><refsect1><title>Parameters</title>
-    
-<variablelist>
-      <varlistentry><term>img.src.path="<replaceable>path</replaceable>"</term>
-        <listitem>
-          
-<para>Specifies the pathname to prepend to the name of the image file</para>
-
-        </listitem>
-      </varlistentry>
-    </variablelist>
-
-  </refsect1><refsect1 role="params"><title>Related Global Parameters</title>
-    
-<para><parameter>img.src.path</parameter></para>
-
-  </refsect1><refsect1 role="tcg"><title>Related Information in <link xlink:href="http://www.sagehill.net/docbookxsl/">DocBook XSL: The Complete Guide</link></title>
-    
-<para><link role="tcg" xlink:href="GraphicsLocations.html#UsingFileref">Using fileref</link></para>
-
-  </refsect1></refentry>
-
-<refentry id="dbhtml_label-width" xml:base="../html/pi.xml">
-<refnamediv>
-<refname>dbhtml_label-width</refname>
-<refpurpose>Specifies the label width for a qandaset</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-
-    <synopsis><tag class="xmlpi">dbhtml label-width="<replaceable>width</replaceable>"</tag></synopsis>
-  
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-    
-<para>Use the <tag class="xmlpi">dbhtml label-width</tag> PI as a child of a
-      <tag>qandaset</tag> to specify the width of labels.</para>
-
-  </refsect1><refsect1><title>Parameters</title>
-    
-<variablelist>
-      <varlistentry><term>label-width="<replaceable>width</replaceable>"</term>
-        <listitem>
-          
-<para>Specifies the label width (including units)</para>
-
-        </listitem>
-      </varlistentry>
-    </variablelist>
-
-  </refsect1><refsect1 role="tcg"><title>Related Information in <link xlink:href="http://www.sagehill.net/docbookxsl/">DocBook XSL: The Complete Guide</link></title>
-    
-<para><link role="tcg" xlink:href="QandAformat.html">Q and A formatting</link></para>
-
-  </refsect1></refentry>
-
-<refentry id="dbhtml_linenumbering.everyNth" xml:base="../html/pi.xml">
-<refnamediv>
-<refname>dbhtml_linenumbering.everyNth</refname>
-<refpurpose>Specifies interval for line numbers in verbatims</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-
-    <synopsis><tag class="xmlpi">dbhtml linenumbering.everyNth="<replaceable>N</replaceable>"</tag></synopsis>
-  
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-    
-<para>Use the <tag class="xmlpi">dbhtml linenumbering.everyNth</tag> PI as a child
-      of a &#8220;verbatim&#8221; element &#8211; <tag>programlisting</tag>,
-      <tag>screen</tag>, <tag>synopsis</tag> &#8212; to specify
-      the interval at which lines are numbered.</para>
-
-  </refsect1><refsect1><title>Parameters</title>
-    
-<variablelist>
-      <varlistentry><term>linenumbering.everyNth="<replaceable>N</replaceable>"</term>
-        <listitem>
-          
-<para>Specifies numbering interval; a number is output
-            before every <replaceable>N</replaceable>th line</para>
-
-        </listitem>
-      </varlistentry>
-    </variablelist>
-
-  </refsect1><refsect1 role="params"><title>Related Global Parameters</title>
-    
-<para><parameter>linenumbering.everyNth</parameter></para>
-
-  </refsect1><refsect1 role="tcg"><title>Related Information in <link xlink:href="http://www.sagehill.net/docbookxsl/">DocBook XSL: The Complete Guide</link></title>
-    
-<para><link role="tcg" xlink:href="AnnotateListing.html#LineNumbering">Line numbering</link></para>
-
-  </refsect1></refentry>
-
-<refentry id="dbhtml_linenumbering.separator" xml:base="../html/pi.xml">
-<refnamediv>
-<refname>dbhtml_linenumbering.separator</refname>
-<refpurpose>Specifies separator text for line numbers in verbatims</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-
-    <synopsis><tag class="xmlpi">dbhtml linenumbering.separator="<replaceable>text</replaceable>"</tag></synopsis>
-  
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-    
-<para>Use the <tag class="xmlpi">dbhtml linenumbering.separator</tag> PI as a child
-      of a &#8220;verbatim&#8221; element &#8211; <tag>programlisting</tag>,
-      <tag>screen</tag>, <tag>synopsis</tag> &#8212; to specify
-      the separator text output between the line numbers and content.</para>
-
-  </refsect1><refsect1><title>Parameters</title>
-    
-<variablelist>
-      <varlistentry><term>linenumbering.separator="<replaceable>text</replaceable>"</term>
-        <listitem>
-          
-<para>Specifies the text (zero or more characters)</para>
-
-        </listitem>
-      </varlistentry>
-    </variablelist>
-
-  </refsect1><refsect1 role="params"><title>Related Global Parameters</title>
-    
-<para><parameter>linenumbering.separator</parameter></para>
-
-  </refsect1><refsect1 role="tcg"><title>Related Information in <link xlink:href="http://www.sagehill.net/docbookxsl/">DocBook XSL: The Complete Guide</link></title>
-    
-<para><link role="tcg" xlink:href="AnnotateListing.html#LineNumbering">Line numbering</link></para>
-
-  </refsect1></refentry>
-
-<refentry id="dbhtml_linenumbering.width" xml:base="../html/pi.xml">
-<refnamediv>
-<refname>dbhtml_linenumbering.width</refname>
-<refpurpose>Specifies width for line numbers in verbatims</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-
-    <synopsis><tag class="xmlpi">dbhtml linenumbering.width="<replaceable>width</replaceable>"</tag></synopsis>
-  
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-    
-<para>Use the <tag class="xmlpi">dbhtml linenumbering.width</tag> PI as a child
-      of a &#8220;verbatim&#8221; element &#8211; <tag>programlisting</tag>,
-      <tag>screen</tag>, <tag>synopsis</tag> &#8212; to specify
-      the width set aside for line numbers.</para>
-
-  </refsect1><refsect1><title>Parameters</title>
-    
-<variablelist>
-      <varlistentry><term>linenumbering.width="<replaceable>width</replaceable>"</term>
-        <listitem>
-          
-<para>Specifies the width (inluding units)</para>
-
-        </listitem>
-      </varlistentry>
-    </variablelist>
-
-  </refsect1><refsect1 role="params"><title>Related Global Parameters</title>
-    
-<para><parameter>linenumbering.width</parameter></para>
-
-  </refsect1><refsect1 role="tcg"><title>Related Information in <link xlink:href="http://www.sagehill.net/docbookxsl/">DocBook XSL: The Complete Guide</link></title>
-    
-<para><link role="tcg" xlink:href="AnnotateListing.html#LineNumbering">Line numbering</link></para>
-
-  </refsect1></refentry>
-
-<refentry id="dbhtml_list-presentation" xml:base="../html/pi.xml">
-<refnamediv>
-<refname>dbhtml_list-presentation</refname>
-<refpurpose>Specifies presentation style for a variablelist or
-    segmentedlist</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-
-    <synopsis><tag class="xmlpi">dbhtml list-presentation="list"|"table"</tag></synopsis>
-  
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-    
-<para>Use the <tag class="xmlpi">dbhtml list-presentation</tag> PI as a child of
-      a <tag>variablelist</tag> or <tag>segmentedlist</tag> to
-      control the presentation style for the list (to cause it, for
-      example, to be displayed as a table).</para>
-
-  </refsect1><refsect1><title>Parameters</title>
-    
-<variablelist>
-      <varlistentry><term>list-presentation="list"</term>
-        <listitem>
-          
-<para>Displays the list as a list</para>
-
-        </listitem>
-      </varlistentry>
-      <varlistentry><term>list-presentation="table"</term>
-        <listitem>
-          
-<para>Displays the list as a table</para>
-
-        </listitem>
-      </varlistentry>
-    </variablelist>
-
-  </refsect1><refsect1 role="params"><title>Related Global Parameters</title>
-    
-<itemizedlist>
-      <listitem>
-        
-<para><parameter>variablelist.as.table</parameter></para>
-
-      </listitem>
-      <listitem>
-        
-<para><parameter>segmentedlist.as.table</parameter></para>
-
-      </listitem>
-    </itemizedlist>
-
-  </refsect1><refsect1 role="tcg"><title>Related Information in <link xlink:href="http://www.sagehill.net/docbookxsl/">DocBook XSL: The Complete Guide</link></title>
-    
-<para><link role="tcg" xlink:href="Variablelists.html#VarListFormatting">Variable list formatting in HTML</link></para>
-
-  </refsect1></refentry>
-
-<refentry id="dbhtml_list-width" xml:base="../html/pi.xml">
-<refnamediv>
-<refname>dbhtml_list-width</refname>
-<refpurpose>Specifies the width of a variablelist or simplelist</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-
-    <synopsis><tag class="xmlpi">dbhtml list-width="<replaceable>width</replaceable>"</tag></synopsis>
-  
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-    
-<para>Use the <tag class="xmlpi">dbhtml list-width</tag> PI as a child of a
-      <tag>variablelist</tag> or a <tag>simplelist</tag> presented
-      as a table, to specify the output width.</para>
-
-  </refsect1><refsect1><title>Parameters</title>
-    
-<variablelist>
-      <varlistentry><term>list-width="<replaceable>width</replaceable>"</term>
-        <listitem>
-          
-<para>Specifies the output width (including units)</para>
-
-        </listitem>
-      </varlistentry>
-    </variablelist>
-
-  </refsect1><refsect1 role="tcg"><title>Related Information in <link xlink:href="http://www.sagehill.net/docbookxsl/">DocBook XSL: The Complete Guide</link></title>
-    
-<para><link role="tcg" xlink:href="Variablelists.html#VarListFormatting">Variable list formatting in HTML</link></para>
-
-  </refsect1></refentry>
-
-<refentry id="dbhtml_row-height" xml:base="../html/pi.xml">
-<refnamediv>
-<refname>dbhtml_row-height</refname>
-<refpurpose>Specifies the height for a CALS table row</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-
-    <synopsis><tag class="xmlpi">dbhtml row-height="<replaceable>height</replaceable>"</tag></synopsis>
-  
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-    
-<para>Use the <tag class="xmlpi">dbhtml row-height</tag> PI as a child of a
-      <tag>row</tag> to specify the height of the row.</para>
-
-  </refsect1><refsect1><title>Parameters</title>
-    
-<variablelist>
-      <varlistentry><term>row-height="<replaceable>height</replaceable>"</term>
-        <listitem>
-          
-<para>Specifies the row height (including units)</para>
-
-        </listitem>
-      </varlistentry>
-    </variablelist>
-
-  </refsect1><refsect1 role="tcg"><title>Related Information in <link xlink:href="http://www.sagehill.net/docbookxsl/">DocBook XSL: The Complete Guide</link></title>
-    
-<para><link role="tcg" xlink:href="RowHeight.html">Row height</link></para>
-
-  </refsect1></refentry>
-
-<refentry id="dbhtml_start" xml:base="../html/pi.xml">
-<refnamediv>
-<refname>dbhtml_start</refname>
-<refpurpose>(obsolete) Sets the starting number on an ordered list</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-
-    <synopsis><tag class="xmlpi">dbhtml start="<replaceable>character</replaceable>"</tag></synopsis>
-  
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-    
-<para><emphasis>This PI is obsolete</emphasis>. The intent of
-      this PI was to provide a means for setting a specific starting
-      number for an ordered list. Instead of this PI, set a value
-      for the <literal>override</literal> attribute on the first
-      <tag>listitem</tag> in the list; that will have the same
-      effect as what this PI was intended for.</para>
-
-  </refsect1><refsect1><title>Parameters</title>
-    
-<variablelist>
-      <varlistentry><term>start="<replaceable>character</replaceable>"</term>
-        <listitem>
-          
-<para>Specifies the character to use as the starting
-            number; use 0-9, a-z, A-Z, or lowercase or uppercase
-            Roman numerals</para>
-
-        </listitem>
-      </varlistentry>
-    </variablelist>
-
-  </refsect1><refsect1 role="tcg"><title>Related Information in <link xlink:href="http://www.sagehill.net/docbookxsl/">DocBook XSL: The Complete Guide</link></title>
-    
-<para><link role="tcg" xlink:href="Orderedlists.html#ListStartNum">List starting number</link></para>
-
-  </refsect1></refentry>
-
-<refentry id="dbhtml_stop-chunking" xml:base="../html/pi.xml">
-<refnamediv>
-<refname>dbhtml_stop-chunking</refname>
-<refpurpose>Do not chunk any descendants of this element.</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-
-    <synopsis><tag class="xmlpi">dbhtml stop-chunking</tag></synopsis>
-  
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-    
-<para>When generating chunked HTML output, adding this PI as the child of an element that contains elements that would normally be generated on separate pages if generating chunked output causes chunking to stop at this point. No descendants of the current element will be split into new HTML pages:
-<programlisting>&lt;section&gt;
-&lt;title&gt;Configuring pencil&lt;/title&gt;
-&lt;?dbhtml stop-chunking?&gt;
-
-...
-
-&lt;/section&gt;</programlisting>
-</para>
-
-  </refsect1><refsect1 role="tcg"><title>Related Information in <link xlink:href="http://www.sagehill.net/docbookxsl/">DocBook XSL: The Complete Guide</link></title>
-    
-<para><link role="tcg" xlink:href="Chunking.html">Chunking into multiple HTML files</link></para>
-
-  </refsect1></refentry>
-
-<refentry id="dbhtml_table-summary" xml:base="../html/pi.xml">
-<refnamediv>
-<refname>dbhtml_table-summary</refname>
-<refpurpose>Specifies summary for CALS table, variablelist, segmentedlist, or qandaset output</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-
-    <synopsis><tag class="xmlpi">dbhtml table-summary="<replaceable>text</replaceable>"</tag></synopsis>
-  
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-    
-<para>Use the <tag class="xmlpi">dbhtml table-summary</tag> PI as a child of
-      a CALS <tag>table</tag>, <tag>variablelist</tag>,
-      <tag>segmentedlist</tag>, or <tag>qandaset</tag> to specify
-      the text for the HTML <literal>summary</literal> attribute
-      in the output HTML table.</para>
-
-  </refsect1><refsect1><title>Parameters</title>
-    
-<variablelist>
-      <varlistentry><term>table-summary="<replaceable>text</replaceable>"</term>
-        <listitem>
-          
-<para>Specifies the summary text (zero or more characters)</para>
-
-        </listitem>
-      </varlistentry>
-    </variablelist>
-
-  </refsect1><refsect1 role="tcg"><title>Related Information in <link xlink:href="http://www.sagehill.net/docbookxsl/">DocBook XSL: The Complete Guide</link></title>
-    
-<para><link role="tcg" xlink:href="Variablelists.html#VarListFormatting">Variable list formatting in HTML</link>,
-      <link role="tcg" xlink:href="TableSummary.html">Table summary text</link></para>
-
-  </refsect1></refentry>
-
-<refentry id="dbhtml_table-width" xml:base="../html/pi.xml">
-<refnamediv>
-<refname>dbhtml_table-width</refname>
-<refpurpose>Specifies the width for a CALS table</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-
-    <synopsis><tag class="xmlpi">dbhtml table-width="<replaceable>width</replaceable>"</tag></synopsis>
-  
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-    
-<para>Use the <tag class="xmlpi">dbhtml table-width</tag> PI as a child of a
-      CALS <tag>table</tag> to specify the width of the table in
-      output.</para>
-
-  </refsect1><refsect1><title>Parameters</title>
-    
-<variablelist>
-      <varlistentry><term>table-width="<replaceable>width</replaceable>"</term>
-        <listitem>
-          
-<para>Specifies the table width (including units or as a percentage)</para>
-
-        </listitem>
-      </varlistentry>
-    </variablelist>
-
-  </refsect1><refsect1 role="params"><title>Related Global Parameters</title>
-    
-<para><parameter>default.table.width</parameter></para>
-
-  </refsect1><refsect1 role="tcg"><title>Related Information in <link xlink:href="http://www.sagehill.net/docbookxsl/">DocBook XSL: The Complete Guide</link></title>
-    
-<para><link role="tcg" xlink:href="Tables.html#TableWidth">Table width</link></para>
-
-  </refsect1></refentry>
-
-<refentry id="dbhtml_term-presentation" xml:base="../html/pi.xml">
-<refnamediv>
-<refname>dbhtml_term-presentation</refname>
-<refpurpose>Sets character formatting for terms in a variablelist</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-
-    <synopsis><tag class="xmlpi">dbhtml term-presentation="bold"|"italic"|"bold-italic"</tag></synopsis>
-  
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-    
-<para>Use the <tag class="xmlpi">dbhtml term-presentation</tag> PI as a child
-      of a <tag>variablelist</tag> to set character formatting for
-      the <tag>term</tag> output of the list.</para>
-
-  </refsect1><refsect1><title>Parameters</title>
-    
-<variablelist>
-      <varlistentry><term>term-presentation="<replaceable>bold</replaceable>"</term>
-        <listitem>
-          
-<para>Specifies that terms are displayed in bold</para>
-
-        </listitem>
-      </varlistentry>
-      <varlistentry><term>term-presentation="<replaceable>italic</replaceable>"</term>
-        <listitem>
-          
-<para>Specifies that terms are displayed in italic</para>
-
-        </listitem>
-      </varlistentry>
-      <varlistentry><term>term-presentation="<replaceable>bold-italic</replaceable>"</term>
-        <listitem>
-          
-<para>Specifies that terms are displayed in bold-italic</para>
-
-        </listitem>
-      </varlistentry>
-    </variablelist>
-
-  </refsect1><refsect1 role="tcg"><title>Related Information in <link xlink:href="http://www.sagehill.net/docbookxsl/">DocBook XSL: The Complete Guide</link></title>
-    
-<para><link role="tcg" xlink:href="Variablelists.html#VarListFormatting">Variable list formatting in HTML</link></para>
-
-  </refsect1></refentry>
-
-<refentry id="dbhtml_term-separator" xml:base="../html/pi.xml">
-<refnamediv>
-<refname>dbhtml_term-separator</refname>
-<refpurpose>Specifies separator text among terms in a varlistentry</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-
-    <synopsis><tag class="xmlpi">dbhtml term-separator="<replaceable>text</replaceable>"</tag></synopsis>
-  
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-    
-<para>Use the <tag class="xmlpi">dbhtml term-separator</tag> PI as a child
-      of a <tag>variablelist</tag> to specify the separator text
-      among <tag>term</tag> instances.</para>
-
-  </refsect1><refsect1><title>Parameters</title>
-    
-<variablelist>
-      <varlistentry><term>term-separator="<replaceable>text</replaceable>"</term>
-        <listitem>
-          
-<para>Specifies the text (zero or more characters)</para>
-
-        </listitem>
-      </varlistentry>
-    </variablelist>
-
-  </refsect1><refsect1 role="params"><title>Related Global Parameters</title>
-    
-<para><parameter>variablelist.term.separator</parameter></para>
-
-  </refsect1><refsect1 role="tcg"><title>Related Information in <link xlink:href="http://www.sagehill.net/docbookxsl/">DocBook XSL: The Complete Guide</link></title>
-    
-<para><link role="tcg" xlink:href="Variablelists.html#VarListFormatting">Variable list formatting in HTML</link></para>
-
-  </refsect1></refentry>
-
-<refentry id="dbhtml_term-width" xml:base="../html/pi.xml">
-<refnamediv>
-<refname>dbhtml_term-width</refname>
-<refpurpose>Specifies the term width for a variablelist</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-
-    <synopsis><tag class="xmlpi">dbhtml term-width="<replaceable>width</replaceable>"</tag></synopsis>
-  
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-    
-<para>Use the <tag class="xmlpi">dbhtml term-width</tag> PI as a child of a
-      <tag>variablelist</tag> to specify the width for
-      <tag>term</tag> output.</para>
-
-  </refsect1><refsect1><title>Parameters</title>
-    
-<variablelist>
-      <varlistentry><term>term-width="<replaceable>width</replaceable>"</term>
-        <listitem>
-          
-<para>Specifies the term width (including units)</para>
-
-        </listitem>
-      </varlistentry>
-    </variablelist>
-
-  </refsect1><refsect1 role="tcg"><title>Related Information in <link xlink:href="http://www.sagehill.net/docbookxsl/">DocBook XSL: The Complete Guide</link></title>
-    
-<para><link role="tcg" xlink:href="Variablelists.html#VarListFormatting">Variable list formatting in HTML</link></para>
-
-  </refsect1></refentry>
-
-<refentry id="dbhtml_toc" xml:base="../html/pi.xml">
-<refnamediv>
-<refname>dbhtml_toc</refname>
-<refpurpose>Specifies whether a TOC should be generated for a qandaset</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-
-    <synopsis><tag class="xmlpi">dbhtml toc="0"|"1"</tag></synopsis>
-  
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-    
-<para>Use the <tag class="xmlpi">dbhtml toc</tag> PI as a child of a
-      <tag>qandaset</tag> to specify whether a table of contents
-      (TOC) is generated for the <tag>qandaset</tag>.</para>
-
-  </refsect1><refsect1><title>Parameters</title>
-    
-<variablelist>
-      <varlistentry><term>toc="0"</term>
-        <listitem>
-          
-<para>If zero, no TOC is generated</para>
-
-        </listitem>
-      </varlistentry>
-      <varlistentry><term>toc="1"</term>
-        <listitem>
-          
-<para>If <code>1</code> (or any non-zero value),
-            a TOC is generated</para>
-
-        </listitem>
-      </varlistentry>
-    </variablelist>
-
-  </refsect1><refsect1 role="tcg"><title>Related Information in <link xlink:href="http://www.sagehill.net/docbookxsl/">DocBook XSL: The Complete Guide</link></title>
-    
-<para><link role="tcg" xlink:href="QandAtoc.html">Q and A list of questions</link>,
-      <link role="tcg" xlink:href="QandAformat.html">Q and A formatting</link></para>
-
-  </refsect1></refentry>
-
-<refentry id="dbcmdlist" xml:base="../html/pi.xml">
-<refnamediv>
-<refname>dbcmdlist</refname>
-<refpurpose>Generates a hyperlinked list of commands</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-
-    <synopsis><tag class="xmlpi">dbcmdlist</tag></synopsis>
-  
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-    
-<para>Use the <tag class="xmlpi">dbcmdlist</tag> PI as the child of any
-      element (for example, <tag>refsynopsisdiv</tag>) containing multiple
-      <tag>cmdsynopsis</tag> instances; a hyperlinked navigational
-      &#8220;command list&#8221; will be generated at the top of output for that
-      element, enabling users to quickly jump
-      to each command synopsis.</para>
-
-  </refsect1><refsect1><title>Parameters</title>
-    
-<para>[No parameters]</para>
-
-  </refsect1></refentry>
-
-<refentry id="dbfunclist" xml:base="../html/pi.xml">
-<refnamediv>
-<refname>dbfunclist</refname>
-<refpurpose>Generates a hyperlinked list of functions</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-
-    <synopsis><tag class="xmlpi">dbfunclist</tag></synopsis>
-  
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-    
-<para>Use the <tag class="xmlpi">dbfunclist</tag> PI as the child of any
-      element (for example, <tag>refsynopsisdiv</tag>) containing multiple
-      <tag>funcsynopsis</tag> instances; a hyperlinked
-      navigational &#8220;function list&#8221; will be generated at the top of
-      output for that element, enabling users to quickly
-      jump to to each function synopsis.</para>
-
-  </refsect1><refsect1><title>Parameters</title>
-    
-<para>[No parameters]</para>
-
-  </refsect1></refentry>
-
-<refentry id="dbhtml-include_href" xml:base="../html/pi.xml">
-<refnamediv>
-<refname>dbhtml-include_href</refname>
-<refpurpose>Copies an external well-formed HTML/XML file into current doc</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-
-    <synopsis><tag class="xmlpi">dbhtml-include href="<replaceable>URI</replaceable>"</tag></synopsis>
-  
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-    
-<para>Use the <tag class="xmlpi">dbhtml-include href</tag> PI anywhere in a
-      document to cause the contents of the file referenced by the
-      <code>href</code> pseudo-attribute to be copied/inserted &#8220;as
-      is&#8221; into your HTML output at the point in document order
-      where the PI occurs in the source.</para>
-
-    <note>
-      
-<para>The referenced file may contain plain text (as long as
-        it is &#8220;wrapped&#8221; in an <tag>html</tag> element &#8212; see the
-        note below) or markup in any arbitrary vocabulary,
-        including HTML &#8212; but it must conform to XML
-        well-formedness constraints (because the feature in XSLT
-        1.0 for opening external files, the
-        <function>document()</function> function, can only handle
-        files that meet XML well-formedness constraints).</para>
-
-      
-<para>Among other things, XML well-formedness constraints
-        require a document to have <emphasis>a single root
-          element</emphasis>. So if the content you want to
-        include is plain text or is markup that does
-        <emphasis>not</emphasis> have a single root element,
-        <emphasis role="strong">wrap the content in an
-          <tag>html</tag> element</emphasis>. The stylesheets will
-        strip out that surrounding <tag>html</tag> &#8220;wrapper&#8221; when
-        they find it, leaving just the content you want to
-        insert.</para>
-
-    </note>
-  </refsect1><refsect1><title>Parameters</title>
-    
-<variablelist>
-      <varlistentry><term>href="<replaceable>URI</replaceable>"</term>
-        <listitem>
-          
-<para>Specifies the URI for the file to include; the URI
-            can be, for example, a remote <literal>http:</literal>
-            URI, or a local filesystem <literal>file:</literal>
-            URI</para>
-
-        </listitem>
-      </varlistentry>
-    </variablelist>
-
-  </refsect1><refsect1 role="params"><title>Related Global Parameters</title>
-    
-<para><parameter>textinsert.extension</parameter></para>
-
-  </refsect1><refsect1 role="tcg"><title>Related Information in <link xlink:href="http://www.sagehill.net/docbookxsl/">DocBook XSL: The Complete Guide</link></title>
-    
-<para><link role="tcg" xlink:href="InsertExtHtml.html">Inserting external HTML code</link>,
-      <link role="tcg" xlink:href="ExternalCode.html">External code files</link></para>
-
-  </refsect1></refentry>
-
-<refentry id="dbhh" xml:base="../html/pi.xml">
-<refnamediv>
-<refname>dbhh</refname>
-<refpurpose>Sets topic name and topic id for context-sensitive HTML Help</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-
-    <synopsis><tag class="xmlpi">dbhh topicname="<replaceable>name</replaceable>" topicid="<replaceable>id</replaceable>"</tag></synopsis>
-  
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-    
-<para>Use the <tag class="xmlpi">dbhh</tag> PI as a child of components
-      that should be used as targets for context-sensitive help requests.</para>
-
-  </refsect1><refsect1><title>Parameters</title>
-    
-<variablelist>
-      <varlistentry><term>topicname="<replaceable>name</replaceable>"</term>
-        <listitem>
-          
-<para>Specifies a unique string constant that identifies a help topic</para>
-
-        </listitem>
-      </varlistentry>
-      <varlistentry><term>topicid="<replaceable>id</replaceable>"</term>
-        <listitem>
-          
-<para>Specifies a unique integer value for the <literal>topicname</literal> string</para>
-
-        </listitem>
-      </varlistentry>
-    </variablelist>
-
-  </refsect1><refsect1 role="tcg"><title>Related Information in <link xlink:href="http://www.sagehill.net/docbookxsl/">DocBook XSL: The Complete Guide</link></title>
-    
-<para><link role="tcg" xlink:href="HtmlHelp.html#HHContextHelp">Context-sensitive help</link></para>
-
-  </refsect1></refentry>
-
-    </part>
-    <part id="pi-fo">
-      <info xml:base="../fo/pi.xml"><title>FO Processing Instruction Reference</title>
-    <releaseinfo role="meta">
-      $Id: pi.xsl 9267 2012-04-03 20:23:45Z bobstayton $
-    </releaseinfo>
-  </info>
-
-  <partintro id="partintro" xml:base="../fo/pi.xml">
-    <title>Introduction</title>
-
-    
-<para>This is generated reference documentation for all
-      user-specifiable processing instructions (PIs) in the DocBook
-      XSL stylesheets for FO output.
-      <note>
-        
-<para>You add these PIs at particular points in a document to
-          cause specific &#8220;exceptions&#8221; to formatting/output behavior. To
-          make global changes in formatting/output behavior across an
-          entire document, it&#8217;s better to do it by setting an
-          appropriate stylesheet parameter (if there is one).</para>
-
-      </note>
-    </para>
-
-  </partintro>
-
-<refentry id="dbfo_background-color" xml:base="../fo/pi.xml">
-<refnamediv>
-<refname>dbfo_background-color</refname>
-<refpurpose>Sets background color for an image</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-
-    <synopsis><tag class="xmlpi">dbfo background-color="<replaceable>color</replaceable>"</tag></synopsis>
-  
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-    
-<para>Use the <tag class="xmlpi">dbfo background-color</tag> PI before or
-      after an image (<tag>graphic</tag>, <tag>inlinegraphic</tag>,
-      <tag>imagedata</tag>, or <tag>videodata</tag> element) as a
-      sibling to the element, to set a background color for the
-      image.</para>
-
-  </refsect1><refsect1><title>Parameters</title>
-    
-<variablelist>
-      <varlistentry><term>background-color="<replaceable>color</replaceable>"</term>
-        <listitem>
-          
-<para>An HTML color value</para>
-
-        </listitem>
-      </varlistentry>
-    </variablelist>
-
-  </refsect1><refsect1 role="tcg"><title>Related Information in <link xlink:href="http://www.sagehill.net/docbookxsl/">DocBook XSL: The Complete Guide</link></title>
-    
-<para><link role="tcg" xlink:href="BGcolor.html">Background color</link></para>
-
-  </refsect1></refentry>
-
-<refentry id="dbfo_bgcolor" xml:base="../fo/pi.xml">
-<refnamediv>
-<refname>dbfo_bgcolor</refname>
-<refpurpose>Sets background color on a table row or table cell</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-
-    <synopsis><tag class="xmlpi">dbfo bgcolor="<replaceable>color</replaceable>"</tag></synopsis>
-  
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-    
-<para>Use the <tag class="xmlpi">dbfo bgcolor</tag> PI as child of a table row
-      or cell to set a background color for that table row or cell.</para>
-
-    
-<para>This PI works for both CALS and HTML tables.</para>
-
-  </refsect1><refsect1><title>Parameters</title>
-    
-<variablelist>
-      <varlistentry><term>bgcolor="<replaceable>color</replaceable>"</term>
-        <listitem>
-          
-<para>An HTML color value</para>
-
-        </listitem>
-      </varlistentry>
-    </variablelist>
-
-  </refsect1><refsect1 role="tcg"><title>Related Information in <link xlink:href="http://www.sagehill.net/docbookxsl/">DocBook XSL: The Complete Guide</link></title>
-    
-<para><link role="tcg" xlink:href="BGtableColor.html#CellBGColor">Cell background color</link></para>
-
-  </refsect1></refentry>
-
-<refentry id="dbfo_float-type" xml:base="../fo/pi.xml">
-<refnamediv>
-<refname>dbfo_float-type</refname>
-<refpurpose>Specifies float behavior for a sidebar</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-
-    <synopsis><tag class="xmlpi">dbfo float-type="margin.note"</tag></synopsis>
-  
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-    
-<para>Use the <tag class="xmlpi">dbfo float-type</tag> PI to specify the float
-      behavior for a <tag>sidebar</tag> (to cause the sidebar to be
-      displayed as a marginal note).</para>
-
-  </refsect1><refsect1><title>Parameters</title>
-    
-<variablelist>
-      <varlistentry><term>float-type="margin.note"</term>
-        <listitem>
-          
-<para>Specifies that the <tag>sidebar</tag> should be
-            displayed as a marginal note.</para>
-
-        </listitem>
-      </varlistentry>
-    </variablelist>
-
-  </refsect1><refsect1 role="params"><title>Related Global Parameters</title>
-    
-<para><parameter>sidebar.float.type</parameter> (parameter),
-      <parameter>sidebar.float.width</parameter> (parameter), 
-      <parameter>sidebar.properties</parameter> (attribute-set),
-      <parameter>sidebar.title.properties</parameter> (attribute-set)
-    </para>
-
-  </refsect1><refsect1 role="tcg"><title>Related Information in <link xlink:href="http://www.sagehill.net/docbookxsl/">DocBook XSL: The Complete Guide</link></title>
-    
-<para><link role="tcg" xlink:href="SideFloats.html#SidebarFloats">A sidebar as
-        side float</link></para>
-
-  </refsect1></refentry>
-
-<refentry id="dbfo_funcsynopsis-style" xml:base="../fo/pi.xml">
-<refnamediv>
-<refname>dbfo_funcsynopsis-style</refname>
-<refpurpose>Specifies presentation style for a funcsynopsis</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-
-    <synopsis><tag class="xmlpi">dbfo funcsynopsis-style="kr"|"ansi"</tag></synopsis>
-  
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-    
-<para>Use the <tag class="xmlpi">dbfo funcsynopsis-style</tag> PI as a child of
-      a <tag>funcsynopsis</tag> or anywhere within a funcsynopsis
-      to control the presentation style for output of all
-      <tag>funcprototype</tag> instances within that funcsynopsis.</para>
-
-  </refsect1><refsect1><title>Parameters</title>
-    
-<variablelist>
-      <varlistentry><term>funcsynopsis-style="kr"</term>
-        <listitem>
-          
-<para>Displays <tag>funcprototype</tag> output in K&amp;R style</para>
-
-        </listitem>
-      </varlistentry>
-      <varlistentry><term>funcsynopsis-style="ansi"</term>
-        <listitem>
-          
-<para>Displays <tag>funcprototype</tag> output in ANSI style</para>
-
-        </listitem>
-      </varlistentry>
-    </variablelist>
-
-  </refsect1><refsect1 role="params"><title>Related Global Parameters</title>
-    
-<para><parameter>funcsynopsis.style</parameter></para>
-
-  </refsect1></refentry>
-
-<refentry id="dbfo_glossary-presentation" xml:base="../fo/pi.xml">
-<refnamediv>
-<refname>dbfo_glossary-presentation</refname>
-<refpurpose>Specifies presentation style for a glossary</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-
-    <synopsis><tag class="xmlpi">dbfo glossary-presentation="list"|"blocks"</tag></synopsis>
-  
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-    
-<para>Use the <tag class="xmlpi">dbfo glossary-presentation</tag> PI as a child of
-      a <tag>glossary</tag> to control its presentation style.</para>
-
-  </refsect1><refsect1><title>Parameters</title>
-    
-<variablelist>
-      <varlistentry><term>glossary-presentation="list"</term>
-        <listitem>
-          
-<para>Displays the glossary as a list</para>
-
-        </listitem>
-      </varlistentry>
-      <varlistentry><term>glossary-presentation="blocks"</term>
-        <listitem>
-          
-<para>Displays the glossary as blocks</para>
-
-        </listitem>
-      </varlistentry>
-    </variablelist>
-
-  </refsect1><refsect1 role="params"><title>Related Global Parameters</title>
-    
-<para><parameter>glossary.as.blocks</parameter></para>
-
-  </refsect1><refsect1 role="tcg"><title>Related Information in <link xlink:href="http://www.sagehill.net/docbookxsl/">DocBook XSL: The Complete Guide</link></title>
-    
-<para><link role="tcg" xlink:href="Glossaries.html#GlossaryFormatPrint">Glossary
-        formatting in print</link></para>
-
-  </refsect1></refentry>
-
-<refentry id="dbfo_glosslist-presentation" xml:base="../fo/pi.xml">
-<refnamediv>
-<refname>dbfo_glosslist-presentation</refname>
-<refpurpose>Specifies presentation style for a glosslist</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-
-    <synopsis><tag class="xmlpi">dbfo glosslist-presentation="list"|"blocks"</tag></synopsis>
-  
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-    
-<para>Use the <tag class="xmlpi">dbfo glosslist-presentation</tag> PI as a child of
-      a <tag>glosslist</tag> to control its presentation style.</para>
-
-  </refsect1><refsect1><title>Parameters</title>
-    
-<variablelist>
-      <varlistentry><term>glosslist-presentation="list"</term>
-        <listitem>
-          
-<para>Displays the glosslist as a list</para>
-
-        </listitem>
-      </varlistentry>
-      <varlistentry><term>glosslist-presentation="blocks"</term>
-        <listitem>
-          
-<para>Displays the glosslist as blocks</para>
-
-        </listitem>
-      </varlistentry>
-    </variablelist>
-
-  </refsect1><refsect1 role="params"><title>Related Global Parameters</title>
-    
-<para><parameter>glosslist.as.blocks</parameter> </para>
-
-  </refsect1><refsect1 role="tcg"><title>Related Information in <link xlink:href="http://www.sagehill.net/docbookxsl/">DocBook XSL: The Complete Guide</link></title>
-    
-<para><link role="tcg" xlink:href="Glossaries.html#GlossaryFormatPrint">Glossary
-        formatting in print</link></para>
-
-  </refsect1></refentry>
-
-<refentry id="dbfo_glossterm-width" xml:base="../fo/pi.xml">
-<refnamediv>
-<refname>dbfo_glossterm-width</refname>
-<refpurpose>Specifies the glossterm width for a glossary or
-    glosslist</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-
-    <synopsis><tag class="xmlpi">dbfo glossterm-width="<replaceable>width</replaceable>"</tag></synopsis>
-  
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-    
-<para>Use the <tag class="xmlpi">dbfo glossterm-width</tag> PI as a child of a
-      <tag>glossary</tag> or <tag>glosslist</tag> to specify the
-      width for output of <tag>glossterm</tag> instances in the
-      output.</para>
-
-  </refsect1><refsect1><title>Parameters</title>
-    
-<variablelist>
-      <varlistentry><term>glossterm-width="<replaceable>width</replaceable>"</term>
-        <listitem>
-          
-<para>Specifies the glossterm width (including units)</para>
-
-        </listitem>
-      </varlistentry>
-    </variablelist>
-
-  </refsect1><refsect1 role="params"><title>Related Global Parameters</title>
-    
-<para><parameter>glossterm.width</parameter>,
-      <parameter>glossterm.separation</parameter>
-    </para>
-
-  </refsect1><refsect1 role="tcg"><title>Related Information in <link xlink:href="http://www.sagehill.net/docbookxsl/">DocBook XSL: The Complete Guide</link></title>
-    
-<para><link role="tcg" xlink:href="Glossaries.html#GlossaryFormatPrint">Glossary
-        formatting in print</link></para>
-
-  </refsect1></refentry>
-
-<refentry id="dbfo_keep-together" xml:base="../fo/pi.xml">
-<refnamediv>
-<refname>dbfo_keep-together</refname>
-<refpurpose>Specifies &#8220;keep&#8221; behavior for a table, example,
-    figure, equation, procedure, or task</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-
-    <synopsis><tag class="xmlpi">dbfo keep-together="auto"|"always"</tag></synopsis>
-  
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-    
-<para>Use the <tag class="xmlpi">dbfo keep-together</tag> PI as a child of a
-      formal object (<tag>table</tag>, <tag>example</tag>,
-      <tag>figure</tag>, <tag>equation</tag>, <tag>procedure</tag>, or
-      <tag>task</tag>) to specify &#8220;keep&#8221; behavior (to allow the object to 
-    &#8220;break&#8221; across a page).</para>
-
-    
-<para>The PI also works with <tag>informaltable</tag>, <tag>informalexample</tag>,
-      <tag>informalfigure</tag> and <tag>informalequation</tag>.
-    </para>
-
-
-  </refsect1><refsect1><title>Parameters</title>
-    
-<variablelist>
-      <varlistentry><term>keep-together="auto"</term>
-        <listitem>
-          
-<para>Enables the object to break across a page</para>
-
-        </listitem>
-      </varlistentry>
-      <varlistentry><term>keep-together="always"</term>
-        <listitem>
-          
-<para>Prevents the object from breaking across a page (the
-            default stylesheet behavior)</para>
-
-        </listitem>
-      </varlistentry>
-    </variablelist>
-
-  </refsect1><refsect1 role="params"><title>Related Global Parameters</title>
-    
-<para>formal.object.properties</para>
-
-  </refsect1><refsect1 role="tcg"><title>Related Information in <link xlink:href="http://www.sagehill.net/docbookxsl/">DocBook XSL: The Complete Guide</link></title>
-    
-<para><link role="tcg" xlink:href="PageBreaking.html#KeepTogetherPI">Keep-together processing instruction</link></para>
-
-  </refsect1></refentry>
-
-<refentry id="dbfo_label-width" xml:base="../fo/pi.xml">
-<refnamediv>
-<refname>dbfo_label-width</refname>
-<refpurpose>Specifies the label width for a qandaset, itemizedlist, orderedlist
-  or calloutlist</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-
-    <synopsis><tag class="xmlpi">dbfo label-width="<replaceable>width</replaceable>"</tag></synopsis>
-  
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-    
-<para>Use the <tag class="xmlpi">dbfo label-width</tag> PI as a child of a
-      <tag>qandaset</tag>, <tag>itemizedlist</tag>, <tag>orderedlist</tag>, 
-      or <tag>calloutlist</tag> to specify the width of labels.</para>
-
-  </refsect1><refsect1><title>Parameters</title>
-    
-<variablelist>
-      <varlistentry><term>label-width="<replaceable>width</replaceable>"</term>
-        <listitem>
-          
-<para>Specifies the label width (including units)</para>
-
-        </listitem>
-      </varlistentry>
-    </variablelist>
-
-  </refsect1><refsect1 role="tcg"><title>Related Information in <link xlink:href="http://www.sagehill.net/docbookxsl/">DocBook XSL: The Complete Guide</link></title>
-    
-<para><link role="tcg" xlink:href="QandAformat.html">Q and A formatting</link></para>
-
-  </refsect1></refentry>
-
-<refentry id="dbfo_linenumbering.everyNth" xml:base="../fo/pi.xml">
-<refnamediv>
-<refname>dbfo_linenumbering.everyNth</refname>
-<refpurpose>Specifies interval for line numbers in verbatims</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-
-    <synopsis><tag class="xmlpi">dbfo linenumbering.everyNth="<replaceable>N</replaceable>"</tag></synopsis>
-  
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-    
-<para>Use the <tag class="xmlpi">dbfo linenumbering.everyNth</tag> PI as a child
-      of a &#8220;verbatim&#8221; element &#8211; <tag>programlisting</tag>,
-      <tag>screen</tag>, <tag>synopsis</tag> &#8212; to specify
-      the interval at which lines are numbered.</para>
-
-  </refsect1><refsect1><title>Parameters</title>
-    
-<variablelist>
-      <varlistentry><term>linenumbering.everyNth="<replaceable>N</replaceable>"</term>
-        <listitem>
-          
-<para>Specifies numbering interval; a number is output
-            before every <replaceable>N</replaceable>th line</para>
-
-        </listitem>
-      </varlistentry>
-    </variablelist>
-
-  </refsect1><refsect1 role="params"><title>Related Global Parameters</title>
-    
-<para><parameter>linenumbering.everyNth</parameter></para>
-
-  </refsect1><refsect1 role="tcg"><title>Related Information in <link xlink:href="http://www.sagehill.net/docbookxsl/">DocBook XSL: The Complete Guide</link></title>
-    
-<para><link role="tcg" xlink:href="AnnotateListing.html#LineNumbering">Line numbering</link></para>
-
-  </refsect1></refentry>
-
-<refentry id="dbfo_linenumbering.separator" xml:base="../fo/pi.xml">
-<refnamediv>
-<refname>dbfo_linenumbering.separator</refname>
-<refpurpose>Specifies separator text for line numbers in verbatims</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-
-    <synopsis><tag class="xmlpi">dbfo linenumbering.separator="<replaceable>text</replaceable>"</tag></synopsis>
-  
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-    
-<para>Use the <tag class="xmlpi">dbfo linenumbering.separator</tag> PI as a child
-      of a &#8220;verbatim&#8221; element &#8211; <tag>programlisting</tag>,
-      <tag>screen</tag>, <tag>synopsis</tag> &#8212; to specify
-      the separator text output between the line numbers and content.</para>
-
-  </refsect1><refsect1><title>Parameters</title>
-    
-<variablelist>
-      <varlistentry><term>linenumbering.separator="<replaceable>text</replaceable>"</term>
-        <listitem>
-          
-<para>Specifies the text (zero or more characters)</para>
-
-        </listitem>
-      </varlistentry>
-    </variablelist>
-
-  </refsect1><refsect1 role="params"><title>Related Global Parameters</title>
-    
-<para><parameter>linenumbering.separator</parameter></para>
-
-  </refsect1><refsect1 role="tcg"><title>Related Information in <link xlink:href="http://www.sagehill.net/docbookxsl/">DocBook XSL: The Complete Guide</link></title>
-    
-<para><link role="tcg" xlink:href="AnnotateListing.html#LineNumbering">Line numbering</link></para>
-
-  </refsect1></refentry>
-
-<refentry id="dbfo_linenumbering.width" xml:base="../fo/pi.xml">
-<refnamediv>
-<refname>dbfo_linenumbering.width</refname>
-<refpurpose>Specifies width for line numbers in verbatims</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-
-    <synopsis><tag class="xmlpi">dbfo linenumbering.width="<replaceable>width</replaceable>"</tag></synopsis>
-  
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-    
-<para>Use the <tag class="xmlpi">dbfo linenumbering.width</tag> PI as a child
-      of a &#8220;verbatim&#8221; element &#8211; <tag>programlisting</tag>,
-      <tag>screen</tag>, <tag>synopsis</tag> &#8212; to specify
-      the width set aside for line numbers.</para>
-
-  </refsect1><refsect1><title>Parameters</title>
-    
-<variablelist>
-      <varlistentry><term>linenumbering.width="<replaceable>width</replaceable>"</term>
-        <listitem>
-          
-<para>Specifies the width (inluding units)</para>
-
-        </listitem>
-      </varlistentry>
-    </variablelist>
-
-  </refsect1><refsect1 role="params"><title>Related Global Parameters</title>
-    
-<para><parameter>linenumbering.width</parameter></para>
-
-  </refsect1><refsect1 role="tcg"><title>Related Information in <link xlink:href="http://www.sagehill.net/docbookxsl/">DocBook XSL: The Complete Guide</link></title>
-    
-<para><link role="tcg" xlink:href="AnnotateListing.html#LineNumbering">Line numbering</link></para>
-
-  </refsect1></refentry>
-
-<refentry id="dbfo_list-presentation" xml:base="../fo/pi.xml">
-<refnamediv>
-<refname>dbfo_list-presentation</refname>
-<refpurpose>Specifies presentation style for a variablelist or
-    segmentedlist</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-
-    <synopsis><tag class="xmlpi">dbfo list-presentation="list"|"blocks"|"table"</tag></synopsis>
-  
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-    
-<para>Use the <tag class="xmlpi">dbfo list-presentation</tag> PI as a child of
-      a <tag>variablelist</tag> or <tag>segmentedlist</tag> to
-      control the presentation style for the list (to cause it, for
-      example, to be displayed as a table).</para>
-
-  </refsect1><refsect1><title>Parameters</title>
-    
-<variablelist>
-      <varlistentry><term>list-presentation="list"</term>
-        <listitem>
-          
-<para>Displays the list as a list</para>
-
-        </listitem>
-      </varlistentry>
-      <varlistentry><term>list-presentation="blocks"</term>
-        <listitem>
-          
-<para>(<tag>variablelist</tag> only) Displays the list as blocks</para>
-
-        </listitem>
-      </varlistentry>
-      <varlistentry><term>list-presentation="table"</term>
-        <listitem>
-          
-<para>(<tag>segmentedlist</tag> only) Displays the list as a table</para>
-
-        </listitem>
-      </varlistentry>
-    </variablelist>
-
-  </refsect1><refsect1 role="params"><title>Related Global Parameters</title>
-    
-<itemizedlist>
-      <listitem>
-        
-<para><parameter>variablelist.as.blocks</parameter></para>
-
-      </listitem>
-      <listitem>
-        
-<para><parameter>variablelist.as.table</parameter></para>
-
-      </listitem>
-    </itemizedlist>
-
-  </refsect1><refsect1 role="tcg"><title>Related Information in <link xlink:href="http://www.sagehill.net/docbookxsl/">DocBook XSL: The Complete Guide</link></title>
-    
-<para><link role="tcg" xlink:href="Variablelists.html#ListIndents">Variable list formatting in print</link></para>
-
-  </refsect1></refentry>
-
-<refentry id="dbfo_list-width" xml:base="../fo/pi.xml">
-<refnamediv>
-<refname>dbfo_list-width</refname>
-<refpurpose>Specifies the width of a horizontal simplelist</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-
-    <synopsis><tag class="xmlpi">dbfo list-width="<replaceable>width</replaceable>"</tag></synopsis>
-  
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-    
-<para>Use the <tag class="xmlpi">dbfo list-width</tag> PI as a child of a
-      <tag>simplelist</tag> whose <tag class="attribute">class</tag>
-      value is <literal>horizontal</literal>, to specify the width
-      of the <tag>simplelist</tag>.</para>
-
-  </refsect1><refsect1><title>Parameters</title>
-    
-<variablelist>
-      <varlistentry><term>list-width="<replaceable>width</replaceable>"</term>
-        <listitem>
-          
-<para>Specifies the <tag>simplelist</tag> width (including units)</para>
-
-        </listitem>
-      </varlistentry>
-    </variablelist>
-
-  </refsect1></refentry>
-
-<refentry id="dbfo_orientation" xml:base="../fo/pi.xml">
-<refnamediv>
-<refname>dbfo_orientation</refname>
-<refpurpose>Specifies the orientation for a CALS table row or cell</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-
-    <synopsis><tag class="xmlpi">dbfo orientation="0"|"90"|"180"|"270"|"-90"|"-180"|"-270"</tag></synopsis>
-  
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-    
-<para>Use the <tag class="xmlpi">dbfo orientation</tag> PI as a child of a CALS
-      <tag>table</tag> row or cell to specify the orientation
-      (rotation) for the row or cell.</para>
-
-  </refsect1><refsect1><title>Parameters</title>
-    
-<variablelist>
-      <varlistentry><term>orientation="0"|"90"|"180"|"270"|"-90"|"-180"|"-270"</term>
-        <listitem>
-          
-<para>Specifies the number of degrees by which the cell or
-            row is rotated</para>
-
-        </listitem>
-      </varlistentry>
-    </variablelist>
-
-  </refsect1></refentry>
-
-<refentry id="dbfo_pgwide" xml:base="../fo/pi.xml">
-<refnamediv>
-<refname>dbfo_pgwide</refname>
-<refpurpose>Specifies if an <tag>equation</tag> or <tag>example</tag> goes across full page width</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-
-    <synopsis><tag class="xmlpi">dbfo pgwide="0"|"1"</tag></synopsis>
-  
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-    
-<para>Use the <tag class="xmlpi">dbfo pgwide</tag> PI as a child of an
-      <tag>equation</tag> or <tag>example</tag> to specify that the
-      content should rendered across the full width of the page.</para>
-
-  </refsect1><refsect1><title>Parameters</title>
-    
-<variablelist>
-      <varlistentry><term>pgwide="0"</term>
-        <listitem>
-          
-<para>If zero, the content is rendered across the current
-            text flow</para>
-
-        </listitem>
-      </varlistentry>
-      <varlistentry><term>pgwide="1"</term>
-        <listitem>
-          
-<para>If <code>1</code> (or any non-zero value), the
-            content is rendered across the full width of the page</para>
-
-        </listitem>
-      </varlistentry>
-    </variablelist>
-
-  </refsect1><refsect1 role="params"><title>Related Global Parameters</title>
-    
-<para><parameter>pgwide.properties</parameter></para>
-
-  </refsect1></refentry>
-
-<refentry id="dbfo_rotated-width" xml:base="../fo/pi.xml">
-<refnamediv>
-<refname>dbfo_rotated-width</refname>
-<refpurpose>Specifies the width for a CALS table <tag>entry</tag> or
-    <tag>row</tag></refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-
-    <synopsis><tag class="xmlpi">dbfo rotated-width="<replaceable>width</replaceable>"</tag></synopsis>
-  
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-    
-<para>Use the <tag class="xmlpi">dbfo rotated-width</tag> PI as a child of 
-      <tag>entry</tag> or <tag>row</tag> instance in a CALS table to specify the
-      width of that the <tag>entry</tag> or <tag>row</tag>; or
-      use it higher up in table to cause the width to be inherited
-      recursively down.</para>
-
-  </refsect1><refsect1><title>Parameters</title>
-    
-<variablelist>
-      <varlistentry><term>rotated-width="<replaceable>width</replaceable>"</term>
-        <listitem>
-          
-<para>Specifies the width of a row or cell (including units)</para>
-
-        </listitem>
-      </varlistentry>
-    </variablelist>
-
-  </refsect1></refentry>
-
-<refentry id="dbfo_sidebar-width" xml:base="../fo/pi.xml">
-<refnamediv>
-<refname>dbfo_sidebar-width</refname>
-<refpurpose>Specifies the width of a sidebar</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-
-    <synopsis><tag class="xmlpi">dbfo sidebar-width="<replaceable>width</replaceable>"</tag></synopsis>
-  
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-    
-<para>Use the <tag class="xmlpi">dbfo sidebar-width</tag> PI as a child of a
-      <tag>sidebar</tag> to specify the width of the sidebar.</para>
-
-  </refsect1><refsect1><title>Parameters</title>
-    
-<variablelist>
-      <varlistentry><term>sidebar-width="<replaceable>width</replaceable>"</term>
-        <listitem>
-          
-<para>Specifies the <tag>sidebar</tag> width (including units)</para>
-
-        </listitem>
-      </varlistentry>
-    </variablelist>
-
-  </refsect1><refsect1 role="params"><title>Related Global Parameters</title>
-    
-<para><parameter>sidebar.float.type parameter</parameter>,
-      <parameter>sidebar.float.width parameter</parameter>, 
-      <parameter>sidebar.properties attribute-set</parameter>,
-      <parameter>sidebar.title.properties</parameter>
-    </para>
-
-  </refsect1><refsect1 role="tcg"><title>Related Information in <link xlink:href="http://www.sagehill.net/docbookxsl/">DocBook XSL: The Complete Guide</link></title>
-    
-<para><link role="tcg" xlink:href="SideFloats.html#SidebarFloats">A sidebar as
-        side float</link></para>
-
-  </refsect1></refentry>
-
-<refentry id="dbfo_start" xml:base="../fo/pi.xml">
-<refnamediv>
-<refname>dbfo_start</refname>
-<refpurpose>(obsolete) Sets the starting number on an ordered list</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-
-    <synopsis><tag class="xmlpi">dbfo start="<replaceable>character</replaceable>"</tag></synopsis>
-  
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-    
-<para><emphasis>This PI is obsolete</emphasis>. The intent of
-      it was to provide a means for setting a specific starting
-      number for an ordered list. Instead of this PI, set a value
-      for the <literal>override</literal> attribute on the first
-      <tag>listitem</tag> in the list; that will have the same
-      effect as what this PI was intended for.</para>
-
-  </refsect1><refsect1><title>Parameters</title>
-    
-<variablelist>
-      <varlistentry><term>start="<replaceable>character</replaceable>"</term>
-        <listitem>
-          
-<para>Specifies the character to use as the starting
-            number; use 0-9, a-z, A-Z, or lowercase or uppercase
-            Roman numerals</para>
-
-        </listitem>
-      </varlistentry>
-    </variablelist>
-
-  </refsect1><refsect1 role="tcg"><title>Related Information in <link xlink:href="http://www.sagehill.net/docbookxsl/">DocBook XSL: The Complete Guide</link></title>
-    
-<para><link role="tcg" xlink:href="Orderedlists.html#ListStartNum">List starting number</link></para>
-
-  </refsect1></refentry>
-
-<refentry id="dbfo_table-width" xml:base="../fo/pi.xml">
-<refnamediv>
-<refname>dbfo_table-width</refname>
-<refpurpose>Specifies the width for a CALS table or for revhistory
-    output</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-
-    <synopsis><tag class="xmlpi">dbfo table-width="<replaceable>width</replaceable>"</tag></synopsis>
-  
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-    
-<para>Use the <tag class="xmlpi">dbfo table-width</tag> PI as a child or
-      sibling of a CALS <tag>table</tag>, or as a child of an
-      <tag>informaltable</tag>, <tag>entrytbl</tag>, or
-      <tag>revhistory</tag> instance (which is rendered as a table
-      in output) to specify the width of the table in output.</para>
-
-  </refsect1><refsect1><title>Parameters</title>
-    
-<variablelist>
-      <varlistentry><term>table-width="<replaceable>width</replaceable>"</term>
-        <listitem>
-          
-<para>Specifies the table width (including units or as a percentage)</para>
-
-        </listitem>
-      </varlistentry>
-    </variablelist>
-
-  </refsect1><refsect1 role="tcg"><title>Related Information in <link xlink:href="http://www.sagehill.net/docbookxsl/">DocBook XSL: The Complete Guide</link></title>
-    
-<para><link role="tcg" xlink:href="Tables.html#TableWidth">Table width</link></para>
-
-  </refsect1></refentry>
-
-<refentry id="dbfo_term-width" xml:base="../fo/pi.xml">
-<refnamediv>
-<refname>dbfo_term-width</refname>
-<refpurpose>Specifies the term width for a variablelist</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-
-    <synopsis><tag class="xmlpi">dbfo term-width="<replaceable>width</replaceable>"</tag></synopsis>
-  
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-    
-<para>Use the <tag class="xmlpi">dbfo term-width</tag> PI as a child of a
-      <tag>variablelist</tag> to specify the width for
-      <tag>term</tag> output.</para>
-
-  </refsect1><refsect1><title>Parameters</title>
-    
-<variablelist>
-      <varlistentry><term>term-width="<replaceable>width</replaceable>"</term>
-        <listitem>
-          
-<para>Specifies the term width (including units)</para>
-
-        </listitem>
-      </varlistentry>
-    </variablelist>
-
-  </refsect1><refsect1 role="tcg"><title>Related Information in <link xlink:href="http://www.sagehill.net/docbookxsl/">DocBook XSL: The Complete Guide</link></title>
-    
-<para><link role="tcg" xlink:href="Variablelists.html#ListIndents">Variable list formatting in print</link></para>
-
-  </refsect1></refentry>
-
-<refentry id="dbfo_toc" xml:base="../fo/pi.xml">
-<refnamediv>
-<refname>dbfo_toc</refname>
-<refpurpose>Specifies whether a TOC should be generated for a qandaset</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-
-    <synopsis><tag class="xmlpi">dbfo toc="0"|"1"</tag></synopsis>
-  
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-    
-<para>Use the <tag class="xmlpi">dbfo toc</tag> PI as a child of a
-      <tag>qandaset</tag> to specify whether a table of contents
-      (TOC) is generated for the <tag>qandaset</tag>.</para>
-
-  </refsect1><refsect1><title>Parameters</title>
-    
-<variablelist>
-      <varlistentry><term>toc="0"</term>
-        <listitem>
-          
-<para>If zero, no TOC is generated</para>
-
-        </listitem>
-      </varlistentry>
-      <varlistentry><term>toc="1"</term>
-        <listitem>
-          
-<para>If <code>1</code> (or any non-zero value),
-            a TOC is generated</para>
-
-        </listitem>
-      </varlistentry>
-    </variablelist>
-
-  </refsect1><refsect1 role="tcg"><title>Related Information in <link xlink:href="http://www.sagehill.net/docbookxsl/">DocBook XSL: The Complete Guide</link></title>
-    
-<para><link role="tcg" xlink:href="QandAtoc.html">Q and A list of questions</link>,
-      <link role="tcg" xlink:href="QandAformat.html">Q and A formatting</link></para>
-
-  </refsect1></refentry>
-
-<refentry id="dbfo-need" xml:base="../fo/pi.xml">
-<refnamediv>
-<refname>dbfo-need</refname>
-<refpurpose>Specify a need for space (a kind of soft page break)</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-
-    <synopsis><tag class="xmlpi">dbfo-need height="<replaceable>n</replaceable>" [space-before="<replaceable>n</replaceable>"]</tag></synopsis>
-  
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-    
-<para>A &#8220;need&#8221; is a request for space on a page.  If the
-      requested space is not available, the page breaks and the
-      content that follows the need request appears on the next
-      page. If the requested space is available, then no page break
-      is inserted.</para>
-
-  </refsect1><refsect1><title>Parameters</title>
-    
-<variablelist>
-      <varlistentry><term>height="<replaceable>n</replaceable>"</term>
-        <listitem>
-          
-<para>The amount of height needed (including units)</para>
-
-        </listitem>
-      </varlistentry>
-      <varlistentry><term>space-before="<replaceable>n</replaceable>"</term>
-        <listitem>
-          
-<para>The amount of extra vertical space to add (including units)</para>
-
-        </listitem>
-      </varlistentry>
-    </variablelist>
-
-  </refsect1><refsect1 role="tcg"><title>Related Information in <link xlink:href="http://www.sagehill.net/docbookxsl/">DocBook XSL: The Complete Guide</link></title>
-    
-<para><link role="tcg" xlink:href="PageBreaking.html#SoftPageBreaks">Soft page breaks</link></para>
-
-  </refsect1></refentry>
-
-<refentry id="dbfo_row-height" xml:base="../fo/pi.xml">
-<refnamediv>
-<refname>dbfo_row-height</refname>
-<refpurpose>Specifies the height for a CALS table row</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-
-    <synopsis><tag class="xmlpi">dbfo row-height="<replaceable>height</replaceable>"</tag></synopsis>
-  
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-    
-<para>Use the <tag class="xmlpi">dbfo row-height</tag> PI as a child of a
-      <tag>row</tag> to specify the height of the row.</para>
-
-  </refsect1><refsect1><title>Parameters</title>
-    
-<variablelist>
-      <varlistentry><term>row-height="<replaceable>height</replaceable>"</term>
-        <listitem>
-          
-<para>Specifies the row height (including units)</para>
-
-        </listitem>
-      </varlistentry>
-    </variablelist>
-
-  </refsect1><refsect1 role="tcg"><title>Related Information in <link xlink:href="http://www.sagehill.net/docbookxsl/">DocBook XSL: The Complete Guide</link></title>
-    
-<para><link role="tcg" xlink:href="RowHeight.html">Row height</link></para>
-
-  </refsect1></refentry>
-
-    </part>
-    <part id="pi-man">
-      <info xml:base="../manpages/pi.xml"><title>manpages Processing Instruction Reference</title>
-    <releaseinfo role="meta">
-      $Id: pi.xsl 7644 2008-01-16 11:04:07Z xmldoc $
-    </releaseinfo>
-  </info>
-  <partintro id="partintro" xml:base="../manpages/pi.xml">
-    <title>Introduction</title>
-    
-<para>This is generated reference documentation for all
-      user-specifiable processing instructions (PIs) in the DocBook
-      XSL stylesheets for manpages output.
-      <note>
-        
-<para>You add these PIs at particular points in a document to
-          cause specific &#8220;exceptions&#8221; to formatting/output behavior. To
-          make global changes in formatting/output behavior across an
-          entire document, it&#8217;s better to do it by setting an
-          appropriate stylesheet parameter (if there is one).</para>
-
-      </note>
-    </para>
-
-  </partintro>
-
-<refentry id="dbman_funcsynopsis-style" xml:base="../manpages/pi.xml">
-<refnamediv>
-<refname>dbman_funcsynopsis-style</refname>
-<refpurpose>Specifies presentation style for a funcsynopsis.</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-
-    <synopsis><tag class="xmlpi">dbman funcsynopsis-style="kr"|"ansi"</tag></synopsis>
-  
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-    
-<para>Use the <tag class="xmlpi">dbman
-        funcsynopsis-style</tag> PI as a child of a
-      <tag>funcsynopsis</tag> or anywhere within a funcsynopsis
-      to control the presentation style for output of all
-      <tag>funcprototype</tag> instances within that funcsynopsis.</para>
-
-  </refsect1><refsect1><title>Parameters</title>
-    
-<variablelist>
-      <varlistentry><term>funcsynopsis-style="kr"</term>
-        <listitem>
-          
-<para>Displays the <tag>funcprototype</tag> in K&amp;R style</para>
-
-        </listitem>
-      </varlistentry>
-      <varlistentry><term>funcsynopsis-style="ansi"</term>
-        <listitem>
-          
-<para>Displays the <tag>funcprototype</tag> in ANSI style</para>
-
-        </listitem>
-      </varlistentry>
-    </variablelist>
-
-  </refsect1><refsect1 role="params"><title>Related Global Parameters</title>
-    
-<para><parameter>man.funcsynopsis.style</parameter></para>
-
-  </refsect1></refentry>
-
-    </part>
-    <part id="pi-common">
-      <info xml:base="../common/pi.xml"><title>Common Processing Instruction Reference</title>
-    <releaseinfo role="meta">
-      $Id: pi.xsl 8782 2010-07-27 21:15:17Z mzjn $
-    </releaseinfo>
-  </info>
-  <partintro id="partintro" xml:base="../common/pi.xml">
-    <title>Introduction</title>
-    
-<para>This is generated reference documentation for all
-      user-specifiable processing instructions (PIs) in the
-      &#8220;common&#8221; part of the DocBook XSL stylesheets.
-      <note>
-        
-<para>You add these PIs at particular points in a document to
-          cause specific &#8220;exceptions&#8221; to formatting/output behavior. To
-          make global changes in formatting/output behavior across an
-          entire document, it&#8217;s better to do it by setting an
-          appropriate stylesheet parameter (if there is one).</para>
-
-      </note>
-    </para>
-
-  </partintro>
-
-<refentry id="dbchoice_choice" xml:base="../common/pi.xml">
-<refnamediv>
-<refname>dbchoice_choice</refname>
-<refpurpose>Generates a localized choice separator</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-
-    <synopsis><tag class="xmlpi">dbchoice choice="and"|"or"|<replaceable>string</replaceable>"</tag></synopsis>
-  
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-    
-<para>Use the <tag class="xmlpi">dbchoice choice</tag> PI to
-      generate an appropriate localized &#8220;choice&#8221; separator (for
-      example, <literal>and</literal> or <literal>or</literal>)
-      before the final item in an inline <tag>simplelist</tag></para>
-
-    <warning>
-      
-<para>This PI is a less-than-ideal hack; support for it may
-        disappear in the future (particularly if and when a more
-        appropriate means for marking up "choice" lists becomes
-        available in DocBook).</para>
-
-    </warning>
-  </refsect1><refsect1><title>Parameters</title>
-    
-<variablelist>
-      <varlistentry><term>choice="and"</term>
-        <listitem>
-          
-<para>generates a localized <literal>and</literal> separator</para>
-
-        </listitem>
-      </varlistentry>
-      <varlistentry><term>choice="or"</term>
-        <listitem>
-          
-<para>generates a localized <literal>or</literal> separator</para>
-
-        </listitem>
-      </varlistentry>
-      <varlistentry><term>choice="<replaceable>string</replaceable>"</term>
-        <listitem>
-          
-<para>generates a literal <replaceable>string</replaceable> separator</para>
-
-        </listitem>
-      </varlistentry>
-    </variablelist>
-
-  </refsect1></refentry>
-
-<refentry id="dbtimestamp" xml:base="../common/pi.xml">
-<refnamediv>
-<refname>dbtimestamp</refname>
-<refpurpose>Inserts a date timestamp</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-
-    <synopsis><tag class="xmlpi">dbtimestamp format="<replaceable>formatstring</replaceable>" [padding="0"|"1"]</tag></synopsis>
-  
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-    
-<para>Use the <tag class="xmlpi">dbtimestamp</tag> PI at any point in a
-      source document to cause a date timestamp (a formatted
-      string representing the current date and time) to be
-      inserted in output of the document.</para>
-
-  </refsect1><refsect1><title>Parameters</title>
-    
-<variablelist>
-      <varlistentry><term>format="<replaceable>formatstring</replaceable>"</term>
-        <listitem>
-          
-<para>Specifies format in which the date and time are
-            output</para>
-
-        <note>
-          
-<para>For details of the content of the format string,
-            see <link role="tcg" xlink:href="Datetime.html">Date and time</link>.</para>
-
-        </note>
-        </listitem>
-      </varlistentry>
-      <varlistentry><term>padding="0"|"1"</term>
-        <listitem>
-          
-<para>Specifies padding behavior; if non-zero, padding is is added</para>
-
-        </listitem>
-      </varlistentry>
-    </variablelist>
-
-  </refsect1></refentry>
-
-<refentry id="dbtex_delims" xml:base="../common/pi.xml">
-<refnamediv>
-<refname>dbtex_delims</refname>
-<refpurpose>Generates delimiters around embedded TeX equations
-    in output</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-
-    <synopsis><tag class="xmlpi">dbtex delims="no"|"yes"</tag></synopsis>
-  
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-    
-<para>Use the <tag class="xmlpi">dbtex delims</tag> PI as a
-      child of a <tag>textobject</tag> containing embedded TeX
-      markup, to cause that markup to be surrounded by
-      <literal>$</literal> delimiter characters in output.</para>
-
-      <warning>
-       
-<para>This feature is useful for print/PDF output only if you
-       use the obsolete and now unsupported PassiveTeX XSL-FO
-       engine.</para>
-
-      </warning>
-  </refsect1><refsect1><title>Parameters</title>
-    
-<variablelist>
-      <varlistentry><term>dbtex delims="no"|"yes"</term>
-        <listitem>
-          
-<para>Specifies whether delimiters are output</para>
-
-        </listitem>
-      </varlistentry>
-    </variablelist>
-
-  </refsect1><refsect1 role="params"><title>Related Global Parameters</title>
-    
-<para><parameter>tex.math.delims</parameter></para>
-
-  </refsect1></refentry>
-
-    </part>
-  </book>
-  <book id="developer"><title>DocBook XSL Stylesheets Developer&#160;Reference</title>
-    <info>
-      <abstract>
-        <para>This is technical reference documentation for
-          developers using the DocBook XSL Stylesheets. It is not
-          intended to be user documentation, but is instead
-          provided for developers writing customization layers for
-          the stylesheets.</para>
-      </abstract>
-    </info>
-    <part id="lib">
-      <?dbhtml dir="lib"?>
-      <?dbhtml filename="index.html"?>
-      <title xml:base="../lib/lib.xml">XSL Library Template Reference</title>
-      <partintro id="libintro">
-        <title xml:base="../lib/lib.xml">Introduction</title>
-      <para xml:base="../lib/lib.xml">This is technical reference documentation for the
-        vocabulary-independent &#8220;library&#8221; templates in the DocBook XSL
-        Stylesheets.</para>
-      <para xml:base="../lib/lib.xml">This is not intended to be user documentation.  It is
-        provided for developers writing customization layers for the
-        stylesheets.</para>
-    
-      </partintro>
-      <reference id="generallibrary" xml:base="../lib/lib.xml">
-    <title>General Library Templates</title>
-
-<refentry id="dot.count">
-<refnamediv>
-<refname>dot.count</refname>
-<refpurpose>Returns the number of <quote>.</quote> characters in a string</refpurpose>
-</refnamediv>
-
-<refsect1><title>Description</title>
-
-  <para>Given a string, the <function>dot.count</function>
-    template returns the number of dot/period characters in the
-    string. This template is useful, for example, when testing the
-    nesting level of nested inline markup (for nested emphasis,
-    quotations, etc.).</para>
-
-<programlisting id="dot.count.frag">
-&lt;xsl:template name="dot.count"&gt;
-  &lt;!-- Returns the number of "." characters in a string --&gt;
-  &lt;xsl:param name="string"&gt;&lt;/xsl:param&gt;
-  &lt;xsl:param name="count" select="0"&gt;&lt;/xsl:param&gt;
-  &lt;xsl:choose&gt;
-    &lt;xsl:when test="contains($string, '.')"&gt;
-      &lt;xsl:call-template name="dot.count"&gt;
-        &lt;xsl:with-param name="string" select="substring-after($string, '.')"&gt;&lt;/xsl:with-param&gt;
-        &lt;xsl:with-param name="count" select="$count+1"&gt;&lt;/xsl:with-param&gt;
-      &lt;/xsl:call-template&gt;
-    &lt;/xsl:when&gt;
-    &lt;xsl:otherwise&gt;
-      &lt;xsl:value-of select="$count"&gt;&lt;/xsl:value-of&gt;
-    &lt;/xsl:otherwise&gt;
-  &lt;/xsl:choose&gt;
-&lt;/xsl:template&gt;
-</programlisting>
-
-</refsect1>
-</refentry>
-
-
-
-<refentry id="copy-string">
-<refnamediv>
-<refname>copy-string</refname>
-<refpurpose>Returns <quote>count</quote> copies of a string</refpurpose>
-</refnamediv>
-
-<refsect1><title>Description</title>
-
-  <para>Given a string, the <function>copy-string</function>
-    template creates <replaceable>n</replaceable> copies of the
-    string, when the value of <replaceable>n</replaceable> is
-    given by the <parameter>count</parameter> parameter.</para>
-
-<programlisting id="copy-string.frag">
-&lt;xsl:template name="copy-string"&gt;
-  &lt;!-- returns 'count' copies of 'string' --&gt;
-  &lt;xsl:param name="string"&gt;&lt;/xsl:param&gt;
-  &lt;xsl:param name="count" select="0"&gt;&lt;/xsl:param&gt;
-  &lt;xsl:param name="result"&gt;&lt;/xsl:param&gt;
-
-  &lt;xsl:choose&gt;
-    &lt;xsl:when test="$count&gt;0"&gt;
-      &lt;xsl:call-template name="copy-string"&gt;
-        &lt;xsl:with-param name="string" select="$string"&gt;&lt;/xsl:with-param&gt;
-        &lt;xsl:with-param name="count" select="$count - 1"&gt;&lt;/xsl:with-param&gt;
-        &lt;xsl:with-param name="result"&gt;
-          &lt;xsl:value-of select="$result"&gt;&lt;/xsl:value-of&gt;
-          &lt;xsl:value-of select="$string"&gt;&lt;/xsl:value-of&gt;
-        &lt;/xsl:with-param&gt;
-      &lt;/xsl:call-template&gt;
-    &lt;/xsl:when&gt;
-    &lt;xsl:otherwise&gt;
-      &lt;xsl:value-of select="$result"&gt;&lt;/xsl:value-of&gt;
-    &lt;/xsl:otherwise&gt;
-  &lt;/xsl:choose&gt;
-&lt;/xsl:template&gt;
-</programlisting>
-
-</refsect1>
-</refentry>
-
-
-
-<refentry id="string.subst">
-<refnamediv>
-<refname>string.subst</refname>
-<refpurpose>Substitute one text string for another in a string</refpurpose>
-</refnamediv>
-
-<refsect1><title>Description</title>
-
-<para>The <function>string.subst</function> template replaces all
-occurances of <parameter>target</parameter> in <parameter>string</parameter>
-with <parameter>replacement</parameter> and returns the result.
-</para>
-
-<programlisting id="string.subst.frag">
-&lt;xsl:template name="string.subst"&gt;
-  &lt;xsl:param name="string"&gt;&lt;/xsl:param&gt;
-  &lt;xsl:param name="target"&gt;&lt;/xsl:param&gt;
-  &lt;xsl:param name="replacement"&gt;&lt;/xsl:param&gt;
-
-  &lt;xsl:choose&gt;
-    &lt;xsl:when test="contains($string, $target)"&gt;
-      &lt;xsl:variable name="rest"&gt;
-        &lt;xsl:call-template name="string.subst"&gt;
-          &lt;xsl:with-param name="string" select="substring-after($string, $target)"&gt;&lt;/xsl:with-param&gt;
-          &lt;xsl:with-param name="target" select="$target"&gt;&lt;/xsl:with-param&gt;
-          &lt;xsl:with-param name="replacement" select="$replacement"&gt;&lt;/xsl:with-param&gt;
-        &lt;/xsl:call-template&gt;
-      &lt;/xsl:variable&gt;
-      &lt;xsl:value-of select="concat(substring-before($string, $target),                                    $replacement,                                    $rest)"&gt;&lt;/xsl:value-of&gt;
-    &lt;/xsl:when&gt;
-    &lt;xsl:otherwise&gt;
-      &lt;xsl:value-of select="$string"&gt;&lt;/xsl:value-of&gt;
-    &lt;/xsl:otherwise&gt;
-  &lt;/xsl:choose&gt;
-&lt;/xsl:template&gt;
-</programlisting>
-
-</refsect1>
-</refentry>
-
-
-
-<refentry id="xpointer.idref">
-<refnamediv>
-<refname>xpointer.idref</refname>
-<refpurpose>Extract IDREF from an XPointer</refpurpose>
-</refnamediv>
-
-<refsect1><title>Description</title>
-
-<para>The <function>xpointer.idref</function> template returns the
-ID portion of an XPointer which is a pointer to an ID within the current
-document, or the empty string if it is not.</para>
-<para>In other words, <function>xpointer.idref</function> returns
-<quote>foo</quote> when passed either <literal>#foo</literal>
-or <literal>#xpointer(id('foo'))</literal>, otherwise it returns
-the empty string.</para>
-
-<programlisting id="xpointer.idref.frag">
-&lt;xsl:template name="xpointer.idref"&gt;
-  &lt;xsl:param name="xpointer"&gt;http://...&lt;/xsl:param&gt;
-  &lt;xsl:choose&gt;
-    &lt;xsl:when test="starts-with($xpointer, '#xpointer(id(')"&gt;
-      &lt;xsl:variable name="rest" select="substring-after($xpointer, '#xpointer(id(')"&gt;&lt;/xsl:variable&gt;
-      &lt;xsl:variable name="quote" select="substring($rest, 1, 1)"&gt;&lt;/xsl:variable&gt;
-      &lt;xsl:value-of select="substring-before(substring-after($xpointer, $quote), $quote)"&gt;&lt;/xsl:value-of&gt;
-    &lt;/xsl:when&gt;
-    &lt;xsl:when test="starts-with($xpointer, '#')"&gt;
-      &lt;xsl:value-of select="substring-after($xpointer, '#')"&gt;&lt;/xsl:value-of&gt;
-    &lt;/xsl:when&gt;
-    &lt;!-- otherwise it's a pointer to some other document --&gt;
-  &lt;/xsl:choose&gt;
-&lt;/xsl:template&gt;
-</programlisting>
-
-</refsect1>
-</refentry>
-
-
-
-<refentry id="idref">
-<refnamediv>
-<refname>idref</refname>
-<refpurpose>Extract IDREF from a linking element</refpurpose>
-</refnamediv>
-
-<refsect1><title>Description</title>
-
-<para>The <function>idref</function> template accepts 
-any <tag>xref</tag> or universally linking element as a parameter
-and returns the local
-ID that it points to.
-If it has a <tag class="attribute">linkend</tag> attribute,
-it returns that value.
-If it has a <tag class="attribute">xlink:href</tag>, it
-returns that value, parsed as needed to extract just
-the id reference.  Otherwise it returns an empty string.</para>
-
-<programlisting id="idref.frag">
-&lt;xsl:template name="idref"&gt;
-  &lt;xsl:param name="xref" select="."&gt;&lt;/xsl:param&gt;
-  &lt;xsl:param name="linkend" select="$xref/@linkend"&gt;&lt;/xsl:param&gt;
-  &lt;xsl:param name="xpointer"&gt;
-    &lt;xsl:call-template name="xpointer.idref"&gt;
-      &lt;xsl:with-param name="xpointer" select="$xref/@xlink:href"&gt;&lt;/xsl:with-param&gt;
-    &lt;/xsl:call-template&gt;
-  &lt;/xsl:param&gt; 
-
-  &lt;xsl:choose&gt;
-    &lt;xsl:when test="string-length($linkend) != 0"&gt;
-      &lt;xsl:value-of select="$linkend"&gt;&lt;/xsl:value-of&gt;
-    &lt;/xsl:when&gt;
-    &lt;xsl:when test="string-length($xpointer) != 0"&gt;
-      &lt;xsl:value-of select="$xpointer"&gt;&lt;/xsl:value-of&gt;
-    &lt;/xsl:when&gt;
-    &lt;!-- otherwise it's a pointer to some other document --&gt;
-  &lt;/xsl:choose&gt;
-&lt;/xsl:template&gt;
-</programlisting>
-
-</refsect1>
-</refentry>
-
-
-
-
-<refentry id="length-magnitude">
-<refnamediv>
-<refname>length-magnitude</refname>
-<refpurpose>Return the unqualified dimension from a length specification</refpurpose>
-</refnamediv>
-
-<refsect1><title>Description</title>
-
-<para>The <function>length-magnitude</function> template returns the
-unqualified length ("20" for "20pt") from a dimension.
-</para>
-
-<programlisting id="length-magnitude.frag">
-&lt;xsl:template name="length-magnitude"&gt;
-  &lt;xsl:param name="length" select="'0pt'"&gt;&lt;/xsl:param&gt;
-
-  &lt;xsl:choose&gt;
-    &lt;xsl:when test="string-length($length) = 0"&gt;&lt;/xsl:when&gt;
-    &lt;xsl:when test="substring($length,1,1) = '0'                     or substring($length,1,1) = '1'                     or substring($length,1,1) = '2'                     or substring($length,1,1) = '3'                     or substring($length,1,1) = '4'                     or substring($length,1,1) = '5'                     or substring($length,1,1) = '6'                     or substring($length,1,1) = '7'                     or substring($length,1,1) = '8'                     or substring($length,1,1) = '9'                     or substring($length,1,1) = '.'"&gt;
-      &lt;xsl:value-of select="substring($length,1,1)"&gt;&lt;/xsl:value-of&gt;
-      &lt;xsl:call-template name="length-magnitude"&gt;
-        &lt;xsl:with-param name="length" select="substring($length,2)"&gt;&lt;/xsl:with-param&gt;
-      &lt;/xsl:call-template&gt;
-    &lt;/xsl:when&gt;
-  &lt;/xsl:choose&gt;
-&lt;/xsl:template&gt;
-</programlisting>
-
-</refsect1>
-</refentry>
-
-
-
-<refentry id="length-units">
-<refnamediv>
-<refname>length-units</refname>
-<refpurpose>Return the units from a length specification</refpurpose>
-</refnamediv>
-
-<refsect1><title>Description</title>
-
-<para>The <function>length-units</function> template returns the
-units ("pt" for "20pt") from a length. If no units are supplied on the
-length, the <parameter>defauilt.units</parameter> are returned.</para>
-
-<programlisting id="length-units.frag">
-&lt;xsl:template name="length-units"&gt;
-  &lt;xsl:param name="length" select="'0pt'"&gt;&lt;/xsl:param&gt;
-  &lt;xsl:param name="default.units" select="'px'"&gt;&lt;/xsl:param&gt;
-  &lt;xsl:variable name="magnitude"&gt;
-    &lt;xsl:call-template name="length-magnitude"&gt;
-      &lt;xsl:with-param name="length" select="$length"&gt;&lt;/xsl:with-param&gt;
-    &lt;/xsl:call-template&gt;
-  &lt;/xsl:variable&gt;
-
-  &lt;xsl:variable name="units"&gt;
-    &lt;xsl:value-of select="substring($length, string-length($magnitude)+1)"&gt;&lt;/xsl:value-of&gt;
-  &lt;/xsl:variable&gt;
-
-  &lt;xsl:choose&gt;
-    &lt;xsl:when test="$units = ''"&gt;
-      &lt;xsl:value-of select="$default.units"&gt;&lt;/xsl:value-of&gt;
-    &lt;/xsl:when&gt;
-    &lt;xsl:otherwise&gt;
-      &lt;xsl:value-of select="$units"&gt;&lt;/xsl:value-of&gt;
-    &lt;/xsl:otherwise&gt;
-  &lt;/xsl:choose&gt;
-&lt;/xsl:template&gt;
-</programlisting>
-
-</refsect1>
-</refentry>
-
-
-
-<refentry id="length-spec">
-<refnamediv>
-<refname>length-spec</refname>
-<refpurpose>Return a fully qualified length specification</refpurpose>
-</refnamediv>
-
-<refsect1><title>Description</title>
-
-<para>The <function>length-spec</function> template returns the
-qualified length from a dimension. If an unqualified length is given,
-the <parameter>default.units</parameter> will be added to it.
-</para>
-
-<programlisting id="length-spec.frag">
-&lt;xsl:template name="length-spec"&gt;
-  &lt;xsl:param name="length" select="'0pt'"&gt;&lt;/xsl:param&gt;
-  &lt;xsl:param name="default.units" select="'px'"&gt;&lt;/xsl:param&gt;
-
-  &lt;xsl:variable name="magnitude"&gt;
-    &lt;xsl:call-template name="length-magnitude"&gt;
-      &lt;xsl:with-param name="length" select="$length"&gt;&lt;/xsl:with-param&gt;
-    &lt;/xsl:call-template&gt;
-  &lt;/xsl:variable&gt;
-
-  &lt;xsl:variable name="units"&gt;
-    &lt;xsl:value-of select="substring($length, string-length($magnitude)+1)"&gt;&lt;/xsl:value-of&gt;
-  &lt;/xsl:variable&gt;
-
-  &lt;xsl:value-of select="$magnitude"&gt;&lt;/xsl:value-of&gt;
-  &lt;xsl:choose&gt;
-    &lt;xsl:when test="$units='cm'                     or $units='mm'                     or $units='in'                     or $units='pt'                     or $units='pc'                     or $units='px'                     or $units='em'"&gt;
-      &lt;xsl:value-of select="$units"&gt;&lt;/xsl:value-of&gt;
-    &lt;/xsl:when&gt;
-    &lt;xsl:when test="$units = ''"&gt;
-      &lt;xsl:value-of select="$default.units"&gt;&lt;/xsl:value-of&gt;
-    &lt;/xsl:when&gt;
-    &lt;xsl:otherwise&gt;
-      &lt;xsl:message&gt;
-        &lt;xsl:text&gt;Unrecognized unit of measure: &lt;/xsl:text&gt;
-        &lt;xsl:value-of select="$units"&gt;&lt;/xsl:value-of&gt;
-        &lt;xsl:text&gt;.&lt;/xsl:text&gt;
-      &lt;/xsl:message&gt;
-    &lt;/xsl:otherwise&gt;
-  &lt;/xsl:choose&gt;
-&lt;/xsl:template&gt;
-</programlisting>
-
-</refsect1>
-</refentry>
-
-
-
-<refentry id="length-in-points">
-<refnamediv>
-<refname>length-in-points</refname>
-<refpurpose>Returns the size, in points, of a specified length</refpurpose>
-</refnamediv>
-
-<refsect1><title>Description</title>
-
-<para>The <function>length-in-points</function> template converts a length
-specification to points and returns that value as an unqualified
-number.
-</para>
-
-<caution>
-<para>There is no way for the template to infer the size of an
-<literal>em</literal>. It relies on the default <parameter>em.size</parameter>
-which is initially <literal>10</literal> (for 10pt).</para>
-
-<para>Similarly, converting pixels to points relies on the
-<parameter>pixels.per.inch</parameter> parameter which is initially
-<literal>90</literal>.
-</para>
-</caution>
-
-<programlisting id="length-in-points.frag">
-&lt;xsl:template name="length-in-points"&gt;
-  &lt;xsl:param name="length" select="'0pt'"&gt;&lt;/xsl:param&gt;
-  &lt;xsl:param name="em.size" select="10"&gt;&lt;/xsl:param&gt;
-  &lt;xsl:param name="pixels.per.inch" select="90"&gt;&lt;/xsl:param&gt;
-
-  &lt;xsl:variable name="magnitude"&gt;
-    &lt;xsl:call-template name="length-magnitude"&gt;
-      &lt;xsl:with-param name="length" select="$length"&gt;&lt;/xsl:with-param&gt;
-    &lt;/xsl:call-template&gt;
-  &lt;/xsl:variable&gt;
-
-  &lt;xsl:variable name="units"&gt;
-    &lt;xsl:value-of select="substring($length, string-length($magnitude)+1)"&gt;&lt;/xsl:value-of&gt;
-  &lt;/xsl:variable&gt;
-
-  &lt;xsl:choose&gt;
-    &lt;xsl:when test="$units = 'pt'"&gt;
-      &lt;xsl:value-of select="$magnitude"&gt;&lt;/xsl:value-of&gt;
-    &lt;/xsl:when&gt;
-    &lt;xsl:when test="$units = 'cm'"&gt;
-      &lt;xsl:value-of select="$magnitude div 2.54 * 72.0"&gt;&lt;/xsl:value-of&gt;
-    &lt;/xsl:when&gt;
-    &lt;xsl:when test="$units = 'mm'"&gt;
-      &lt;xsl:value-of select="$magnitude div 25.4 * 72.0"&gt;&lt;/xsl:value-of&gt;
-    &lt;/xsl:when&gt;
-    &lt;xsl:when test="$units = 'in'"&gt;
-      &lt;xsl:value-of select="$magnitude * 72.0"&gt;&lt;/xsl:value-of&gt;
-    &lt;/xsl:when&gt;
-    &lt;xsl:when test="$units = 'pc'"&gt;
-      &lt;xsl:value-of select="$magnitude * 12.0"&gt;&lt;/xsl:value-of&gt;
-    &lt;/xsl:when&gt;
-    &lt;xsl:when test="$units = 'px'"&gt;
-      &lt;xsl:value-of select="$magnitude div $pixels.per.inch * 72.0"&gt;&lt;/xsl:value-of&gt;
-    &lt;/xsl:when&gt;
-    &lt;xsl:when test="$units = 'em'"&gt;
-      &lt;xsl:value-of select="$magnitude * $em.size"&gt;&lt;/xsl:value-of&gt;
-    &lt;/xsl:when&gt;
-    &lt;xsl:otherwise&gt;
-      &lt;xsl:message&gt;
-        &lt;xsl:text&gt;Unrecognized unit of measure: &lt;/xsl:text&gt;
-        &lt;xsl:value-of select="$units"&gt;&lt;/xsl:value-of&gt;
-        &lt;xsl:text&gt;.&lt;/xsl:text&gt;
-      &lt;/xsl:message&gt;
-    &lt;/xsl:otherwise&gt;
-  &lt;/xsl:choose&gt;
-&lt;/xsl:template&gt;
-</programlisting>
-
-</refsect1>
-</refentry>
-
-
-
-<refentry id="pi-attribute">
-<refnamediv>
-<refname>pi-attribute</refname>
-<refpurpose>Extract a pseudo-attribute from a PI</refpurpose>
-</refnamediv>
-
-<refsect1><title>Description</title>
-
-<para>The <function>pi-attribute</function> template extracts a pseudo-attribute
-from a processing instruction. For example, given the PI
-<quote><literal>&lt;?foo bar="1" baz='red'?&gt;</literal></quote>,</para>
-<programlisting>&lt;xsl:call-template name="pi-attribute"&gt;
-  &lt;xsl:with-param name="pis" select="processing-instruction('foo')"/&gt;
-  &lt;xsl:with-param name="attribute" select="'baz'"/&gt;
-&lt;/xsl:call-template&gt;</programlisting>
-<para>will return <quote>red</quote>. This template returns the first matching
-attribute that it finds. Presented with processing instructions that
-contain badly formed pseudo-attributes (missing or unbalanced quotes,
-for example), the template may silently return erroneous results.</para>
-
-<programlisting id="pi-attribute.frag">
-&lt;xsl:template name="pi-attribute"&gt;
-  &lt;xsl:param name="pis" select="processing-instruction('BOGUS_PI')"&gt;&lt;/xsl:param&gt;
-  &lt;xsl:param name="attribute"&gt;filename&lt;/xsl:param&gt;
-  &lt;xsl:param name="count"&gt;1&lt;/xsl:param&gt;
-
-  &lt;xsl:choose&gt;
-    &lt;xsl:when test="$count&gt;count($pis)"&gt;
-      &lt;!-- not found --&gt;
-    &lt;/xsl:when&gt;
-    &lt;xsl:otherwise&gt;
-      &lt;xsl:variable name="pi"&gt;
-        &lt;xsl:value-of select="$pis[$count]"&gt;&lt;/xsl:value-of&gt;
-      &lt;/xsl:variable&gt;
-      &lt;xsl:variable name="pivalue"&gt;
-        &lt;xsl:value-of select="concat(' ', normalize-space($pi))"&gt;&lt;/xsl:value-of&gt;
-      &lt;/xsl:variable&gt;
-      &lt;xsl:choose&gt;
-        &lt;xsl:when test="contains($pivalue,concat(' ', $attribute, '='))"&gt;
-          &lt;xsl:variable name="rest" select="substring-after($pivalue,concat(' ', $attribute,'='))"&gt;&lt;/xsl:variable&gt;
-          &lt;xsl:variable name="quote" select="substring($rest,1,1)"&gt;&lt;/xsl:variable&gt;
-          &lt;xsl:value-of select="substring-before(substring($rest,2),$quote)"&gt;&lt;/xsl:value-of&gt;
-        &lt;/xsl:when&gt;
-        &lt;xsl:otherwise&gt;
-          &lt;xsl:call-template name="pi-attribute"&gt;
-            &lt;xsl:with-param name="pis" select="$pis"&gt;&lt;/xsl:with-param&gt;
-            &lt;xsl:with-param name="attribute" select="$attribute"&gt;&lt;/xsl:with-param&gt;
-            &lt;xsl:with-param name="count" select="$count + 1"&gt;&lt;/xsl:with-param&gt;
-          &lt;/xsl:call-template&gt;
-        &lt;/xsl:otherwise&gt;
-      &lt;/xsl:choose&gt;
-    &lt;/xsl:otherwise&gt;
-  &lt;/xsl:choose&gt;
-&lt;/xsl:template&gt;
-</programlisting>
-
-</refsect1>
-</refentry>
-
-
-
-<refentry id="lookup.key">
-<refnamediv>
-<refname>lookup.key</refname>
-<refpurpose>Retrieve the value associated with a particular key in a table</refpurpose>
-</refnamediv>
-
-<refsect1><title>Description</title>
-
-<para>Given a table of space-delimited key/value pairs,
-the <function>lookup.key</function> template extracts the value associated
-with a particular key.</para>
-
-<programlisting id="lookup.key.frag">
-&lt;xsl:template name="lookup.key"&gt;
-  &lt;xsl:param name="key" select="''"&gt;&lt;/xsl:param&gt;
-  &lt;xsl:param name="table" select="''"&gt;&lt;/xsl:param&gt;
-
-  &lt;xsl:if test="contains($table, ' ')"&gt;
-    &lt;xsl:choose&gt;
-      &lt;xsl:when test="substring-before($table, ' ') = $key"&gt;
-        &lt;xsl:variable name="rest" select="substring-after($table, ' ')"&gt;&lt;/xsl:variable&gt;
-        &lt;xsl:choose&gt;
-          &lt;xsl:when test="contains($rest, ' ')"&gt;
-            &lt;xsl:value-of select="substring-before($rest, ' ')"&gt;&lt;/xsl:value-of&gt;
-          &lt;/xsl:when&gt;
-          &lt;xsl:otherwise&gt;
-            &lt;xsl:value-of select="$rest"&gt;&lt;/xsl:value-of&gt;
-          &lt;/xsl:otherwise&gt;
-        &lt;/xsl:choose&gt;
-      &lt;/xsl:when&gt;
-      &lt;xsl:otherwise&gt;
-        &lt;xsl:call-template name="lookup.key"&gt;
-          &lt;xsl:with-param name="key" select="$key"&gt;&lt;/xsl:with-param&gt;
-          &lt;xsl:with-param name="table" select="substring-after(substring-after($table,' '), ' ')"&gt;&lt;/xsl:with-param&gt;
-        &lt;/xsl:call-template&gt;
-      &lt;/xsl:otherwise&gt;
-    &lt;/xsl:choose&gt;
-  &lt;/xsl:if&gt;
-&lt;/xsl:template&gt;
-</programlisting>
-
-</refsect1>
-</refentry>
-
-
-
-<refentry id="xpath.location">
-<refnamediv>
-<refname>xpath.location</refname>
-<refpurpose>Calculate the XPath child-sequence to the current node</refpurpose>
-</refnamediv>
-
-<refsect1><title>Description</title>
-
-<para>The <function>xpath.location</function> template calculates the
-absolute path from the root of the tree to the current element node.
-</para>
-
-<programlisting id="xpath.location.frag">
-&lt;xsl:template name="xpath.location"&gt;
-  &lt;xsl:param name="node" select="."&gt;&lt;/xsl:param&gt;
-  &lt;xsl:param name="path" select="''"&gt;&lt;/xsl:param&gt;
-
-  &lt;xsl:variable name="next.path"&gt;
-    &lt;xsl:value-of select="local-name($node)"&gt;&lt;/xsl:value-of&gt;
-    &lt;xsl:if test="$path != ''"&gt;/&lt;/xsl:if&gt;
-    &lt;xsl:value-of select="$path"&gt;&lt;/xsl:value-of&gt;
-  &lt;/xsl:variable&gt;
-
-  &lt;xsl:choose&gt;
-    &lt;xsl:when test="$node/parent::*"&gt;
-      &lt;xsl:call-template name="xpath.location"&gt;
-        &lt;xsl:with-param name="node" select="$node/parent::*"&gt;&lt;/xsl:with-param&gt;
-        &lt;xsl:with-param name="path" select="$next.path"&gt;&lt;/xsl:with-param&gt;
-      &lt;/xsl:call-template&gt;
-    &lt;/xsl:when&gt;
-    &lt;xsl:otherwise&gt;
-      &lt;xsl:text&gt;/&lt;/xsl:text&gt;
-      &lt;xsl:value-of select="$next.path"&gt;&lt;/xsl:value-of&gt;
-    &lt;/xsl:otherwise&gt;
-  &lt;/xsl:choose&gt;
-&lt;/xsl:template&gt;
-</programlisting>
-
-</refsect1>
-</refentry>
-
-
-
-<refentry id="comment-escape-string">
-<refnamediv>
-<refname>comment-escape-string</refname>
-<refpurpose>Prepare a string for inclusion in an XML comment</refpurpose>
-</refnamediv>
-
-<refsect1><title>Description</title>
-
-<para>The <function>comment-escape-string</function> template returns a string
-that has been transformed so that it can safely be output as an XML comment.
-Internal occurrences of "--" will be replaced with "- -" and a leading and/or
-trailing space will be added to the string, if necessary.</para>
-
-<programlisting id="comment-escape-string.frag">
-&lt;xsl:template name="comment-escape-string"&gt;
-  &lt;xsl:param name="string" select="''"&gt;&lt;/xsl:param&gt;
-
-  &lt;xsl:if test="starts-with($string, '-')"&gt;
-    &lt;xsl:text&gt; &lt;/xsl:text&gt;
-  &lt;/xsl:if&gt;
-
-  &lt;xsl:call-template name="comment-escape-string.recursive"&gt;
-    &lt;xsl:with-param name="string" select="$string"&gt;&lt;/xsl:with-param&gt;
-  &lt;/xsl:call-template&gt;
-
-  &lt;xsl:if test="substring($string, string-length($string), 1) = '-'"&gt;
-    &lt;xsl:text&gt; &lt;/xsl:text&gt;
-  &lt;/xsl:if&gt;
-&lt;/xsl:template&gt;
-</programlisting>
-
-</refsect1>
-</refentry>
-
-
-
-<refentry id="comment-escape-string.recursive">
-<refnamediv>
-<refname>comment-escape-string.recursive</refname>
-<refpurpose>Internal function used by comment-escape-string</refpurpose>
-</refnamediv>
-
-<refsect1><title>Description</title>
-
-<para>The <function>comment-escape-string.recursive</function> template is used
-by <function>comment-escape-string</function>.</para>
-
-<programlisting id="comment-escape-string.recursive.frag">
-&lt;xsl:template name="comment-escape-string.recursive"&gt;
-  &lt;xsl:param name="string" select="''"&gt;&lt;/xsl:param&gt;
-  &lt;xsl:choose&gt;
-    &lt;xsl:when test="contains($string, '--')"&gt;
-      &lt;xsl:value-of select="substring-before($string, '--')"&gt;&lt;/xsl:value-of&gt;
-      &lt;xsl:value-of select="'- -'"&gt;&lt;/xsl:value-of&gt;
-      &lt;xsl:call-template name="comment-escape-string.recursive"&gt;
-        &lt;xsl:with-param name="string" select="substring-after($string, '--')"&gt;&lt;/xsl:with-param&gt;
-      &lt;/xsl:call-template&gt;
-    &lt;/xsl:when&gt;
-    &lt;xsl:otherwise&gt;
-      &lt;xsl:value-of select="$string"&gt;&lt;/xsl:value-of&gt;
-    &lt;/xsl:otherwise&gt;
-  &lt;/xsl:choose&gt;
-&lt;/xsl:template&gt;
-</programlisting>
-</refsect1>
-</refentry>
-
-
-
-<refentry id="trim.text">
-<refnamediv>
-<refname>trim.text</refname>
-<refpurpose>Trim leading and trailing whitespace from a text node</refpurpose>
-</refnamediv>
-
-<refsect1><title>Description</title>
-
-<para>Given a text node, this function trims leading and trailing
-whitespace from it and returns the trimmed contents.</para>
-
-<programlisting id="trim.text.frag">
-
-  &lt;xsl:template name="trim.text"&gt;
-    &lt;xsl:param name="contents" select="."&gt;&lt;/xsl:param&gt;
-    &lt;xsl:variable name="contents-left-trimmed"&gt;
-      &lt;xsl:call-template name="trim-left"&gt;
-        &lt;xsl:with-param name="contents" select="$contents"&gt;&lt;/xsl:with-param&gt;
-      &lt;/xsl:call-template&gt;
-    &lt;/xsl:variable&gt;
-    &lt;xsl:variable name="contents-trimmed"&gt;
-      &lt;xsl:call-template name="trim-right"&gt;
-        &lt;xsl:with-param name="contents" select="$contents-left-trimmed"&gt;&lt;/xsl:with-param&gt;
-      &lt;/xsl:call-template&gt;
-    &lt;/xsl:variable&gt;
-    &lt;xsl:value-of select="$contents-trimmed"&gt;&lt;/xsl:value-of&gt;
-  &lt;/xsl:template&gt;
-
-  &lt;xsl:template name="trim-left"&gt;
-    &lt;xsl:param name="contents"&gt;&lt;/xsl:param&gt;
-    &lt;xsl:choose&gt;
-      &lt;xsl:when test="starts-with($contents,'
-') or                       starts-with($contents,'&#xD;') or                       starts-with($contents,' ') or                       starts-with($contents,'	')"&gt;
-        &lt;xsl:call-template name="trim-left"&gt;
-          &lt;xsl:with-param name="contents" select="substring($contents, 2)"&gt;&lt;/xsl:with-param&gt;
-        &lt;/xsl:call-template&gt;
-      &lt;/xsl:when&gt;
-      &lt;xsl:otherwise&gt;
-        &lt;xsl:value-of select="$contents"&gt;&lt;/xsl:value-of&gt;
-      &lt;/xsl:otherwise&gt;
-    &lt;/xsl:choose&gt;
-  &lt;/xsl:template&gt;
-
-  &lt;xsl:template name="trim-right"&gt;
-    &lt;xsl:param name="contents"&gt;&lt;/xsl:param&gt;
-    &lt;xsl:variable name="last-char"&gt;
-      &lt;xsl:value-of select="substring($contents, string-length($contents), 1)"&gt;&lt;/xsl:value-of&gt;
-    &lt;/xsl:variable&gt;
-    &lt;xsl:choose&gt;
-      &lt;xsl:when test="($last-char = '
-') or                       ($last-char = '&#xD;') or                       ($last-char = ' ') or                       ($last-char = '	')"&gt;
-        &lt;xsl:call-template name="trim-right"&gt;
-          &lt;xsl:with-param name="contents" select="substring($contents, 1, string-length($contents) - 1)"&gt;&lt;/xsl:with-param&gt;
-        &lt;/xsl:call-template&gt;
-      &lt;/xsl:when&gt;
-      &lt;xsl:otherwise&gt;
-        &lt;xsl:value-of select="$contents"&gt;&lt;/xsl:value-of&gt;
-      &lt;/xsl:otherwise&gt;
-    &lt;/xsl:choose&gt;
-  &lt;/xsl:template&gt;
-</programlisting>
-
-</refsect1>
-</refentry>
-
-
-
-<refentry id="str.tokenize.keep.delimiters">
-<refnamediv>
-<refname>str.tokenize.keep.delimiters</refname>
-<refpurpose>Tokenize a string while preserving any delimiters</refpurpose>
-</refnamediv>
-<refsect1><title>Description</title>
-<para>Based on the occurrence of one or more delimiter characters,
-this function breaks a string into a list of tokens and delimiters,
-marking up each of the tokens with a <tag>token</tag> element
-and preserving the delimiters as text nodes between the tokens.</para>
-<note>
-  <para>This function is a very slightly modified version of a
-  function from the <link xlink:href="http://www.exslt.org/">EXSLT
-  site</link>. The original is available at:
-
-<blockquote><para><link xlink:href="http://www.exslt.org/str/functions/tokenize/str.tokenize.template.xsl"/></para></blockquote>
-
-  The <function>str.tokenize.keep.delimiters</function> function
-  differs only in that it preserves the delimiters instead of
-  discarding them.</para>
-</note>
-<programlisting id="str.tokenize.keep.delimiters.frag">
-  &lt;xsl:template name="str.tokenize.keep.delimiters"&gt;
-    &lt;xsl:param name="string" select="''"&gt;&lt;/xsl:param&gt;
-    &lt;xsl:param name="delimiters" select="' '"&gt;&lt;/xsl:param&gt;
-    &lt;xsl:choose&gt;
-      &lt;xsl:when test="not($string)"&gt;&lt;/xsl:when&gt;
-      &lt;xsl:when test="not($delimiters)"&gt;
-        &lt;xsl:call-template name="str.tokenize.keep.delimiters-characters"&gt;
-          &lt;xsl:with-param name="string" select="$string"&gt;&lt;/xsl:with-param&gt;
-        &lt;/xsl:call-template&gt;
-      &lt;/xsl:when&gt;
-      &lt;xsl:otherwise&gt;
-        &lt;xsl:call-template name="str.tokenize.keep.delimiters-delimiters"&gt;
-          &lt;xsl:with-param name="string" select="$string"&gt;&lt;/xsl:with-param&gt;
-          &lt;xsl:with-param name="delimiters" select="$delimiters"&gt;&lt;/xsl:with-param&gt;
-        &lt;/xsl:call-template&gt;
-      &lt;/xsl:otherwise&gt;
-    &lt;/xsl:choose&gt;
-  &lt;/xsl:template&gt;
-  &lt;xsl:template name="str.tokenize.keep.delimiters-characters"&gt;
-    &lt;xsl:param name="string"&gt;&lt;/xsl:param&gt;
-    &lt;xsl:if test="$string"&gt;
-      &lt;ssb:token&gt;&lt;xsl:value-of select="substring($string, 1, 1)"&gt;&lt;/xsl:value-of&gt;&lt;/ssb:token&gt;
-      &lt;xsl:call-template name="str.tokenize.keep.delimiters-characters"&gt;
-        &lt;xsl:with-param name="string" select="substring($string, 2)"&gt;&lt;/xsl:with-param&gt;
-      &lt;/xsl:call-template&gt;
-    &lt;/xsl:if&gt;
-  &lt;/xsl:template&gt;
-  &lt;xsl:template name="str.tokenize.keep.delimiters-delimiters"&gt;
-    &lt;xsl:param name="string"&gt;&lt;/xsl:param&gt;
-    &lt;xsl:param name="delimiters"&gt;&lt;/xsl:param&gt;
-    &lt;xsl:variable name="delimiter" select="substring($delimiters, 1, 1)"&gt;&lt;/xsl:variable&gt;
-    &lt;xsl:choose&gt;
-      &lt;xsl:when test="not($delimiter)"&gt;
-        &lt;ssb:token&gt;&lt;xsl:value-of select="$string"&gt;&lt;/xsl:value-of&gt;&lt;/ssb:token&gt;
-      &lt;/xsl:when&gt;
-      &lt;xsl:when test="contains($string, $delimiter)"&gt;
-        &lt;xsl:if test="not(starts-with($string, $delimiter))"&gt;
-          &lt;xsl:call-template name="str.tokenize.keep.delimiters-delimiters"&gt;
-            &lt;xsl:with-param name="string" select="substring-before($string, $delimiter)"&gt;&lt;/xsl:with-param&gt;
-            &lt;xsl:with-param name="delimiters" select="substring($delimiters, 2)"&gt;&lt;/xsl:with-param&gt;
-          &lt;/xsl:call-template&gt;
-        &lt;/xsl:if&gt;
-        &lt;!-- output each delimiter --&gt;
-        &lt;xsl:value-of select="$delimiter"&gt;&lt;/xsl:value-of&gt;
-        &lt;xsl:call-template name="str.tokenize.keep.delimiters-delimiters"&gt;
-          &lt;xsl:with-param name="string" select="substring-after($string, $delimiter)"&gt;&lt;/xsl:with-param&gt;
-          &lt;xsl:with-param name="delimiters" select="$delimiters"&gt;&lt;/xsl:with-param&gt;
-        &lt;/xsl:call-template&gt;
-      &lt;/xsl:when&gt;
-      &lt;xsl:otherwise&gt;
-        &lt;xsl:call-template name="str.tokenize.keep.delimiters-delimiters"&gt;
-          &lt;xsl:with-param name="string" select="$string"&gt;&lt;/xsl:with-param&gt;
-          &lt;xsl:with-param name="delimiters" select="substring($delimiters, 2)"&gt;&lt;/xsl:with-param&gt;
-        &lt;/xsl:call-template&gt;
-      &lt;/xsl:otherwise&gt;
-    &lt;/xsl:choose&gt;
-  &lt;/xsl:template&gt;
-</programlisting>
-</refsect1>
-</refentry>
-
-
-
-<refentry id="apply-string-subst-map">
-  <refnamediv>
-    <refname>apply-string-subst-map</refname>
-    <refpurpose>Apply a string-substitution map</refpurpose>
-  </refnamediv>
-  <refsect1><title>Description</title>
-  <para>This function applies a &#8220;string substitution&#8221; map. Use it when
-  you want to do multiple string substitutions on the same target
-  content. It reads in two things: <parameter>content</parameter>, the
-  content on which to perform the substitution, and
-  <parameter>map.contents</parameter>, a node set of
-  elements (the names of the elements don't matter), with each element
-  having the following attributes:
-  <itemizedlist>
-    <listitem>
-      <simpara><tag class="attribute">oldstring</tag>, a string to
-      be replaced</simpara>
-    </listitem>
-    <listitem>
-      <simpara><tag class="attribute">newstring</tag>, a string with
-      which to replace <tag class="attribute">oldstring</tag></simpara>
-    </listitem>
-  </itemizedlist>
-  The function uses <parameter>map.contents</parameter> to
-  do substitution on <parameter>content</parameter>, and then
-  returns the modified contents.</para>
-  <note>
-    <para>This function is a very slightly modified version of Jeni
-    Tennison&#8217;s <function>replace_strings</function> function in the
-    <link xlink:href="http://www.dpawson.co.uk/xsl/sect2/StringReplace.html#d9351e13">multiple string replacements</link> section of Dave Pawson&#8217;s
-    <link xlink:href="http://www.dpawson.co.uk/xsl/index.html">XSLT
-    FAQ</link>.</para>
-    <para>The <function>apply-string-subst-map</function> function is
-    essentially the same function as the
-    <function>apply-character-map</function> function; the only
-    difference is that in the map that
-    <function>apply-string-subst-map</function> expects, <tag class="attribute">oldstring</tag> and <tag class="attribute">newstring</tag> attributes are used instead of
-    <tag class="attribute">character</tag> and <tag class="attribute">string</tag> attributes.</para>
-  </note>
-  <programlisting id="apply-string-subst-map.frag">
-    &lt;xsl:template name="apply-string-subst-map"&gt;
-      &lt;xsl:param name="content"&gt;&lt;/xsl:param&gt;
-      &lt;xsl:param name="map.contents"&gt;&lt;/xsl:param&gt;
-      &lt;xsl:variable name="replaced_text"&gt;
-        &lt;xsl:call-template name="string.subst"&gt;
-          &lt;xsl:with-param name="string" select="$content"&gt;&lt;/xsl:with-param&gt;
-          &lt;xsl:with-param name="target" select="$map.contents[1]/@oldstring"&gt;&lt;/xsl:with-param&gt;
-          &lt;xsl:with-param name="replacement" select="$map.contents[1]/@newstring"&gt;&lt;/xsl:with-param&gt;
-        &lt;/xsl:call-template&gt;
-      &lt;/xsl:variable&gt;
-      &lt;xsl:choose&gt;
-        &lt;xsl:when test="$map.contents[2]"&gt;
-          &lt;xsl:call-template name="apply-string-subst-map"&gt;
-            &lt;xsl:with-param name="content" select="$replaced_text"&gt;&lt;/xsl:with-param&gt;
-            &lt;xsl:with-param name="map.contents" select="$map.contents[position() &gt; 1]"&gt;&lt;/xsl:with-param&gt;
-          &lt;/xsl:call-template&gt;
-        &lt;/xsl:when&gt;
-        &lt;xsl:otherwise&gt;
-          &lt;xsl:value-of select="$replaced_text"&gt;&lt;/xsl:value-of&gt;
-        &lt;/xsl:otherwise&gt;
-      &lt;/xsl:choose&gt;
-    &lt;/xsl:template&gt;
-  </programlisting>
-  </refsect1>
-</refentry>
-</reference><reference id="relativeuri" xml:base="../lib/lib.xml">
-<title>Relative URI Functions</title>
-
-<partintro id="partintro"><title>Introduction</title>
-
-<para>These functions manipulate relative URI references.</para>
-
-<para>The following assumptions must hold true:</para>
-
-<orderedlist>
-<listitem>
-<para>All URIs are relative.</para>
-</listitem>
-<listitem>
-<para>No URI contains the <quote><literal>../</literal></quote> sequence
-which would effectively move <quote>up</quote> the hierarchy.</para>
-</listitem>
-</orderedlist>
-
-<para>If these assumptions do not hold, the results are unpredictable.</para>
-
-</partintro>
-
-
-
-<refentry id="count.uri.path.depth">
-<refnamediv>
-<refname>count.uri.path.depth</refname>
-<refpurpose>Count the number of path components in a relative URI</refpurpose>
-</refnamediv>
-
-<refsect1><title>Description</title>
-
-<para>This function counts the number of path components in a relative URI.</para>
-
-<programlisting id="count.uri.path.depth.frag">
-&lt;xsl:template name="count.uri.path.depth"&gt;
-  &lt;xsl:param name="filename" select="''"&gt;&lt;/xsl:param&gt;
-  &lt;xsl:param name="count" select="0"&gt;&lt;/xsl:param&gt;
-
-  &lt;xsl:choose&gt;
-    &lt;xsl:when test="contains($filename, '/')"&gt;
-      &lt;xsl:call-template name="count.uri.path.depth"&gt;
-        &lt;xsl:with-param name="filename" select="substring-after($filename, '/')"&gt;&lt;/xsl:with-param&gt;
-        &lt;xsl:with-param name="count" select="$count + 1"&gt;&lt;/xsl:with-param&gt;
-      &lt;/xsl:call-template&gt;
-    &lt;/xsl:when&gt;
-    &lt;xsl:otherwise&gt;
-      &lt;xsl:value-of select="$count"&gt;&lt;/xsl:value-of&gt;
-    &lt;/xsl:otherwise&gt;
-  &lt;/xsl:choose&gt;
-&lt;/xsl:template&gt;
-</programlisting>
-
-</refsect1>
-</refentry>
-
-
-
-<refentry id="trim.common.uri.paths">
-<refnamediv>
-<refname>trim.common.uri.paths</refname>
-<refpurpose>Trim common leading path components from a relative URI</refpurpose>
-</refnamediv>
-
-<refsect1><title>Description</title>
-
-<para>This function trims common leading path components from a relative URI.</para>
-
-<programlisting id="trim.common.uri.paths.frag">
-&lt;xsl:template name="trim.common.uri.paths"&gt;
-  &lt;xsl:param name="uriA" select="''"&gt;&lt;/xsl:param&gt;
-  &lt;xsl:param name="uriB" select="''"&gt;&lt;/xsl:param&gt;
-  &lt;xsl:param name="return" select="'A'"&gt;&lt;/xsl:param&gt;
-
-  &lt;!-- Resolve any ../ in the path --&gt;
-  &lt;xsl:variable name="trimmed.uriA"&gt;
-    &lt;xsl:call-template name="resolve.path"&gt;
-      &lt;xsl:with-param name="filename" select="$uriA"&gt;&lt;/xsl:with-param&gt;
-    &lt;/xsl:call-template&gt;
-  &lt;/xsl:variable&gt;
-
-  &lt;xsl:variable name="trimmed.uriB"&gt;
-    &lt;xsl:call-template name="resolve.path"&gt;
-      &lt;xsl:with-param name="filename" select="$uriB"&gt;&lt;/xsl:with-param&gt;
-    &lt;/xsl:call-template&gt;
-  &lt;/xsl:variable&gt;
-
-  &lt;xsl:choose&gt;
-    &lt;xsl:when test="contains($trimmed.uriA, '/') and contains($trimmed.uriB, '/')                     and substring-before($trimmed.uriA, '/') = substring-before($trimmed.uriB, '/')"&gt;
-      &lt;xsl:call-template name="trim.common.uri.paths"&gt;
-        &lt;xsl:with-param name="uriA" select="substring-after($trimmed.uriA, '/')"&gt;&lt;/xsl:with-param&gt;
-        &lt;xsl:with-param name="uriB" select="substring-after($trimmed.uriB, '/')"&gt;&lt;/xsl:with-param&gt;
-        &lt;xsl:with-param name="return" select="$return"&gt;&lt;/xsl:with-param&gt;
-      &lt;/xsl:call-template&gt;
-    &lt;/xsl:when&gt;
-    &lt;xsl:otherwise&gt;
-      &lt;xsl:choose&gt;
-        &lt;xsl:when test="$return = 'A'"&gt;
-          &lt;xsl:value-of select="$trimmed.uriA"&gt;&lt;/xsl:value-of&gt;
-        &lt;/xsl:when&gt;
-        &lt;xsl:otherwise&gt;
-          &lt;xsl:value-of select="$trimmed.uriB"&gt;&lt;/xsl:value-of&gt;
-        &lt;/xsl:otherwise&gt;
-      &lt;/xsl:choose&gt;
-    &lt;/xsl:otherwise&gt;
-  &lt;/xsl:choose&gt;
-&lt;/xsl:template&gt;
-</programlisting>
-
-</refsect1>
-</refentry>
-
-<refentry id="resolve.path">
-<refnamediv>
-<refname>resolve.path</refname>
-<refpurpose>Resolve any ../ in path, except leading ../</refpurpose>
-</refnamediv>
-
-<refsect1><title>Description</title>
-
-<para>This function resolves any relative ../ parts of a file path.</para>
-
-<programlisting id="resolve.path.frag">
-&lt;xsl:template name="resolve.path"&gt;
-  &lt;xsl:param name="filename" select="''"&gt;&lt;/xsl:param&gt;
-  &lt;xsl:choose&gt;
-    &lt;!-- Leading .. are not eliminated --&gt;
-    &lt;xsl:when test="starts-with($filename, '../')"&gt;
-      &lt;xsl:value-of select="'../'"&gt;&lt;/xsl:value-of&gt;
-      &lt;xsl:call-template name="resolve.path"&gt;
-        &lt;xsl:with-param name="filename" select="substring-after($filename, '../')"&gt;&lt;/xsl:with-param&gt;
-      &lt;/xsl:call-template&gt;
-    &lt;/xsl:when&gt;
-    &lt;xsl:when test="contains($filename, '/../')"&gt;
-      &lt;xsl:call-template name="resolve.path"&gt;
-        &lt;xsl:with-param name="filename"&gt;
-          &lt;xsl:call-template name="dirname"&gt;
-            &lt;xsl:with-param name="filename" select="substring-before($filename, '/../')"&gt;&lt;/xsl:with-param&gt;
-          &lt;/xsl:call-template&gt;
-          &lt;xsl:value-of select="substring-after($filename, '/../')"&gt;&lt;/xsl:value-of&gt;
-        &lt;/xsl:with-param&gt;
-      &lt;/xsl:call-template&gt;
-    &lt;/xsl:when&gt;
-    &lt;xsl:otherwise&gt;
-      &lt;xsl:value-of select="$filename"&gt;&lt;/xsl:value-of&gt;
-    &lt;/xsl:otherwise&gt;
-  &lt;/xsl:choose&gt;
-&lt;/xsl:template&gt;
-</programlisting>
-
-</refsect1>
-</refentry>
-
-<refentry id="dirname">
-<refnamediv>
-<refname>dirname</refname>
-<refpurpose>Return directory part of a path</refpurpose>
-</refnamediv>
-
-<refsect1><title>Description</title>
-
-<para>This function returns the directory part of a path.</para>
-
-<programlisting id="dirname.frag">
-
-&lt;xsl:template name="dirname"&gt;
-  &lt;xsl:param name="filename" select="''"&gt;&lt;/xsl:param&gt;
-  &lt;xsl:if test="contains($filename, '/')"&gt;
-    &lt;xsl:value-of select="substring-before($filename, '/')"&gt;&lt;/xsl:value-of&gt;
-    &lt;xsl:text&gt;/&lt;/xsl:text&gt;
-    &lt;xsl:call-template name="dirname"&gt;
-      &lt;xsl:with-param name="filename" select="substring-after($filename, '/')"&gt;&lt;/xsl:with-param&gt;
-    &lt;/xsl:call-template&gt;
-  &lt;/xsl:if&gt;
-&lt;/xsl:template&gt;
-
-</programlisting>
-
-</refsect1>
-</refentry>
-
-</reference>
-    </part>
-    <part id="common-part"><title>Common&#160;Template&#160;Reference</title>
-      <?dbhtml dir="common"?>
-      <?dbhtml filename="index.html"?>
-      <info>
-        <abstract>
-          <para>This is technical reference documentation for the
-            &#8220;base&#8221;, &#8220;refentry&#8221;, and &#8220;utility&#8221; sets of common
-            templates in the DocBook XSL Stylesheets. These
-            templates are &#8220;common&#8221; in that they are shared across
-            output formats (that is, they&#8217;re not
-            output-format-dependent)</para>
-          <para>This documentation is not intended to be user
-            documentation. It is provided for developers writing
-            customization layers for the stylesheets.</para>
-        </abstract>
-      </info>
-        <reference id="base" xml:base="../common/common.xml">
-  <info>
-    <title>Common &#187; Base Template Reference</title>
-    <releaseinfo role="meta">
-      $Id: common.xsl 9347 2012-05-11 03:49:49Z bobstayton $
-    </releaseinfo>
-  </info>
-  
-  <partintro id="partintro">
-    <title>Introduction</title>
-    
-<para>This is technical reference documentation for the &#8220;base&#8221;
-      set of common templates in the DocBook XSL Stylesheets.</para>
-
-    
-<para>This is not intended to be user documentation. It is
-      provided for developers writing customization layers for the
-      stylesheets.</para>
-
-  </partintro>
-
-<refentry id="template.is.component">
-<refnamediv>
-<refname>is.component</refname>
-<refpurpose>Tests if a given node is a component-level element</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-<synopsis>&lt;xsl:template name="is.component"&gt;
-&lt;xsl:param name="node" select="."/&gt;
-  ...
-&lt;/xsl:template&gt;</synopsis>
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-
-<para>This template returns '1' if the specified node is a component
-(Chapter, Appendix, etc.), and '0' otherwise.</para>
-
-</refsect1><refsect1><title>Parameters</title>
-
-<variablelist>
-<varlistentry><term>node</term>
-<listitem>
-
-<para>The node which is to be tested.</para>
-
-</listitem>
-</varlistentry>
-</variablelist>
-
-</refsect1><refsect1><title>Returns</title>
-
-<para>This template returns '1' if the specified node is a component
-(Chapter, Appendix, etc.), and '0' otherwise.</para>
-
-</refsect1></refentry>
-
-<refentry id="template.is.section">
-<refnamediv>
-<refname>is.section</refname>
-<refpurpose>Tests if a given node is a section-level element</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-<synopsis>&lt;xsl:template name="is.section"&gt;
-&lt;xsl:param name="node" select="."/&gt;
-  ...
-&lt;/xsl:template&gt;</synopsis>
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-
-<para>This template returns '1' if the specified node is a section
-(Section, Sect1, Sect2, etc.), and '0' otherwise.</para>
-
-</refsect1><refsect1><title>Parameters</title>
-
-<variablelist>
-<varlistentry><term>node</term>
-<listitem>
-
-<para>The node which is to be tested.</para>
-
-</listitem>
-</varlistentry>
-</variablelist>
-
-</refsect1><refsect1><title>Returns</title>
-
-<para>This template returns '1' if the specified node is a section
-(Section, Sect1, Sect2, etc.), and '0' otherwise.</para>
-
-</refsect1></refentry>
-
-<refentry id="template.section.level">
-<refnamediv>
-<refname>section.level</refname>
-<refpurpose>Returns the hierarchical level of a section</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-<synopsis>&lt;xsl:template name="section.level"&gt;
-&lt;xsl:param name="node" select="."/&gt;
-  ...
-&lt;/xsl:template&gt;</synopsis>
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-
-<para>This template calculates the hierarchical level of a section.
-The element <tag>sect1</tag> is at level 1, <tag>sect2</tag> is
-at level 2, etc.</para>
-
-
-
-<para>Recursive sections are calculated down to the fifth level.</para>
-
-</refsect1><refsect1><title>Parameters</title>
-
-<variablelist>
-<varlistentry><term>node</term>
-<listitem>
-
-<para>The section node for which the level should be calculated.
-Defaults to the context node.</para>
-
-</listitem>
-</varlistentry>
-</variablelist>
-
-</refsect1><refsect1><title>Returns</title>
-
-<para>The section level, <quote>1</quote>, <quote>2</quote>, etc.
-</para>
-
-</refsect1></refentry>
-
-<refentry id="template.qanda.section.level">
-<refnamediv>
-<refname>qanda.section.level</refname>
-<refpurpose>Returns the hierarchical level of a QandASet</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-<synopsis>&lt;xsl:template name="qanda.section.level"/&gt;</synopsis>
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-
-<para>This template calculates the hierarchical level of a QandASet.
-</para>
-
-</refsect1><refsect1><title>Returns</title>
-
-<para>The level, <quote>1</quote>, <quote>2</quote>, etc.
-</para>
-
-</refsect1></refentry>
-
-<refentry id="template.select.mediaobject">
-<refnamediv>
-<refname>select.mediaobject</refname>
-<refpurpose>Selects and processes an appropriate media object from a list</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-<synopsis>&lt;xsl:template name="select.mediaobject"&gt;
-&lt;xsl:param name="olist" select="imageobject|imageobjectco                      |videoobject|audioobject|textobject"/&gt;
-  ...
-&lt;/xsl:template&gt;</synopsis>
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-
-<para>This template takes a list of media objects (usually the
-children of a mediaobject or inlinemediaobject) and processes
-the "right" object.</para>
-
-
-
-<para>This template relies on a template named 
-"select.mediaobject.index" to determine which object
-in the list is appropriate.</para>
-
-
-
-<para>If no acceptable object is located, nothing happens.</para>
-
-</refsect1><refsect1><title>Parameters</title>
-
-<variablelist>
-<varlistentry><term>olist</term>
-<listitem>
-
-<para>The node list of potential objects to examine.</para>
-
-</listitem>
-</varlistentry>
-</variablelist>
-
-</refsect1><refsect1><title>Returns</title>
-
-<para>Calls &lt;xsl:apply-templates&gt; on the selected object.</para>
-
-</refsect1></refentry>
-
-<refentry id="template.select.mediaobject.index">
-<refnamediv>
-<refname>select.mediaobject.index</refname>
-<refpurpose>Selects the position of the appropriate media object from a list</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-<synopsis>&lt;xsl:template name="select.mediaobject.index"&gt;
-&lt;xsl:param name="olist" select="imageobject|imageobjectco                      |videoobject|audioobject|textobject"/&gt;
-&lt;xsl:param name="count"&gt;1&lt;/xsl:param&gt;
-  ...
-&lt;/xsl:template&gt;</synopsis>
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-
-<para>This template takes a list of media objects (usually the
-children of a mediaobject or inlinemediaobject) and determines
-the "right" object. It returns the position of that object
-to be used by the calling template.</para>
-
-
-
-<para>If the parameter <parameter>use.role.for.mediaobject</parameter>
-is nonzero, then it first checks for an object with
-a role attribute of the appropriate value.  It takes the first
-of those.  Otherwise, it takes the first acceptable object
-through a recursive pass through the list.</para>
-
-
-
-<para>This template relies on a template named "is.acceptable.mediaobject"
-to determine if a given object is an acceptable graphic. The semantics
-of media objects is that the first acceptable graphic should be used.
-</para>
-
-
-
-<para>If no acceptable object is located, no index is returned.</para>
-
-</refsect1><refsect1><title>Parameters</title>
-
-<variablelist>
-<varlistentry><term>olist</term>
-<listitem>
-
-<para>The node list of potential objects to examine.</para>
-
-</listitem>
-</varlistentry>
-<varlistentry><term>count</term>
-<listitem>
-
-<para>The position in the list currently being considered by the 
-recursive process.</para>
-
-</listitem>
-</varlistentry>
-</variablelist>
-
-</refsect1><refsect1><title>Returns</title>
-
-<para>Returns the position in the original list of the selected object.</para>
-
-</refsect1></refentry>
-
-<refentry id="template.is.acceptable.mediaobject">
-<refnamediv>
-<refname>is.acceptable.mediaobject</refname>
-<refpurpose>Returns '1' if the specified media object is recognized</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-<synopsis>&lt;xsl:template name="is.acceptable.mediaobject"&gt;
-&lt;xsl:param name="object"/&gt;
-  ...
-&lt;/xsl:template&gt;</synopsis>
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-
-<para>This template examines a media object and returns '1' if the
-object is recognized as a graphic.</para>
-
-</refsect1><refsect1><title>Parameters</title>
-
-<variablelist>
-<varlistentry><term>object</term>
-<listitem>
-
-<para>The media object to consider.</para>
-
-</listitem>
-</varlistentry>
-</variablelist>
-
-</refsect1><refsect1><title>Returns</title>
-
-<para>0 or 1</para>
-
-</refsect1></refentry>
-
-<refentry id="template.check.id.unique">
-<refnamediv>
-<refname>check.id.unique</refname>
-<refpurpose>Warn users about references to non-unique IDs</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-<synopsis>&lt;xsl:template name="check.id.unique"&gt;
-&lt;xsl:param name="linkend"/&gt;
-  ...
-&lt;/xsl:template&gt;</synopsis>
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-
-<para>If passed an ID in <varname>linkend</varname>,
-<function>check.id.unique</function> prints
-a warning message to the user if either the ID does not exist or
-the ID is not unique.</para>
-
-</refsect1></refentry>
-
-<refentry id="template.check.idref.targets">
-<refnamediv>
-<refname>check.idref.targets</refname>
-<refpurpose>Warn users about incorrectly typed references</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-<synopsis>&lt;xsl:template name="check.idref.targets"&gt;
-&lt;xsl:param name="linkend"/&gt;
-&lt;xsl:param name="element-list"/&gt;
-  ...
-&lt;/xsl:template&gt;</synopsis>
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-
-<para>If passed an ID in <varname>linkend</varname>,
-<function>check.idref.targets</function> makes sure that the element
-pointed to by the link is one of the elements listed in
-<varname>element-list</varname> and warns the user otherwise.</para>
-
-</refsect1></refentry>
-
-<refentry id="template.copyright.years">
-<refnamediv>
-<refname>copyright.years</refname>
-<refpurpose>Print a set of years with collapsed ranges</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-<synopsis>&lt;xsl:template name="copyright.years"&gt;
-&lt;xsl:param name="years"/&gt;
-&lt;xsl:param name="print.ranges" select="1"/&gt;
-&lt;xsl:param name="single.year.ranges" select="0"/&gt;
-&lt;xsl:param name="firstyear" select="0"/&gt;
-&lt;xsl:param name="nextyear" select="0"/&gt;
-  ...
-&lt;/xsl:template&gt;</synopsis>
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-
-<para>This template prints a list of year elements with consecutive
-years printed as a range. In other words:</para>
-
-
-<screen>&lt;year&gt;1992&lt;/year&gt;
-&lt;year&gt;1993&lt;/year&gt;
-&lt;year&gt;1994&lt;/year&gt;</screen>
-
-
-<para>is printed <quote>1992-1994</quote>, whereas:</para>
-
-
-<screen>&lt;year&gt;1992&lt;/year&gt;
-&lt;year&gt;1994&lt;/year&gt;</screen>
-
-
-<para>is printed <quote>1992, 1994</quote>.</para>
-
-
-
-<para>This template assumes that all the year elements contain only
-decimal year numbers, that the elements are sorted in increasing
-numerical order, that there are no duplicates, and that all the years
-are expressed in full <quote>century+year</quote>
-(<quote>1999</quote> not <quote>99</quote>) notation.</para>
-
-</refsect1><refsect1><title>Parameters</title>
-
-<variablelist>
-<varlistentry><term>years</term>
-<listitem>
-
-<para>The initial set of year elements.</para>
-
-</listitem>
-</varlistentry>
-<varlistentry><term>print.ranges</term>
-<listitem>
-
-<para>If non-zero, multi-year ranges are collapsed. If zero, all years
-are printed discretely.</para>
-
-</listitem>
-</varlistentry>
-<varlistentry><term>single.year.ranges</term>
-<listitem>
-
-<para>If non-zero, two consecutive years will be printed as a range,
-otherwise, they will be printed discretely. In other words, a single
-year range is <quote>1991-1992</quote> but discretely it's
-<quote>1991, 1992</quote>.</para>
-
-</listitem>
-</varlistentry>
-</variablelist>
-
-</refsect1><refsect1><title>Returns</title>
-
-<para>This template returns the formatted list of years.</para>
-
-</refsect1></refentry>
-
-<refentry id="template.find.path.params">
-<refnamediv>
-<refname>find.path.params</refname>
-<refpurpose>Search in a table for the "best" match for the node</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-<synopsis>&lt;xsl:template name="find.path.params"&gt;
-&lt;xsl:param name="node" select="."/&gt;
-&lt;xsl:param name="table" select="''"/&gt;
-&lt;xsl:param name="location"&gt;
-    &lt;xsl:call-template name="xpath.location"&gt;
-      &lt;xsl:with-param name="node" select="$node"/&gt;
-    &lt;/xsl:call-template&gt;
-  &lt;/xsl:param&gt;
-  ...
-&lt;/xsl:template&gt;</synopsis>
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-
-<para>This template searches in a table for the value that most-closely
-(in the typical best-match sense of XSLT) matches the current (element)
-node location.</para>
-
-</refsect1></refentry>
-
-<refentry id="template.string.upper">
-<refnamediv>
-<refname>string.upper</refname>
-<refpurpose>Converts a string to all uppercase letters</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-<synopsis>&lt;xsl:template name="string.upper"&gt;
-&lt;xsl:param name="string" select="''"/&gt;
-  ...
-&lt;/xsl:template&gt;</synopsis>
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-
-<para>Given a string, this template does a language-aware conversion
-of that string to all uppercase letters, based on the values of the
-<literal>lowercase.alpha</literal> and
-<literal>uppercase.alpha</literal> gentext keys for the current
-locale. It affects only those characters found in the values of
-<literal>lowercase.alpha</literal> and
-<literal>uppercase.alpha</literal>. All other characters are left
-unchanged.</para>
-
-</refsect1><refsect1><title>Parameters</title>
-
-<variablelist>
-<varlistentry><term>string</term>
-<listitem>
-
-<para>The string to convert to uppercase.</para>
-
-</listitem>
-</varlistentry>
-</variablelist>
-
-</refsect1></refentry>
-
-<refentry id="template.string.lower">
-<refnamediv>
-<refname>string.lower</refname>
-<refpurpose>Converts a string to all lowercase letters</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-<synopsis>&lt;xsl:template name="string.lower"&gt;
-&lt;xsl:param name="string" select="''"/&gt;
-  ...
-&lt;/xsl:template&gt;</synopsis>
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-
-<para>Given a string, this template does a language-aware conversion
-of that string to all lowercase letters, based on the values of the
-<literal>uppercase.alpha</literal> and
-<literal>lowercase.alpha</literal> gentext keys for the current
-locale. It affects only those characters found in the values of
-<literal>uppercase.alpha</literal> and
-<literal>lowercase.alpha</literal>. All other characters are left
-unchanged.</para>
-
-</refsect1><refsect1><title>Parameters</title>
-
-<variablelist>
-<varlistentry><term>string</term>
-<listitem>
-
-<para>The string to convert to lowercase.</para>
-
-</listitem>
-</varlistentry>
-</variablelist>
-
-</refsect1></refentry>
-
-<refentry id="template.select.choice.separator">
-<refnamediv>
-<refname>select.choice.separator</refname>
-<refpurpose>Returns localized choice separator</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-<synopsis>&lt;xsl:template name="select.choice.separator"/&gt;</synopsis>
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-    
-<para>This template enables auto-generation of an appropriate
-    localized "choice" separator (for example, "and" or "or") before
-    the final item in an inline list (though it could also be useful
-    for generating choice separators for non-inline lists).</para>
-
-    
-<para>It currently works by evaluating a processing instruction
-    (PI) of the form &lt;?dbchoice&#160;choice="foo"?&gt; :
-    
-<itemizedlist>
-      <listitem>
-        <simpara>if the value of the <tag>choice</tag>
-        pseudo-attribute is "and" or "or", returns a localized "and"
-        or "or"</simpara>
-      </listitem>
-      <listitem>
-        <simpara>otherwise returns the literal value of the
-        <tag>choice</tag> pseudo-attribute</simpara>
-      </listitem>
-    </itemizedlist>
-
-    The latter is provided only as a temporary workaround because the
-    locale files do not currently have translations for the word
-    <wordasword>or</wordasword>. So if you want to generate a a
-    logical "or" separator in French (for example), you currently need
-    to do this:
-    <literallayout>&lt;?dbchoice choice="ou"?&gt;</literallayout>
-    </para>
-
-    <warning>
-      
-<para>The <tag>dbchoice</tag> processing instruction is
-      an unfortunate hack; support for it may disappear in the future
-      (particularly if and when a more appropriate means for marking
-      up "choice" lists becomes available in DocBook).</para>
-
-    </warning>
-  </refsect1></refentry>
-
-<refentry id="template.evaluate.info.profile">
-<refnamediv>
-<refname>evaluate.info.profile</refname>
-<refpurpose>Evaluates an info profile</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-<synopsis>&lt;xsl:template name="evaluate.info.profile"&gt;
-&lt;xsl:param name="profile"/&gt;
-&lt;xsl:param name="info"/&gt;
-  ...
-&lt;/xsl:template&gt;</synopsis>
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-    
-<para>This template evaluates an "info profile" matching the XPath
-    expression given by the <parameter>profile</parameter>
-    parameter. It relies on the XSLT <function>evaluate()</function>
-    extension function.</para>
-
-
-    
-<para>The value of the <parameter>profile</parameter> parameter
-    can include the literal string <literal>$info</literal>. If found
-    in the value of the <parameter>profile</parameter> parameter, the
-    literal string <literal>$info</literal> string is replaced with
-    the value of the <parameter>info</parameter> parameter, which
-    should be a set of <replaceable>*info</replaceable> nodes; the
-    expression is then evaluated using the XSLT
-    <function>evaluate()</function> extension function.</para>
-
-  </refsect1><refsect1><title>Parameters</title>
-    
-<variablelist>
-       <varlistentry>
-        <term>profile</term>
-        <listitem>
-          
-<para>A string representing an XPath expression </para>
-
-        </listitem>
-      </varlistentry>
-       <varlistentry>
-        <term>info</term>
-        <listitem>
-          
-<para>A set of *info nodes</para>
-
-        </listitem>
-      </varlistentry>
-    </variablelist>
-
-  </refsect1><refsect1><title>Returns</title>
-    
-<para>Returns a node (the result of evaluating the
-    <parameter>profile</parameter> parameter)</para>
-
-  </refsect1></refentry>
-
-<refentry id="template.graphic.format.content-type">
-<refnamediv>
-<refname>graphic.format.content-type</refname>
-<refpurpose>Returns mimetype for media format</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-<synopsis>&lt;xsl:template name="graphic.format.content-type"&gt;
-&lt;xsl:param name="format"/&gt;
-  ...
-&lt;/xsl:template&gt;</synopsis>
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-    
-<para>This takes as input a 'format' param and returns
-    a mimetype string.  It uses an xsl:choose after first
-    converting the input to all uppercase.</para>
-
-  </refsect1></refentry>
-</reference>
-        <reference id="refentry" xml:base="../common/refentry.xml">
-  <info>
-    <title>Common &#187; Refentry Metadata Template Reference</title>
-    <releaseinfo role="meta">
-      $Id: refentry.xsl 7867 2008-03-07 09:54:25Z xmldoc $
-    </releaseinfo>
-  </info>
-  
-  <partintro id="partintro">
-    <title>Introduction</title>
-    
-<para>This is technical reference documentation for the &#8220;refentry
-    metadata&#8221; templates in the DocBook XSL Stylesheets.</para>
-
-    
-<para>This is not intended to be user documentation. It is provided
-    for developers writing customization layers for the stylesheets.</para>
-
-    <note>
-      
-<para>Currently, only the manpages stylesheets make use of these
-      templates. They are, however, potentially useful elsewhere.</para>
-
-    </note>
-  </partintro>
-
-<refentry id="template.get.refentry.metadata">
-<refnamediv>
-<refname>get.refentry.metadata</refname>
-<refpurpose>Gathers metadata from a refentry and its ancestors</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-<synopsis>&lt;xsl:template name="get.refentry.metadata"&gt;
-&lt;xsl:param name="refname"/&gt;
-&lt;xsl:param name="info"/&gt;
-&lt;xsl:param name="prefs"/&gt;
-  ...
-&lt;/xsl:template&gt;</synopsis>
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-    
-<para>Reference documentation for particular commands, functions,
-    etc., is sometimes viewed in isolation from its greater "context". For
-    example, users view Unix man pages as, well, individual pages, not as
-    part of a "book" of some kind. Therefore, it is sometimes necessary to
-    embed "context" information in output for each <tag>refentry</tag>.</para>
-
-
-    
-<para>However, one problem is that different users mark up that
-    context information in different ways. Often (usually), the
-    context information is not actually part of the content of the
-    <tag>refentry</tag> itself, but instead part of the content of a
-    parent or ancestor element to the <tag>refentry</tag>. And
-    even then, DocBook provides a variety of elements that users might
-    potentially use to mark up the same kind of information. One user
-    might use the <tag>productnumber</tag> element to mark up version
-    information about a particular product, while another might use
-    the <tag>releaseinfo</tag> element.</para>
-
-
-    
-<para>Taking all that in mind, the
-    <function>get.refentry.metadata</function> template tries to gather
-    metadata from a <tag>refentry</tag> element and its ancestor
-    elements in an intelligent and user-configurable way. The basic
-    mechanism used in the XPath expressions throughout this stylesheet
-    is to select the relevant metadata from the *info element that is
-    closest to the actual <tag>refentry</tag>&#160;&#8211; either on the
-    <tag>refentry</tag> itself, or on its nearest ancestor.</para>
-
-
-    <note>
-      
-<para>The <function>get.refentry.metadata</function>
-        template is actually just sort of a "driver" template; it
-        calls other templates that do the actual data collection,
-        then returns the data as a set.</para>
-
-    </note>
-
-  </refsect1><refsect1><title>Parameters</title>
-    
-<variablelist>
-      <varlistentry>
-        <term>refname</term>
-        <listitem>
-          
-<para>The first <tag>refname</tag> in the refentry</para>
-
-        </listitem>
-      </varlistentry>
-      <varlistentry>
-        <term>info</term>
-        <listitem>
-          
-<para>A set of info nodes (from a <tag>refentry</tag>
-          element and its ancestors)</para>
-
-        </listitem>
-      </varlistentry>
-      <varlistentry>
-        <term>prefs</term>
-        <listitem>
-          
-<para>A node containing user preferences (from global
-          stylesheet parameters)</para>
-
-        </listitem>
-      </varlistentry>
-    </variablelist>
-
-  </refsect1><refsect1><title>Returns</title>
-    
-<para>Returns a node set with the following elements. The
-    descriptions are verbatim from the <literal>man(7)</literal> man
-    page.
-    
-<variablelist>
-      <varlistentry>
-        <term>title</term>
-        <listitem>
-          
-<para>the title of the man page (e.g., <literal>MAN</literal>)</para>
-
-        </listitem>
-      </varlistentry>
-      <varlistentry>
-        <term>section</term>
-        <listitem>
-          
-<para>the section number the man page should be placed in (e.g.,
-          <literal>7</literal>)</para>
-
-        </listitem>
-      </varlistentry>
-      <varlistentry>
-        <term>date</term>
-        <listitem>
-          
-<para>the date of the last revision</para>
-
-        </listitem>
-      </varlistentry>
-      <varlistentry>
-        <term>source</term>
-        <listitem>
-          
-<para>the source of the command</para>
-
-        </listitem>
-      </varlistentry>
-      <varlistentry>
-        <term>manual</term>
-        <listitem>
-          
-<para>the title of the manual (e.g., <citetitle>Linux
-          Programmer's Manual</citetitle>)</para>
-
-        </listitem>
-      </varlistentry>
-    </variablelist>
-
-    </para>
-
-  </refsect1></refentry>
-
-<refentry id="template.get.refentry.title">
-<refnamediv>
-<refname>get.refentry.title</refname>
-<refpurpose>Gets title metadata for a refentry</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-<synopsis>&lt;xsl:template name="get.refentry.title"&gt;
-&lt;xsl:param name="refname"/&gt;
-  ...
-&lt;/xsl:template&gt;</synopsis>
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-    
-<para>The <literal>man(7)</literal> man page describes this as "the
-    title of the man page (e.g., <literal>MAN</literal>). This differs
-    from <tag>refname</tag> in that, if the <tag>refentry</tag> has a
-    <tag>refentrytitle</tag>, we use that as the <tag>title</tag>;
-    otherwise, we just use first <tag>refname</tag> in the first
-    <tag>refnamediv</tag> in the source.</para>
-
-  </refsect1><refsect1><title>Parameters</title>
-    
-<variablelist>
-      <varlistentry>
-        <term>refname</term>
-        <listitem>
-          
-<para>The first <tag>refname</tag> in the refentry</para>
-
-        </listitem>
-      </varlistentry>
-    </variablelist>
-
-  </refsect1><refsect1><title>Returns</title>
-  
-<para>Returns a <tag>title</tag> node.</para>
-</refsect1></refentry>
-
-<refentry id="template.get.refentry.section">
-<refnamediv>
-<refname>get.refentry.section</refname>
-<refpurpose>Gets section metadata for a refentry</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-<synopsis>&lt;xsl:template name="get.refentry.section"&gt;
-&lt;xsl:param name="refname"/&gt;
-&lt;xsl:param name="quiet" select="0"/&gt;
-  ...
-&lt;/xsl:template&gt;</synopsis>
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-    
-<para>The <literal>man(7)</literal> man page describes this as "the
-    section number the man page should be placed in (e.g.,
-    <literal>7</literal>)". If we do not find a <tag>manvolnum</tag>
-    specified in the source, and we find that the <tag>refentry</tag> is
-    for a function, we use the section number <literal>3</literal>
-    ["Library calls (functions within program libraries)"]; otherwise, we
-    default to using <literal>1</literal> ["Executable programs or shell
-    commands"].</para>
-
-  </refsect1><refsect1><title>Parameters</title>
-    
-<variablelist>
-      <varlistentry>
-        <term>refname</term>
-        <listitem>
-          
-<para>The first <tag>refname</tag> in the refentry</para>
-
-        </listitem>
-      </varlistentry>
-      <varlistentry>
-        <term>quiet</term>
-        <listitem>
-          
-<para>If non-zero, no "missing" message is emitted</para>
-
-        </listitem>
-      </varlistentry>
-    </variablelist>
-
-  </refsect1><refsect1><title>Returns</title>
-  
-<para>Returns a string representing a section number.</para>
-</refsect1></refentry>
-
-<refentry id="template.get.refentry.date">
-<refnamediv>
-<refname>get.refentry.date</refname>
-<refpurpose>Gets date metadata for a refentry</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-<synopsis>&lt;xsl:template name="get.refentry.date"&gt;
-&lt;xsl:param name="refname"/&gt;
-&lt;xsl:param name="info"/&gt;
-&lt;xsl:param name="prefs"/&gt;
-  ...
-&lt;/xsl:template&gt;</synopsis>
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-    
-<para>The <literal>man(7)</literal> man page describes this as "the
-    date of the last revision". If we cannot find a date in the source, we
-    generate one.</para>
-
-  </refsect1><refsect1><title>Parameters</title>
-    
-<variablelist>
-      <varlistentry>
-        <term>refname</term>
-        <listitem>
-          
-<para>The first <tag>refname</tag> in the refentry</para>
-
-        </listitem>
-      </varlistentry>
-      <varlistentry>
-        <term>info</term>
-        <listitem>
-          
-<para>A set of info nodes (from a <tag>refentry</tag>
-          element and its ancestors)</para>
-
-        </listitem>
-      </varlistentry>
-      <varlistentry>
-        <term>prefs</term>
-        <listitem>
-          
-<para>A node containing users preferences (from global stylesheet parameters)</para>
-
-        </listitem>
-      </varlistentry>
-    </variablelist>
-
-  </refsect1><refsect1><title>Returns</title>
-    
-<para>Returns a <tag>date</tag> node.</para>
-
-  </refsect1></refentry>
-
-<refentry id="template.get.refentry.source">
-<refnamediv>
-<refname>get.refentry.source</refname>
-<refpurpose>Gets source metadata for a refentry</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-<synopsis>&lt;xsl:template name="get.refentry.source"&gt;
-&lt;xsl:param name="refname"/&gt;
-&lt;xsl:param name="info"/&gt;
-&lt;xsl:param name="prefs"/&gt;
-  ...
-&lt;/xsl:template&gt;</synopsis>
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-    
-<para>The <literal>man(7)</literal> man page describes this as "the
-    source of the command", and provides the following examples:
-    
-<itemizedlist>
-      <listitem>
-        
-<para>For binaries, use something like: GNU, NET-2, SLS
-        Distribution, MCC Distribution.</para>
-
-      </listitem>
-      <listitem>
-        
-<para>For system calls, use the version of the kernel that you are
-        currently looking at: Linux 0.99.11.</para>
-
-      </listitem>
-      <listitem>
-        
-<para>For library calls, use the source of the function: GNU, BSD
-        4.3, Linux DLL 4.4.1.</para>
-
-      </listitem>
-    </itemizedlist>
-
-    </para>
-
-
-    
-<para>The <literal>solbook(5)</literal> man page describes
-    something very much like what <literal>man(7)</literal> calls
-    "source", except that <literal>solbook(5)</literal> names it
-    "software" and describes it like this:
-    <blockquote>
-      
-<para>This is the name of the software product that the topic
-      discussed on the reference page belongs to. For example UNIX
-      commands are part of the <literal>SunOS x.x</literal>
-      release.</para>
-
-    </blockquote>
-    </para>
-
-
-    
-<para>In practice, there are many pages that simply have a version
-    number in the "source" field. So, it looks like what we have is a
-    two-part field,
-    <replaceable>Name</replaceable>&#160;<replaceable>Version</replaceable>,
-    where:
-    
-<variablelist>
-      <varlistentry>
-        <term>Name</term>
-        <listitem>
-          
-<para>product name (e.g., BSD) or org. name (e.g., GNU)</para>
-
-        </listitem>
-      </varlistentry>
-      <varlistentry>
-        <term>Version</term>
-        <listitem>
-          
-<para>version name</para>
-
-        </listitem>
-      </varlistentry>
-    </variablelist>
-
-    Each part is optional. If the <replaceable>Name</replaceable> is a
-    product name, then the <replaceable>Version</replaceable> is probably
-    the version of the product. Or there may be no
-    <replaceable>Name</replaceable>, in which case, if there is a
-    <replaceable>Version</replaceable>, it is probably the version of the
-    item itself, not the product it is part of. Or, if the
-    <replaceable>Name</replaceable> is an organization name, then there
-    probably will be no <replaceable>Version</replaceable>.
-    </para>
-
-  </refsect1><refsect1><title>Parameters</title>
-    
-<variablelist>
-      <varlistentry>
-        <term>refname</term>
-        <listitem>
-          
-<para>The first <tag>refname</tag> in the refentry</para>
-
-        </listitem>
-      </varlistentry>
-      <varlistentry>
-        <term>info</term>
-        <listitem>
-          
-<para>A set of info nodes (from a <tag>refentry</tag>
-          element and its ancestors)</para>
-
-        </listitem>
-      </varlistentry>
-      <varlistentry>
-        <term>prefs</term>
-        <listitem>
-          
-<para>A node containing users preferences (from global
-          stylesheet parameters)</para>
-
-        </listitem>
-      </varlistentry>
-    </variablelist>
-
-  </refsect1><refsect1><title>Returns</title>
-    
-<para>Returns a <tag>source</tag> node.</para>
-
-  </refsect1></refentry>
-
-<refentry id="template.get.refentry.source.name">
-<refnamediv>
-<refname>get.refentry.source.name</refname>
-<refpurpose>Gets source-name metadata for a refentry</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-<synopsis>&lt;xsl:template name="get.refentry.source.name"&gt;
-&lt;xsl:param name="refname"/&gt;
-&lt;xsl:param name="info"/&gt;
-&lt;xsl:param name="prefs"/&gt;
-  ...
-&lt;/xsl:template&gt;</synopsis>
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-    
-<para>A "source name" is one part of a (potentially) two-part
-    <replaceable>Name</replaceable>&#160;<replaceable>Version</replaceable>
-    source field. For more details, see the documentation for the
-    <function>get.refentry.source</function> template.</para>
-
-  </refsect1><refsect1><title>Parameters</title>
-    
-<variablelist>
-      <varlistentry>
-        <term>refname</term>
-        <listitem>
-          
-<para>The first <tag>refname</tag> in the refentry</para>
-
-        </listitem>
-      </varlistentry>
-      <varlistentry>
-        <term>info</term>
-        <listitem>
-          
-<para>A set of info nodes (from a <tag>refentry</tag>
-          element and its ancestors)</para>
-
-        </listitem>
-      </varlistentry>
-      <varlistentry>
-        <term>prefs</term>
-        <listitem>
-          
-<para>A node containing users preferences (from global
-          stylesheet parameters)</para>
-
-        </listitem>
-      </varlistentry>
-    </variablelist>
-
-  </refsect1><refsect1><title>Returns</title>
-    
-<para>Depending on what output method is used for the
-  current stylesheet, either returns a text node or possibly an element
-  node, containing "source name" data.</para>
-
-  </refsect1></refentry>
-
-<refentry id="template.get.refentry.version">
-<refnamediv>
-<refname>get.refentry.version</refname>
-<refpurpose>Gets version metadata for a refentry</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-<synopsis>&lt;xsl:template name="get.refentry.version"&gt;
-&lt;xsl:param name="refname"/&gt;
-&lt;xsl:param name="info"/&gt;
-&lt;xsl:param name="prefs"/&gt;
-  ...
-&lt;/xsl:template&gt;</synopsis>
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-    
-<para>A "version" is one part of a (potentially) two-part
-    <replaceable>Name</replaceable>&#160;<replaceable>Version</replaceable>
-    source field. For more details, see the documentation for the
-    <function>get.refentry.source</function> template.</para>
-
-  </refsect1><refsect1><title>Parameters</title>
-    
-<variablelist>
-      <varlistentry>
-        <term>refname</term>
-        <listitem>
-          
-<para>The first <tag>refname</tag> in the refentry</para>
-
-        </listitem>
-      </varlistentry>
-      <varlistentry>
-        <term>info</term>
-        <listitem>
-          
-<para>A set of info nodes (from a <tag>refentry</tag>
-          element and its ancestors)</para>
-
-        </listitem>
-      </varlistentry>
-      <varlistentry>
-        <term>prefs</term>
-        <listitem>
-          
-<para>A node containing users preferences (from global
-          stylesheet parameters)</para>
-
-        </listitem>
-      </varlistentry>
-    </variablelist>
-
-  </refsect1><refsect1><title>Returns</title>
-    
-<para>Depending on what output method is used for the
-  current stylesheet, either returns a text node or possibly an element
-  node, containing "version" data.</para>
-
-  </refsect1></refentry>
-
-<refentry id="template.get.refentry.manual">
-<refnamediv>
-<refname>get.refentry.manual</refname>
-<refpurpose>Gets source metadata for a refentry</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-<synopsis>&lt;xsl:template name="get.refentry.manual"&gt;
-&lt;xsl:param name="refname"/&gt;
-&lt;xsl:param name="info"/&gt;
-&lt;xsl:param name="prefs"/&gt;
-  ...
-&lt;/xsl:template&gt;</synopsis>
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-    
-<para>The <literal>man(7)</literal> man page describes this as "the
-    title of the manual (e.g., <citetitle>Linux Programmer's
-    Manual</citetitle>)". Here are some examples from existing man pages:
-    
-<itemizedlist>
-      <listitem>
-        
-<para><citetitle>dpkg utilities</citetitle>
-        (<command>dpkg-name</command>)</para>
-
-      </listitem>
-      <listitem>
-        
-<para><citetitle>User Contributed Perl Documentation</citetitle>
-        (<command>GET</command>)</para>
-
-      </listitem>
-      <listitem>
-        
-<para><citetitle>GNU Development Tools</citetitle>
-        (<command>ld</command>)</para>
-
-      </listitem>
-      <listitem>
-        
-<para><citetitle>Emperor Norton Utilities</citetitle>
-        (<command>ddate</command>)</para>
-
-      </listitem>
-      <listitem>
-        
-<para><citetitle>Debian GNU/Linux manual</citetitle>
-        (<command>faked</command>)</para>
-
-      </listitem>
-      <listitem>
-        
-<para><citetitle>GIMP Manual Pages</citetitle>
-        (<command>gimp</command>)</para>
-
-      </listitem>
-      <listitem>
-        
-<para><citetitle>KDOC Documentation System</citetitle>
-        (<command>qt2kdoc</command>)</para>
-
-      </listitem>
-    </itemizedlist>
-
-    </para>
-
-
-    
-<para>The <literal>solbook(5)</literal> man page describes
-    something very much like what <literal>man(7)</literal> calls
-    "manual", except that <literal>solbook(5)</literal> names it
-    "sectdesc" and describes it like this:
-    <blockquote>
-      
-<para>This is the section title of the reference page; for
-      example <literal>User Commands</literal>.</para>
-
-    </blockquote>
-    </para>
-
-
-  </refsect1><refsect1><title>Parameters</title>
-    
-<variablelist>
-      <varlistentry>
-        <term>refname</term>
-        <listitem>
-          
-<para>The first <tag>refname</tag> in the refentry</para>
-
-        </listitem>
-      </varlistentry>
-      <varlistentry>
-        <term>info</term>
-        <listitem>
-          
-<para>A set of info nodes (from a <tag>refentry</tag>
-          element and its ancestors)</para>
-
-        </listitem>
-      </varlistentry>
-      <varlistentry>
-        <term>prefs</term>
-        <listitem>
-          
-<para>A node containing users preferences (from global
-          stylesheet parameters)</para>
-
-        </listitem>
-      </varlistentry>
-    </variablelist>
-
-  </refsect1><refsect1><title>Returns</title>
-    
-<para>Returns a <tag>manual</tag> node.</para>
-
-  </refsect1></refentry>
-
-<refentry id="template.get.refentry.metadata.prefs">
-<refnamediv>
-<refname>get.refentry.metadata.prefs</refname>
-<refpurpose>Gets user preferences for refentry metadata gathering</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-<synopsis>&lt;xsl:template name="get.refentry.metadata.prefs"/&gt;</synopsis>
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-    
-<para>The DocBook XSL stylesheets include several user-configurable
-    global stylesheet parameters for controlling <tag>refentry</tag>
-    metadata gathering. Those parameters are not read directly by the
-    other <tag>refentry</tag> metadata-gathering
-    templates. Instead, they are read only by the
-    <function>get.refentry.metadata.prefs</function> template,
-    which assembles them into a structure that is then passed to
-    the other <tag>refentry</tag> metadata-gathering
-    templates.</para>
-
-
-    
-<para>So the, <function>get.refentry.metadata.prefs</function>
-    template is the only interface to collecting stylesheet parameters for
-    controlling <tag>refentry</tag> metadata gathering.</para>
-
-  </refsect1><refsect1><title>Parameters</title>
-    
-<para>There are no local parameters for this template; however, it
-    does rely on a number of global parameters.</para>
-
-  </refsect1><refsect1><title>Returns</title>
-    
-<para>Returns a <tag>manual</tag> node.</para>
-
-  </refsect1></refentry>
-
-<refentry id="template.set.refentry.metadata">
-<refnamediv>
-<refname>set.refentry.metadata</refname>
-<refpurpose>Sets content of a refentry metadata item</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-<synopsis>&lt;xsl:template name="set.refentry.metadata"&gt;
-&lt;xsl:param name="refname"/&gt;
-&lt;xsl:param name="info"/&gt;
-&lt;xsl:param name="contents"/&gt;
-&lt;xsl:param name="context"/&gt;
-&lt;xsl:param name="preferred"/&gt;
-  ...
-&lt;/xsl:template&gt;</synopsis>
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-    
-<para>The <function>set.refentry.metadata</function> template is
-    called each time a suitable source element is found for a certain
-    metadata field.</para>
-
-  </refsect1><refsect1><title>Parameters</title>
-    
-<variablelist>
-      <varlistentry>
-        <term>refname</term>
-        <listitem>
-          
-<para>The first <tag>refname</tag> in the refentry</para>
-
-        </listitem>
-      </varlistentry>
-      <varlistentry>
-        <term>info</term>
-        <listitem>
-          
-<para>A single *info node that contains the selected source element.</para>
-
-        </listitem>
-      </varlistentry>
-      <varlistentry>
-        <term>contents</term>
-        <listitem>
-          
-<para>A node containing the selected source element.</para>
-
-        </listitem>
-      </varlistentry>
-      <varlistentry>
-        <term>context</term>
-        <listitem>
-          
-<para>A string describing the metadata context in which the
-          <function>set.refentry.metadata</function> template was
-          called: either "date", "source", "version", or "manual".</para>
-
-        </listitem>
-      </varlistentry>
-    </variablelist>
-
-  </refsect1><refsect1><title>Returns</title>
-  
-<para>Returns formatted contents of a selected source element.</para>
-</refsect1></refentry>
-</reference>
-        <reference id="utility" xml:base="../common/utility.xml">
-  <info>
-    <title>Common &#187; Utility Template Reference</title>
-    <releaseinfo role="meta">
-      $Id: utility.xsl 7101 2007-07-20 15:32:12Z xmldoc $
-    </releaseinfo>
-  </info>
-  
-  <partintro id="partintro">
-    <title>Introduction</title>
-    
-<para>This is technical reference documentation for the
-      miscellaneous utility templates in the DocBook XSL
-      Stylesheets.</para>
-
-    <note>
-      
-<para>These templates are defined in a separate file from the set
-        of &#8220;common&#8221; templates because some of the common templates
-        reference DocBook XSL stylesheet parameters, requiring the
-        entire set of parameters to be imported/included in any
-        stylesheet that imports/includes the common templates.</para>
-
-      
-<para>The utility templates don&#8217;t import or include any DocBook
-        XSL stylesheet parameters, so the utility templates can be used
-        without importing the whole set of parameters.</para>
-
-    </note>
-    
-<para>This is not intended to be user documentation. It is
-      provided for developers writing customization layers for the
-      stylesheets.</para>
-
-  </partintro>
-
-<refentry id="template.log.message">
-<refnamediv>
-<refname>log.message</refname>
-<refpurpose>Logs/emits formatted notes and warnings</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-<synopsis>&lt;xsl:template name="log.message"&gt;
-&lt;xsl:param name="level"/&gt;
-&lt;xsl:param name="source"/&gt;
-&lt;xsl:param name="context-desc"/&gt;
-&lt;xsl:param name="context-desc-field-length"&gt;12&lt;/xsl:param&gt;
-&lt;xsl:param name="context-desc-padded"&gt;
-    &lt;xsl:if test="not($context-desc = '')"&gt;
-      &lt;xsl:call-template name="pad-string"&gt;
-        &lt;xsl:with-param name="leftRight"&gt;right&lt;/xsl:with-param&gt;
-        &lt;xsl:with-param name="padVar" select="substring($context-desc, 1, $context-desc-field-length)"/&gt;
-        &lt;xsl:with-param name="length" select="$context-desc-field-length"/&gt;
-      &lt;/xsl:call-template&gt;
-    &lt;/xsl:if&gt;
-  &lt;/xsl:param&gt;
-&lt;xsl:param name="message"/&gt;
-&lt;xsl:param name="message-field-length" select="45"/&gt;
-&lt;xsl:param name="message-padded"&gt;
-    &lt;xsl:variable name="spaces-for-blank-level"&gt;
-      &lt;!-- * if the level field is blank, we'll need to pad out --&gt;
-      &lt;!-- * the message field with spaces to compensate --&gt;
-      &lt;xsl:choose&gt;
-        &lt;xsl:when test="$level = ''"&gt;
-          &lt;xsl:value-of select="4 + 2"/&gt;
-          &lt;!-- * 4 = hard-coded length of comment text ("Note" or "Warn") --&gt;
-          &lt;!-- * + 2 = length of colon-plus-space separator ": " --&gt;
-        &lt;/xsl:when&gt;
-        &lt;xsl:otherwise&gt;
-          &lt;xsl:value-of select="0"/&gt;
-        &lt;/xsl:otherwise&gt;
-      &lt;/xsl:choose&gt;
-    &lt;/xsl:variable&gt;
-    &lt;xsl:variable name="spaces-for-blank-context-desc"&gt;
-      &lt;!-- * if the context-description field is blank, we'll need --&gt;
-      &lt;!-- * to pad out the message field with spaces to compensate --&gt;
-      &lt;xsl:choose&gt;
-        &lt;xsl:when test="$context-desc = ''"&gt;
-          &lt;xsl:value-of select="$context-desc-field-length + 2"/&gt;
-          &lt;!-- * + 2 = length of colon-plus-space separator ": " --&gt;
-        &lt;/xsl:when&gt;
-        &lt;xsl:otherwise&gt;
-          &lt;xsl:value-of select="0"/&gt;
-        &lt;/xsl:otherwise&gt;
-      &lt;/xsl:choose&gt;
-    &lt;/xsl:variable&gt;
-    &lt;xsl:variable name="extra-spaces" select="$spaces-for-blank-level + $spaces-for-blank-context-desc"/&gt;
-    &lt;xsl:call-template name="pad-string"&gt;
-      &lt;xsl:with-param name="leftRight"&gt;right&lt;/xsl:with-param&gt;
-      &lt;xsl:with-param name="padVar" select="substring($message, 1, ($message-field-length + $extra-spaces))"/&gt;
-      &lt;xsl:with-param name="length" select="$message-field-length + $extra-spaces"/&gt;
-    &lt;/xsl:call-template&gt;
-  &lt;/xsl:param&gt;
-  ...
-&lt;/xsl:template&gt;</synopsis>
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-    
-<para>The <function>log.message</function> template is a utility
-    template for logging/emitting formatted messages&#160;&#8211; that is,
-    notes and warnings, along with a given log &#8220;level&#8221; and an
-    identifier for the &#8220;source&#8221; that the message relates to.</para>
-
-  </refsect1><refsect1><title>Parameters</title>
-    
-<variablelist>
-      <varlistentry><term>level</term>
-        <listitem>
-          
-<para>Text to log/emit in the message-level field to
-            indicate the message level
-          (<literal>Note</literal> or
-          <literal>Warning</literal>)</para>
-
-        </listitem>
-      </varlistentry>
-      <varlistentry><term>source</term>
-        <listitem>
-          
-<para>Text to log/emit in the source field to identify the
-            &#8220;source&#8221; to which the notification/warning relates.
-            This can be any arbitrary string, but because the
-            message lacks line and column numbers to identify the
-            exact part of the source document to which it
-            relates, the intention is that the value you pass
-            into the <literal>source</literal> parameter should
-            give the user some way to identify the portion of
-            their source document on which to take potentially
-            take action in response to the log message (for
-            example, to edit, change, or add content).</para>
-
-          
-<para>So the <literal>source</literal> value should be,
-            for example, an ID, book/chapter/article title, title
-            of some formal object, or even a string giving an
-            XPath expression.</para>
-
-        </listitem>
-      </varlistentry>
-      <varlistentry><term>context-desc</term>
-        <listitem>
-          
-<para>Text to log/emit in the context-description field to
-            describe the context for the message.</para>
-
-        </listitem>
-      </varlistentry>
-      <varlistentry><term>context-desc-field-length</term>
-        <listitem>
-          
-<para>Specifies length of the context-description field
-            (in characters); default is 12</para>
-
-          
-<para>If the text specified by the
-            <literal>context-desc</literal> parameter is longer
-            than the number of characters specified in
-            <literal>context-desc-field-length</literal>, it is
-            truncated to <literal>context-desc-field-length</literal>
-            (12 characters by default).</para>
-
-          
-<para>If the specified text is shorter than
-            <literal>context-desc-field-length</literal>,
-          it is right-padded out to
-          <literal>context-desc-field-length</literal> (12 by
-          default).</para>
-
-        
-<para>If no value has been specified for the
-          <literal>context-desc</literal> parameter, the field is
-          left empty and the text of the log message begins with
-          the value of the <literal>message</literal>
-          parameter.</para>
-
-        </listitem>
-      </varlistentry>
-      <varlistentry><term>message</term>
-        <listitem>
-          
-<para>Text to log/emit in the actual message field</para>
-
-        </listitem>
-      </varlistentry>
-      <varlistentry><term>message-field-length</term>
-        <listitem>
-          
-<para>Specifies length of the message
-            field (in characters); default is 45</para>
-
-        </listitem>
-      </varlistentry>
-    </variablelist>
-
-  </refsect1><refsect1><title>Returns</title>
-  
-<para>Outputs a message (generally, to standard error).</para>
-</refsect1></refentry>
-
-<refentry id="template.get.doc.title">
-<refnamediv>
-<refname>get.doc.title</refname>
-<refpurpose>Gets a title from the current document</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-<synopsis>&lt;xsl:template name="get.doc.title"/&gt;</synopsis>
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-    
-<para>The <function>get.doc.title</function> template is a
-      utility template for returning the first title found in the
-      current document.</para>
-
-  </refsect1><refsect1><title>Returns</title>
-  
-<para>Returns a string containing some identifying title for the
-    current document .</para>
-</refsect1></refentry>
-
-<refentry id="template.pad-string">
-<refnamediv>
-<refname>pad-string</refname>
-<refpurpose>Right-pads or left-pads a string out to a certain length</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-<synopsis>&lt;xsl:template name="pad-string"&gt;
-&lt;xsl:param name="padChar" select="' '"/&gt;
-&lt;xsl:param name="leftRight"&gt;left&lt;/xsl:param&gt;
-&lt;xsl:param name="padVar"/&gt;
-&lt;xsl:param name="length"/&gt;
-  ...
-&lt;/xsl:template&gt;</synopsis>
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-    
-<para>This function takes string <parameter>padVar</parameter> and
-      pads it out in the direction <parameter>rightLeft</parameter> to
-      the string-length <parameter>length</parameter>, using string
-      <parameter>padChar</parameter> (a space character by default) as
-      the padding string (note that <parameter>padChar</parameter> can
-      be a string; it is not limited to just being a single
-      character).</para>
-
-    <note>
-      
-<para>This function began as a copy of Nate Austin's
-        <function>prepend-pad</function> function in the <link xlink:href="http://www.dpawson.co.uk/xsl/sect2/padding.html">Padding
-          Content</link> section of Dave Pawson's <link xlink:href="http://www.dpawson.co.uk/xsl/index.html">XSLT
-          FAQ</link>.</para>
-
-    </note>
-  </refsect1><refsect1><title>Returns</title>
-  
-<para>Returns a (padded) string.</para>
-</refsect1></refentry>
-</reference>
-        <reference id="charmap" xml:base="../common/charmap.xml">
-  <info>
-    <title>Common &#187; Character-Map Template Reference</title>
-    <releaseinfo role="meta">
-      $Id: charmap.xsl 7266 2007-08-22 11:58:42Z xmldoc $
-    </releaseinfo>
-  </info>
-  
-  <partintro id="partintro">
-    <title>Introduction</title>
-    
-<para>This is technical reference documentation for the
-      character-map templates in the DocBook XSL Stylesheets.</para>
-
-    <note>
-      
-<para>These templates are defined in a separate file from the set
-        of &#8220;common&#8221; templates because some of the common templates
-        reference DocBook XSL stylesheet parameters, requiring the
-        entire set of parameters to be imported/included in any
-        stylesheet that imports/includes the common templates.</para>
-
-      
-<para>The character-map templates don&#8217;t import or include
-        any DocBook XSL stylesheet parameters, so the
-        character-map templates can be used without importing the
-        whole set of parameters.</para>
-
-    </note>
-    
-<para>This is not intended to be user documentation. It is
-      provided for developers writing customization layers for the
-      stylesheets.</para>
-
-  </partintro>
-
-<refentry id="template.apply-character-map">
-<refnamediv>
-<refname>apply-character-map</refname>
-<refpurpose>Applies an XSLT character map</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-<synopsis>&lt;xsl:template name="apply-character-map"&gt;
-&lt;xsl:param name="content"/&gt;
-&lt;xsl:param name="map.contents"/&gt;
-  ...
-&lt;/xsl:template&gt;</synopsis>
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-    
-<para>This template applies an <link xlink:href="http://www.w3.org/TR/xslt20/#character-maps">XSLT character map</link>; that is, it causes certain
-      individual characters to be substituted with strings of one
-      or more characters. It is useful mainly for replacing
-      multiple &#8220;special&#8221; characters or symbols in the same target
-      content. It uses the value of
-      <parameter>map.contents</parameter> to do substitution on
-      <parameter>content</parameter>, and then returns the
-      modified contents.</para>
-
-    <note>
-      
-<para>This template is a very slightly modified version of
-        Jeni Tennison&#8217;s <function>replace_strings</function>
-        template in the <link xlink:href="http://www.dpawson.co.uk/xsl/sect2/StringReplace.html#d9351e13">multiple string replacements</link> section of Dave Pawson&#8217;s
-        <link xlink:href="http://www.dpawson.co.uk/xsl/index.html">XSLT FAQ</link>.</para>
-
-      
-<para>The <function>apply-string-subst-map</function>
-        template is essentially the same template as the
-        <function>apply-character-map</function> template; the
-        only difference is that in the map that
-        <function>apply-string-subst-map</function> expects, <tag class="attribute">oldstring</tag> and <tag class="attribute">newstring</tag> attributes are used
-        instead of <tag class="attribute">character</tag> and <tag class="attribute">string</tag> attributes.</para>
-
-    </note>
-  </refsect1><refsect1><title>Parameters</title>
-    
-<variablelist>
-      <varlistentry><term>content</term>
-        <listitem>
-          
-<para>The content on which to perform the character-map
-            substitution.</para>
-
-        </listitem>
-      </varlistentry>
-      <varlistentry><term>map.contents</term>
-        <listitem>
-          
-<para>A node set of elements, with each element having
-            the following attributes:
-            
-<itemizedlist>
-              <listitem>
-                <simpara><tag class="attribute">character</tag>, a
-                  character to be replaced</simpara>
-              </listitem>
-              <listitem>
-                <simpara><tag class="attribute">string</tag>, a
-                  string with which to replace <tag class="attribute">character</tag></simpara>
-              </listitem>
-            </itemizedlist>
-
-          </para>
-
-        </listitem>
-      </varlistentry>
-    </variablelist>
-
-  </refsect1></refentry>
-
-<refentry id="template.read-character-map">
-<refnamediv>
-<refname>read-character-map</refname>
-<refpurpose>Reads in all or part of an XSLT character map</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-<synopsis>&lt;xsl:template name="read-character-map"&gt;
-&lt;xsl:param name="use.subset"/&gt;
-&lt;xsl:param name="subset.profile"/&gt;
-&lt;xsl:param name="uri"/&gt;
-  ...
-&lt;/xsl:template&gt;</synopsis>
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-    
-<para>The XSLT 2.0 specification describes <link xlink:href="http://www.w3.org/TR/xslt20/#character-maps">character maps</link> and explains how they may be used
-      to allow a specific character appearing in a text or
-      attribute node in a final result tree to be substituted by
-      a specified string of characters during serialization. The
-      <function>read-character-map</function> template provides a
-      means for reading and using character maps with XSLT
-      1.0-based tools.</para>
-
-    
-<para>This template reads the character-map contents from
-      <parameter>uri</parameter> (in full or in part, depending on
-      the value of the <parameter>use.subset</parameter>
-      parameter), then passes those contents to the
-      <function>apply-character-map</function> template, along with
-      <parameter>content</parameter>, the data on which to perform
-      the character substitution.</para>
-
-    
-<para>Using the character map &#8220;in part&#8221; means that it uses only
-      those <tag>output-character</tag> elements that match the
-      XPath expression given in the value of the
-      <parameter>subset.profile</parameter> parameter. The current
-      implementation of that capability here relies on the
-      <function>evaluate</function> extension XSLT function.</para>
-
-  </refsect1><refsect1><title>Parameters</title>
-    
-<variablelist>
-      <varlistentry><term>use.subset</term>
-        <listitem>
-          
-<para>Specifies whether to use a subset of the character
-            map instead of the whole map; boolean
-            <literal>0</literal> or <literal>1</literal></para>
-
-        </listitem>
-      </varlistentry>
-      <varlistentry><term>subset.profile</term>
-        <listitem>
-          
-<para>XPath expression that specifies what subset of the
-            character map to use</para>
-
-        </listitem>
-      </varlistentry>
-      <varlistentry><term>uri</term>
-        <listitem>
-          
-<para>URI for a character map</para>
-
-        </listitem>
-      </varlistentry>
-    </variablelist>
-
-  </refsect1></refentry>
-</reference>
-    </part>
-    <part id="table-templates">
-      <?dbhtml dir="fo"?>
-  
-  <info xml:base="../fo/table.xml">
-    <title>Formatting Object Table Reference</title>
-    <releaseinfo role="meta">
-      $Id: table.xsl 9666 2012-11-14 04:42:56Z bobstayton $
-    </releaseinfo>
-  </info>
-  <partintro id="partintro" xml:base="../fo/table.xml">
-    <title>Introduction</title>
-    
-<para>This is technical reference documentation for the FO
-      table-processing templates in the DocBook XSL Stylesheets.</para>
-
-    
-<para>This is not intended to be user documentation.  It is
-      provided for developers writing customization layers for the
-      stylesheets.</para>
-
-  </partintro>
-
-<refentry id="template.calc.column.width" xml:base="../fo/table.xml">
-<refnamediv>
-<refname>calc.column.width</refname>
-<refpurpose>Calculate an XSL FO table column width specification from a
-CALS table column width specification.</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-<synopsis>&lt;xsl:template name="calc.column.width"&gt;
-&lt;xsl:param name="colwidth"&gt;1*&lt;/xsl:param&gt;
-  ...
-&lt;/xsl:template&gt;</synopsis>
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-
-<para>CALS expresses table column widths in the following basic
-forms:</para>
-
-
-
-<itemizedlist>
-<listitem>
-
-<para><emphasis>99.99units</emphasis>, a fixed length specifier.</para>
-
-</listitem>
-<listitem>
-
-<para><emphasis>99.99</emphasis>, a fixed length specifier without any units.</para>
-
-</listitem>
-<listitem>
-
-<para><emphasis>99.99*</emphasis>, a relative length specifier.</para>
-
-</listitem>
-<listitem>
-
-<para><emphasis>99.99*+99.99units</emphasis>, a combination of both.</para>
-
-</listitem>
-</itemizedlist>
-
-
-
-<para>The CALS units are points (pt), picas (pi), centimeters (cm),
-millimeters (mm), and inches (in). These are the same units as XSL,
-except that XSL abbreviates picas "pc" instead of "pi". If a length
-specifier has no units, the CALS default unit (pt) is assumed.</para>
-
-
-
-<para>Relative length specifiers are represented in XSL with the
-proportional-column-width() function.</para>
-
-
-
-<para>Here are some examples:</para>
-
-
-
-<itemizedlist>
-<listitem>
-
-<para>"36pt" becomes "36pt"</para>
-
-</listitem>
-<listitem>
-
-<para>"3pi" becomes "3pc"</para>
-
-</listitem>
-<listitem>
-
-<para>"36" becomes "36pt"</para>
-
-</listitem>
-<listitem>
-
-<para>"3*" becomes "proportional-column-width(3)"</para>
-
-</listitem>
-<listitem>
-
-<para>"3*+2pi" becomes "proportional-column-width(3)+2pc"</para>
-
-</listitem>
-<listitem>
-
-<para>"1*+2" becomes "proportional-column-width(1)+2pt"</para>
-
-</listitem>
-</itemizedlist>
-
-</refsect1><refsect1><title>Parameters</title>
-
-<variablelist>
-<varlistentry><term>colwidth</term>
-<listitem>
-
-<para>The CALS column width specification.</para>
-
-</listitem>
-</varlistentry>
-</variablelist>
-
-</refsect1><refsect1><title>Returns</title>
-
-<para>The XSL column width specification.</para>
-
-</refsect1></refentry>
-
-    </part>
-    <part id="template"> 
-      <?dbhtml dir="template"?><?dbhtml filename="index.html"?>
-  
-  
-  <info xml:base="../template/titlepage.xml">
-    <title>Titlepage Template Stylesheet Reference</title>
-    <releaseinfo role="meta">
-      $Id: titlepage.xsl 9600 2012-09-11 12:12:09Z kosek $
-    </releaseinfo>
-  </info>
-  <partintro id="intro_partintro" xml:base="../template/titlepage.xml">
-    <title>Introduction</title>
-    
-<para>This is technical reference documentation for the
-      &#8220;titlepage&#8221; templates in the DocBook XSL Stylesheets.</para>
-
-    
-<para>This is not intended to be user documentation.  It is
-      provided for developers writing customization layers for the
-      stylesheets.</para>
-
-  </partintro>
-
-<refentry id="templates" xml:base="../template/titlepage.xml">
-<refnamediv>
-<refname>t:templates</refname>
-<refpurpose>Construct a stylesheet for the templates provided</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-<synopsis>&lt;xsl:template match="t:templates"/&gt;</synopsis>
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-
-<para>The <literal>t:templates</literal> element is the root of a
-set of templates. This template creates an appropriate
-<literal>xsl:stylesheet</literal> for the templates.</para>
-
-
-
-<para>If the <literal>t:templates</literal> element has a
-<literal>base-stylesheet</literal> attribute, an
-<literal>xsl:import</literal> statement is constructed for it.</para>
-
-</refsect1></refentry>
-
-<refentry id="star" xml:base="../template/titlepage.xml">
-<refnamediv>
-<refname>xsl:*</refname>
-<refpurpose>Copy xsl: elements straight through</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-<synopsis>&lt;xsl:template match="xsl:*"/&gt;</synopsis>
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-
-<para>This template simply copies the xsl: elements
-straight through into the result tree.</para>
-
-</refsect1></refentry>
-
-<refentry id="titlepage" xml:base="../template/titlepage.xml">
-<refnamediv>
-<refname>t:titlepage</refname>
-<refpurpose>Create the templates necessary to construct a title page</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-<synopsis>&lt;xsl:template match="t:titlepage"/&gt;</synopsis>
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-
-<para>The <literal>t:titlepage</literal> element creates a set of
-templates for processing the titlepage for an element. The
-<quote>root</quote> of this template set is the template named
-<quote><literal>wrapper.titlepage</literal></quote>. That is the
-template that should be called to generate the title page.
-</para>
-
-
-
-<para>The <literal>t:titlepage</literal> element has three attributes:
-
-
-<variablelist>
-<varlistentry><term>element</term>
-<listitem>
-<para>The name of the source document element for which
-these templates apply. In other words, to make a title page for the
-<tag>article</tag> element, set the
-<tag class="attribute">element</tag> attribute to
-<quote><literal>article</literal></quote>. This attribute is required.
-</para>
-</listitem>
-</varlistentry>
-<varlistentry><term>wrapper</term>
-<listitem>
-<para>The entire title page can be wrapped with an element.
-This attribute identifies that element.
-</para>
-</listitem>
-</varlistentry>
-<varlistentry><term>class</term>
-<listitem>
-<para>If the <tag class="attribute">class</tag> attribute
-is set, a <tag class="attribute">class</tag> attribute with this
-value will be added to the wrapper element that surrounds the entire
-title page.
-</para>
-</listitem>
-</varlistentry>
-</variablelist>
-
-</para>
-
-
-
-<para>Any other attributes are copied through literally to the
-wrapper element.</para>
-
-
-
-<para>The content of a <literal>t:titlepage</literal> is one or
-more <literal>t:titlepage-content</literal>,
-<literal>t:titlepage-separator</literal>, and
-<literal>t:titlepage-before</literal> elements.</para>
-
-
-
-<para>Each of these elements may be provided for the <quote>recto</quote>
-and <quote>verso</quote> sides of the title page.</para>
-
-
-</refsect1></refentry>
-
-<refentry id="attr_star_in_copy.literal.atts" xml:base="../template/titlepage.xml">
-<refnamediv>
-<refname>@* (in copy.literal.atts mode)</refname>
-<refpurpose>Copy t:titlepage attributes</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-<synopsis>&lt;xsl:template match="@*" mode="copy.literal.atts"/&gt;</synopsis>
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-
-<para>This template copies all of the <quote>other</quote> attributes
-from a <literal>t:titlepage</literal> element onto the specified
-wrapper.</para>
-
-</refsect1></refentry>
-
-<refentry id="titlepage-content" xml:base="../template/titlepage.xml">
-<refnamediv>
-<refname>t:titlepage-content</refname>
-<refpurpose>Create templates for the content of one side of a title page</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-<synopsis>&lt;xsl:template match="t:titlepage-content"/&gt;</synopsis>
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-
-<para>The title page content, that is, the elements from the source
-document that are rendered on the title page, can be controlled independently
-for the recto and verso sides of the title page.</para>
-
-
-
-<para>The <literal>t:titlepage-content</literal> element has two attributes:
-
-
-<variablelist>
-<varlistentry><term>side</term>
-<listitem>
-<para>Identifies the side of the page to which this title
-page content applies. The
-<tag class="attribute">side</tag> attribute is required and
-must be set to either 
-<quote><literal>recto</literal></quote> or
-<quote><literal>verso</literal></quote>. In addition, you must specify
-exactly one <literal>t:titlepage-content</literal> for each side
-within each <literal>t:titlepage</literal>.</para>
-
-</listitem>
-</varlistentry>
-<varlistentry><term>order</term>
-<listitem>
-<para>Indicates how the order of the elements presented on
-the title page is determined. If the
-<tag class="attribute">order</tag> is
-<quote><literal>document</literal></quote>, the elements are presented
-in document order. Otherwise (if the
-<tag class="attribute">order</tag> is
-<quote><literal>stylesheet</literal></quote>), the elements are presented
-in the order that they appear in the template (and consequently in
-the stylesheet).</para>
-
-</listitem>
-</varlistentry>
-</variablelist>
-
-</para>
-
-
-
-<para>The content of a <literal>t:titlepage-content</literal> element is
-a list of element names. These names should be unqualified.  They identify
-the elements in the source document that should appear on the title page.
-</para>
-
-
-
-<para>Each element may have a single attribute:
-<tag class="attribute">predicate</tag>. The value of this
-attribute is used as a predicate for the expression that matches
-the element on which it occurs.</para>
-
-
-
-<para>In other words, to put only the first three authors on the
-recto-side of a title
-page, you could specify:
-
-<screen>
-  &lt;t:titlepage-contents side="recto"&gt;
-    &lt;!-- other titlepage elements --&gt;
-    &lt;author predicate="[count(previous-sibling::author)&lt;2]"/&gt;
-    &lt;!-- other titlepage elements --&gt;
-  &lt;/t:titlepage-contents&gt;
-</screen>
-</para>
-
-
-
-<para>Usually, the elements so named are empty. But it is possible to
-make one level of selection within them. Suppose that you want to
-process <literal>authorgroup</literal> elements on the title page, but
-you want to select only proper authors, editors, or corporate authors,
-not collaborators or other credited authors.</para>
-
-
-
-<para>In that case, you can put a <literal>t:or</literal> group inside
-the <literal>authorgroup</literal> element:
-
-<screen>
-  &lt;t:titlepage-contents side="recto"&gt;
-    &lt;!-- other titlepage elements --&gt;
-    &lt;authorgroup&gt;
-      &lt;t:or&gt;
-        &lt;author/&gt;
-        &lt;editor/&gt;
-        &lt;corpauthor/&gt;
-      &lt;/t:or&gt;
-    &lt;/authorgroup&gt;
-    &lt;!-- other titlepage elements --&gt;
-  &lt;/t:titlepage-contents&gt;
-</screen>
-</para>
-
-
-
-<para>This will have the effect of automatically generating a template
-for processing <literal>authorgroup</literal>s in the title page mode,
-selecting only the specified children. If you need more complex processing,
-you'll have to construct the templates by hand.</para>
-
-
-</refsect1></refentry>
-
-<refentry id="titlepage-separator" xml:base="../template/titlepage.xml">
-<refnamediv>
-<refname>t:titlepage-separator</refname>
-<refpurpose>Create templates for the separator</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-<synopsis>&lt;xsl:template match="t:titlepage-separator"/&gt;</synopsis>
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-
-<para>The title page is separated from the content which follows it by
-the markup specified in the <literal>t:titlepage-separator</literal>
-element.</para>
-
-</refsect1></refentry>
-
-<refentry id="titlepage-before" xml:base="../template/titlepage.xml">
-<refnamediv>
-<refname>t:titlepage-before</refname>
-<refpurpose>Create templates for what precedes a title page</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-<synopsis>&lt;xsl:template match="t:titlepage-before"/&gt;</synopsis>
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-
-<para>Each side of the title page is preceded by the markup specified
-in the <literal>t:titlepage-before</literal> element for that
-side.</para>
-
-</refsect1></refentry>
-
-<refentry id="star_in_copy" xml:base="../template/titlepage.xml">
-<refnamediv>
-<refname>* (in copy mode)</refname>
-<refpurpose>Copy elements</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-<synopsis>&lt;xsl:template match="*" mode="copy"/&gt;</synopsis>
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-
-<para>This template simply copies the elements that it applies to
-straight through into the result tree.</para>
-
-</refsect1></refentry>
-
-<refentry id="attr_star_in_copy" xml:base="../template/titlepage.xml">
-<refnamediv>
-<refname>@* (in copy mode)</refname>
-<refpurpose>Copy attributes</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-<synopsis>&lt;xsl:template match="@*" mode="copy"/&gt;</synopsis>
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-
-<para>This template simply copies the attributes that it applies to
-straight through into the result tree.</para>
-
-</refsect1></refentry>
-
-<refentry id="attr_star_in_document.order" xml:base="../template/titlepage.xml">
-<refnamediv>
-<refname>* (in document.order mode)</refname>
-<refpurpose>Create rules to process titlepage elements in document order</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-<synopsis>&lt;xsl:template match="*" mode="document.order"/&gt;</synopsis>
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-
-<para>This template is called to process all of the children of the
-<literal>t:titlepage-content</literal> element. It creates the hairy
-select expression necessary to process each of those elements in
-the title page.</para>
-
-
-
-<para>Note that this template automatically handles the case where
-some DocBook elements, like title and subtitle, can occur both inside
-the *info elements where metadata is usually stored and outside.
-</para>
-
-
-
-<para>It also automatically calculates the name for the *info container
-and handles elements that have historically had containers with different
-names.</para>
-
-
-</refsect1></refentry>
-
-<refentry id="star_in_document.order" xml:base="../template/titlepage.xml">
-<refnamediv>
-<refname>* (in document.order mode)</refname>
-<refpurpose>Create rules to process titlepage elements in stylesheet order</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-<synopsis>&lt;xsl:template match="*" mode="document.order"/&gt;</synopsis>
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-
-<para>This template is called to process all of the children of the
-<literal>t:titlepage-content</literal> element. It creates the set
-of <literal>xsl:apply-templates</literal> elements necessary
-process each of those elements in the title page.</para>
-
-
-
-<para>Note that this template automatically handles the case where
-some DocBook elements, like title and subtitle, can occur both inside
-the *info elements where metadata is usually stored and outside.
-</para>
-
-
-
-<para>It also automatically calculates the name for the *info container
-and handles elements that have historically had containers with different
-names.</para>
-
-
-</refsect1></refentry>
-
-<refentry id="star_in_titlepage.specialrules" xml:base="../template/titlepage.xml">
-<refnamediv>
-<refname>* (in titlepage.specialrules mode)</refname>
-<refpurpose>Create templates for special rules</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-<synopsis>&lt;xsl:template match="*" mode="titlepage.specialrules"/&gt;</synopsis>
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-
-<para>This template is called to process all of the descendants of the
-<literal>t:titlepage-content</literal> element that require special
-processing. At present, that's just <literal>t:or</literal> elements.
-</para>
-
-</refsect1></refentry>
-
-<refentry id="star_in_titlepage.subrules" xml:base="../template/titlepage.xml">
-<refnamediv>
-<refname>* (in titlepage.subrules mode)</refname>
-<refpurpose>Create template for individual special rules</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-<synopsis>&lt;xsl:template match="*" mode="titlepage.subrules"/&gt;</synopsis>
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-
-<para>This template is called to process the children of special
-template elements.
-</para>
-
-</refsect1></refentry>
-
-<refentry id="or" xml:base="../template/titlepage.xml">
-<refnamediv>
-<refname>t:or</refname>
-<refpurpose>Process the t:or special rule</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-<synopsis>&lt;xsl:template match="t:or"/&gt;&lt;xsl:template match="t:or" mode="titlepage.subrules"/&gt;</synopsis>
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-
-<para>This template processes t:or.</para>
-
-</refsect1></refentry>
-
-<refentry id="or_in_titlepage.subrules" xml:base="../template/titlepage.xml">
-<refnamediv>
-<refname>t:or (in titlepage.subrules mode)</refname>
-<refpurpose>Process the t:or special rule in
-titlepage.subrules mode</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-<synopsis>&lt;xsl:template match="t:or" mode="titlepage.subrules"/&gt;</synopsis>
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-
-<para>The titlepage.subrules mode doesn't apply to t:or, so just
-reprocess this node in the normal mode.</para>
-
-</refsect1></refentry>
-
-<refentry id="template.element-or-list" xml:base="../template/titlepage.xml">
-<refnamediv>
-<refname>element-or-list</refname>
-<refpurpose>Construct the "or-list" used in the select attribute for
-special rules.</refpurpose>
-</refnamediv>
-<refsynopsisdiv>
-<synopsis>&lt;xsl:template name="element-or-list"&gt;
-&lt;xsl:param name="elements" select="*"/&gt;
-&lt;xsl:param name="element.count" select="count($elements)"/&gt;
-&lt;xsl:param name="count" select="1"/&gt;
-&lt;xsl:param name="orlist"/&gt;
-  ...
-&lt;/xsl:template&gt;</synopsis>
-</refsynopsisdiv>
-<refsect1><title>Description</title>
-
-<para>Walk through each of the children of t:or, producing the
-text of the select attribute.</para>
-
-</refsect1></refentry>
-
-    </part>
-  </book>
-</set><!-- * vim: set ft=docbk foldlevel=2: -->

+ 0 - 11
stylesheets/lfs-xsl/docbook-xsl-1.78.1/docsrc/warranty.xml

@@ -1,11 +0,0 @@
-<legalnotice xmlns="http://docbook.org/ns/docbook" version="5.0"
-  xml:id="warranty"><title>Warranty</title>
-<para>THE SOFTWARE IS PROVIDED <quote>AS IS</quote>,
-WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT
-LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR
-PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL NORMAN WALSH OR ANY
-OTHER CONTRIBUTOR BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
-WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT
-OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
-THE SOFTWARE.</para>
-</legalnotice>

+ 0 - 306
stylesheets/lfs-xsl/docbook-xsl-1.78.1/eclipse/eclipse.xsl

@@ -1,306 +0,0 @@
-<?xml version="1.0"?>
-<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
-  xmlns:ng="http://docbook.org/docbook-ng"
-  xmlns:db="http://docbook.org/ns/docbook"
-  xmlns:exsl="http://exslt.org/common"
-  version="1.0"
-  exclude-result-prefixes="exsl db ng">
-  
-<xsl:import href="../html/chunk.xsl"/>
-
-<!-- ********************************************************************
-     $Id: eclipse.xsl 9149 2011-11-12 00:12:07Z bobstayton $
-     ********************************************************************
-
-     This file is part of the XSL DocBook Stylesheet distribution.
-     See ../README or http://docbook.sf.net/release/xsl/current/ for
-     copyright and other information.
-
-     ******************************************************************** -->
-
-<xsl:template match="/">
-  <!-- * Get a title for current doc so that we let the user -->
-  <!-- * know what document we are processing at this point. -->
-  <xsl:variable name="doc.title">
-    <xsl:call-template name="get.doc.title"/>
-  </xsl:variable>
-  <xsl:choose>
-    <!-- Hack! If someone hands us a DocBook V5.x or DocBook NG document,
-         toss the namespace and continue.  Use the docbook5 namespaced
-         stylesheets for DocBook5 if you don't want to use this feature.-->
-    <!-- include extra test for Xalan quirk -->
-    <xsl:when test="$exsl.node.set.available != 0
-                    and (*/self::ng:* or */self::db:*)">
-      <xsl:call-template name="log.message">
-        <xsl:with-param name="level">Note</xsl:with-param>
-        <xsl:with-param name="source" select="$doc.title"/>
-        <xsl:with-param name="context-desc">
-          <xsl:text>namesp. cut</xsl:text>
-        </xsl:with-param>
-        <xsl:with-param name="message">
-          <xsl:text>stripped namespace before processing</xsl:text>
-        </xsl:with-param>
-      </xsl:call-template>
-      <xsl:variable name="nons">
-        <xsl:apply-templates mode="stripNS"/>
-      </xsl:variable>
-      <xsl:call-template name="log.message">
-        <xsl:with-param name="level">Note</xsl:with-param>
-        <xsl:with-param name="source" select="$doc.title"/>
-        <xsl:with-param name="context-desc">
-          <xsl:text>namesp. cut</xsl:text>
-        </xsl:with-param>
-        <xsl:with-param name="message">
-          <xsl:text>processing stripped document</xsl:text>
-        </xsl:with-param>
-      </xsl:call-template>
-      <xsl:apply-templates select="exsl:node-set($nons)"/>
-    </xsl:when>
-    <xsl:otherwise>
-  <xsl:choose>
-    <xsl:when test="$rootid != ''">
-      <xsl:choose>
-        <xsl:when test="count(key('id',$rootid)) = 0">
-          <xsl:message terminate="yes">
-            <xsl:text>ID '</xsl:text>
-            <xsl:value-of select="$rootid"/>
-            <xsl:text>' not found in document.</xsl:text>
-          </xsl:message>
-        </xsl:when>
-        <xsl:otherwise>
-          <xsl:if test="$collect.xref.targets = 'yes' or
-                        $collect.xref.targets = 'only'">
-            <xsl:apply-templates select="key('id', $rootid)"
-                        mode="collect.targets"/>
-          </xsl:if>
-          <xsl:if test="$collect.xref.targets != 'only'">
-            <xsl:message>Formatting from <xsl:value-of 
-	                          select="$rootid"/></xsl:message>
-            <xsl:apply-templates select="key('id',$rootid)"
-                        mode="process.root"/>
-            <xsl:call-template name="etoc"/>
-            <xsl:call-template name="plugin.xml"/>
-				<xsl:call-template name="helpidx"/>
-          </xsl:if>
-        </xsl:otherwise>
-      </xsl:choose>
-    </xsl:when>
-    <xsl:otherwise>
-      <xsl:if test="$collect.xref.targets = 'yes' or
-                    $collect.xref.targets = 'only'">
-        <xsl:apply-templates select="/" mode="collect.targets"/>
-      </xsl:if>
-      <xsl:if test="$collect.xref.targets != 'only'">
-        <xsl:apply-templates select="/" mode="process.root"/>
-        <xsl:call-template name="etoc"/>
-        <xsl:call-template name="plugin.xml"/>
-		  <xsl:call-template name="helpidx"/>
-      </xsl:if>
-    </xsl:otherwise>
-  </xsl:choose>
-</xsl:otherwise>
-</xsl:choose>
-</xsl:template>
-
-<xsl:template name="etoc">
-  <xsl:call-template name="write.chunk">
-    <xsl:with-param name="filename">
-      <xsl:if test="$manifest.in.base.dir != 0">
-        <xsl:value-of select="$chunk.base.dir"/>
-      </xsl:if>
-      <xsl:value-of select="'toc.xml'"/>
-    </xsl:with-param>
-    <xsl:with-param name="method" select="'xml'"/>
-    <xsl:with-param name="encoding" select="'utf-8'"/>
-    <xsl:with-param name="indent" select="'yes'"/>
-    <xsl:with-param name="quiet" select="$chunk.quietly"/>
-    <xsl:with-param name="content">
-      <xsl:choose>
-
-        <xsl:when test="$rootid != ''">
-          <xsl:variable name="title">
-            <xsl:if test="$eclipse.autolabel=1">
-              <xsl:variable name="label.markup">
-                <xsl:apply-templates select="key('id',$rootid)" mode="label.markup"/>
-              </xsl:variable>
-              <xsl:if test="normalize-space($label.markup)">
-                <xsl:value-of select="concat($label.markup,$autotoc.label.separator)"/>
-              </xsl:if>
-            </xsl:if>
-            <xsl:apply-templates select="key('id',$rootid)" mode="title.markup"/>
-          </xsl:variable>
-          <xsl:variable name="href">
-            <xsl:call-template name="href.target.with.base.dir">
-              <xsl:with-param name="object" select="key('id',$rootid)"/>
-            </xsl:call-template>
-          </xsl:variable>
-          
-          <toc label="{normalize-space($title)}" topic="{$href}">
-            <xsl:apply-templates select="key('id',$rootid)/*" mode="etoc"/>
-          </toc>
-        </xsl:when>
-
-        <xsl:otherwise>
-          <xsl:variable name="title">
-            <xsl:if test="$eclipse.autolabel=1">
-              <xsl:variable name="label.markup">
-                <xsl:apply-templates select="/*" mode="label.markup"/>
-              </xsl:variable>
-              <xsl:if test="normalize-space($label.markup)">
-                <xsl:value-of select="concat($label.markup,$autotoc.label.separator)"/>
-              </xsl:if>
-            </xsl:if>
-            <xsl:apply-templates select="/*" mode="title.markup"/>
-          </xsl:variable>
-          <xsl:variable name="href">
-            <xsl:call-template name="href.target.with.base.dir">
-              <xsl:with-param name="object" select="/"/>
-            </xsl:call-template>
-          </xsl:variable>
-          
-          <toc label="{normalize-space($title)}" topic="{$href}">
-            <xsl:apply-templates select="/*/*" mode="etoc"/>
-          </toc>
-        </xsl:otherwise>
-
-      </xsl:choose>
-    </xsl:with-param>
-  </xsl:call-template>
-</xsl:template>
-
-<xsl:template match="book|part|reference|preface|chapter|bibliography|appendix|article|glossary|section|sect1|sect2|sect3|sect4|sect5|refentry|colophon|bibliodiv|index" mode="etoc">
-  <xsl:variable name="title">
-    <xsl:if test="$eclipse.autolabel=1">
-      <xsl:variable name="label.markup">
-        <xsl:apply-templates select="." mode="label.markup"/>
-      </xsl:variable>
-      <xsl:if test="normalize-space($label.markup)">
-        <xsl:value-of select="concat($label.markup,$autotoc.label.separator)"/>
-      </xsl:if>
-    </xsl:if>
-    <xsl:apply-templates select="." mode="title.markup"/>
-  </xsl:variable>
-
-  <xsl:variable name="href">
-    <xsl:call-template name="href.target.with.base.dir">
-      <xsl:with-param name="context" select="/"/>        <!-- Generate links relative to the location of root file/toc.xml file -->
-    </xsl:call-template>
-  </xsl:variable>
-
-  <topic label="{normalize-space($title)}" href="{$href}">
-    <xsl:apply-templates select="part|reference|preface|chapter|bibliography|appendix|article|glossary|section|sect1|sect2|sect3|sect4|sect5|refentry|colophon|bibliodiv|index" mode="etoc"/>
-  </topic>
-
-</xsl:template>
-
-<xsl:template match="text()" mode="etoc"/>
-
-<xsl:template name="plugin.xml">
-  <xsl:call-template name="write.chunk">
-    <xsl:with-param name="filename">
-      <xsl:if test="$manifest.in.base.dir != 0">
-        <xsl:value-of select="$chunk.base.dir"/>
-      </xsl:if>
-      <xsl:value-of select="'plugin.xml'"/>
-    </xsl:with-param>
-    <xsl:with-param name="method" select="'xml'"/>
-    <xsl:with-param name="encoding" select="'utf-8'"/>
-    <xsl:with-param name="indent" select="'yes'"/>
-    <xsl:with-param name="quiet" select="$chunk.quietly"/>
-    <xsl:with-param name="content">
-      <plugin name="{$eclipse.plugin.name}"
-        id="{$eclipse.plugin.id}"
-        version="1.0"
-        provider-name="{$eclipse.plugin.provider}">
-
-		  <extension point="org.eclipse.help.toc">
-			<toc file="toc.xml" primary="true"/>
-		  </extension>
-		  <extension point="org.eclipse.help.index">
-			<index file="index.xml"/>
-		  </extension>
-      </plugin>
-    </xsl:with-param>
-  </xsl:call-template>
-</xsl:template>
-
-<!-- ==================================================================== -->
-<!-- The following templates come from the javahelp xsls with modifications needed to make them generate and ecilpse index.xml file -->
-
-<xsl:template name="helpidx">
-  <xsl:call-template name="write.chunk.with.doctype">
-    <xsl:with-param name="filename" select="concat($chunk.base.dir, 'index.xml')"/>
-    <xsl:with-param name="method" select="'xml'"/>
-    <xsl:with-param name="indent" select="'yes'"/>
-    <xsl:with-param name="doctype-public" select="''"/>
-    <xsl:with-param name="doctype-system" select="''"/>
-    <xsl:with-param name="encoding" select="'utf-8'"/>
-    <xsl:with-param name="quiet" select="$chunk.quietly"/>
-    <xsl:with-param name="content">
-      <xsl:call-template name="helpidx.content"/>
-    </xsl:with-param>
-  </xsl:call-template>
-</xsl:template>
-
-  <xsl:template name="helpidx.content">
-	<index>
-	  <xsl:choose>
-		<xsl:when test="$rootid != ''">
-		  <xsl:apply-templates select="key('id',$rootid)//indexterm" mode="idx">
-			<xsl:sort select="normalize-space(concat(primary/@sortas, primary[not(@sortas) or @sortas = '']))"/>
-			<xsl:sort select="normalize-space(concat(secondary/@sortas, secondary[not(@sortas) or @sortas = '']))"/>
-			<xsl:sort select="normalize-space(concat(tertiary/@sortas, tertiary[not(@sortas) or @sortas = '']))"/>
-		  </xsl:apply-templates>
-		</xsl:when>
-		<xsl:otherwise>
-		  <xsl:apply-templates select="//indexterm" mode="idx">
-			<xsl:sort select="normalize-space(concat(primary/@sortas, primary[not(@sortas) or @sortas = '']))"/>
-			<xsl:sort select="normalize-space(concat(secondary/@sortas, secondary[not(@sortas) or @sortas = '']))"/>
-			<xsl:sort select="normalize-space(concat(tertiary/@sortas, tertiary[not(@sortas) or @sortas = '']))"/>
-		  </xsl:apply-templates>
-		</xsl:otherwise>
-	  </xsl:choose>
-	</index>
-  </xsl:template>
-  
-  <xsl:template match="indexterm[@class='endofrange']" mode="idx"/>
-  
-  <xsl:template match="indexterm|primary|secondary|tertiary" mode="idx">
-
-	<xsl:variable name="href">
-	  <xsl:call-template name="href.target.with.base.dir">
-		<xsl:with-param name="context" select="/"/>        <!-- Generate links relative to the location of root file/toc.xml file -->
-	  </xsl:call-template>
-	</xsl:variable>
-
-	<xsl:variable name="text">
-	  <xsl:value-of select="normalize-space(.)"/>
-	  <xsl:if test="following-sibling::*[1][self::see]">
-		<xsl:text> (</xsl:text><xsl:call-template name="gentext">
-		  <xsl:with-param name="key" select="'see'"/>
-		</xsl:call-template><xsl:text> </xsl:text>
-		<xsl:value-of select="following-sibling::*[1][self::see]"/>)</xsl:if>
-	</xsl:variable>
-	
-	<xsl:choose>
-	  <xsl:when test="self::indexterm">
-		<xsl:apply-templates select="primary" mode="idx"/>
-	  </xsl:when>
-	  <xsl:when test="self::primary">
-		<entry keyword="{$text}">
-		  <topic href="{$href}"/>
-		  <xsl:apply-templates select="following-sibling::secondary"  mode="idx"/>
-		</entry>
-	  </xsl:when>
-	  <xsl:otherwise>
-		<entry keyword="{$text}">
-		  <topic href="{$href}"/>
-		  <xsl:apply-templates select="following-sibling::tertiary"  mode="idx"/>
-		</entry>
-	  </xsl:otherwise>
-	</xsl:choose>
-  </xsl:template>
-
-  <!-- ==================================================================== -->
-
-</xsl:stylesheet>

+ 0 - 111
stylesheets/lfs-xsl/docbook-xsl-1.78.1/eclipse/eclipse3.xsl

@@ -1,111 +0,0 @@
-<?xml version="1.0"?>
-<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
-		xmlns:ng="http://docbook.org/docbook-ng" 
-		xmlns:db="http://docbook.org/ns/docbook"
-		xmlns:exsl="http://exslt.org/common" version="1.0"
-		exclude-result-prefixes="exsl db ng">
-
-<!-- 
-********************************************************************************
-     $Id: eclipse3.xsl 9149 2011-11-12 00:12:07Z bobstayton $
-
-     This file is part of the XSL DocBook Stylesheet distribution.
-     See ../README or http://docbook.sf.net/release/xsl/current/ for
-     copyright and other information.
-
- * Copyright (c) 2008 Standards for Technology in Automotive Retail and others.
- * All rights reserved. This program and the accompanying materials
- * are made available under the terms of the Eclipse Public License v1.0
- * which accompanies this distribution, and is available at
- * http://www.eclipse.org/legal/epl-v10.html
- *
- * Contributors:
- *     David Carver - STAR - Extended existing eclipse.xsl file to produce valid
- *                           eclipse 3.3 plugin.xml with a manifest file.
- *******************************************************************************
- -->
-  
-  <xsl:import href="eclipse.xsl"/>
-
-  <xsl:param name="eclipse.manifest">1</xsl:param>
-  <xsl:param name="create.plugin.xml">1</xsl:param>
-  
-  <xsl:template name="plugin.xml">
-    <xsl:if test="$create.plugin.xml != 0">
-      <xsl:call-template name="write.chunk">
-	<xsl:with-param name="filename">
-	  <xsl:if test="$manifest.in.base.dir != 0">
-	    <xsl:value-of select="$chunk.base.dir" />
-	  </xsl:if>
-	  <xsl:value-of select="'plugin.xml'" />
-	</xsl:with-param>
-	<xsl:with-param name="method" select="'xml'" />
-	<xsl:with-param name="encoding" select="'utf-8'" />
-	<xsl:with-param name="indent" select="'yes'" />
-	<xsl:with-param name="quiet" select="$chunk.quietly"/>
-	<xsl:with-param name="content">
-	  <xsl:choose>
-	    
-	    <xsl:when test="$eclipse.manifest = '1'">
-	      <plugin>
-		<extension point="org.eclipse.help.toc">
-		  <toc file="toc.xml" primary="true" />
-		</extension>
-		<xsl:if test="$generate.index = 1">
-		  <extension point="org.eclipse.help.index">
-		    <index file="index.xml"/>
-		 </extension>
-		</xsl:if>
-	      </plugin>
-	      <xsl:call-template name="write.chunk">
-		<xsl:with-param name="filename">
-		  <xsl:if test="$manifest.in.base.dir != 0">
-		    <xsl:value-of select="$chunk.base.dir" />
-		  </xsl:if>
-		  <xsl:value-of select="'META-INF/'" />
-		  <xsl:value-of select="'MANIFEST.MF'" />
-		</xsl:with-param>
-		<xsl:with-param name="method" select="'text'" />
-		<xsl:with-param name="encoding" select="'utf-8'" />
-		<xsl:with-param name="quiet" select="$chunk.quietly"/>
-		<xsl:with-param name="content">
-		  <xsl:call-template name="manifest.content"/>
-		</xsl:with-param>
-	      </xsl:call-template>
-	    </xsl:when>
-
-	    <xsl:otherwise>
-	      <plugin name="{$eclipse.plugin.name}" id="{$eclipse.plugin.id}"
-		      version="1.0" provider-name="{$eclipse.plugin.provider}">
-		<extension point="org.eclipse.help.toc">
-		  <toc file="toc.xml" primary="true" />
-		</extension>
-		<xsl:if test="$generate.index = 1">
-		  <extension point="org.eclipse.help.index">
-		  <index file="index.xml"/>
-		  </extension>
-		</xsl:if>
-	      </plugin>
-	    </xsl:otherwise>
-
-	  </xsl:choose>
-	</xsl:with-param>
-      </xsl:call-template>	    
-    </xsl:if>
-  </xsl:template>
-
-  <xsl:template name="manifest.content">
-    <xsl:text>Manifest-Version: 1.0</xsl:text>
-    <xsl:text>&#xA;</xsl:text>
-    <xsl:text>Bundle-Version: 1.0</xsl:text>
-    <xsl:text>&#xA;</xsl:text>
-    <xsl:text>Bundle-Name: </xsl:text><xsl:value-of select="$eclipse.plugin.name"/>
-    <xsl:text>&#xA;</xsl:text>
-    <xsl:text>Bundle-SymbolicName: </xsl:text><xsl:value-of select="$eclipse.plugin.id"/>
-    <xsl:text>&#xA;</xsl:text>
-    <xsl:text>Bundle-Vendor: </xsl:text><xsl:value-of select="$eclipse.plugin.provider"/>
-    <xsl:text>&#xA;</xsl:text>
-  </xsl:template>
-
-</xsl:stylesheet>
- 	  	 

+ 0 - 269
stylesheets/lfs-xsl/docbook-xsl-1.78.1/eclipse/profile-eclipse.xsl

@@ -1,269 +0,0 @@
-<?xml version="1.0" encoding="US-ASCII"?>
-<!--This file was created automatically by xsl2profile-->
-<!--from the DocBook XSL stylesheets.-->
-<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" xmlns:ng="http://docbook.org/docbook-ng" xmlns:db="http://docbook.org/ns/docbook" xmlns:exsl="http://exslt.org/common" xmlns:exslt="http://exslt.org/common" exslt:dummy="dummy" ng:dummy="dummy" db:dummy="dummy" extension-element-prefixes="exslt" version="1.0" exclude-result-prefixes="exsl db ng exslt">
-  
-<xsl:import href="../html/chunk.xsl"/>
-
-<!-- ********************************************************************
-     $Id: eclipse.xsl 9149 2011-11-12 00:12:07Z bobstayton $
-     ********************************************************************
-
-     This file is part of the XSL DocBook Stylesheet distribution.
-     See ../README or http://docbook.sf.net/release/xsl/current/ for
-     copyright and other information.
-
-     ******************************************************************** -->
-
-<xslo:include xmlns:xslo="http://www.w3.org/1999/XSL/Transform" href="../profiling/profile-mode.xsl"/><xslo:variable xmlns:xslo="http://www.w3.org/1999/XSL/Transform" name="profiled-content"><xslo:choose><xslo:when test="*/self::ng:* or */self::db:*"><xslo:message>Note: namesp. cut : stripped namespace before processing</xslo:message><xslo:variable name="stripped-content"><xslo:apply-templates select="/" mode="stripNS"/></xslo:variable><xslo:message>Note: namesp. cut : processing stripped document</xslo:message><xslo:apply-templates select="exslt:node-set($stripped-content)" mode="profile"/></xslo:when><xslo:otherwise><xslo:apply-templates select="/" mode="profile"/></xslo:otherwise></xslo:choose></xslo:variable><xslo:variable xmlns:xslo="http://www.w3.org/1999/XSL/Transform" name="profiled-nodes" select="exslt:node-set($profiled-content)"/><xsl:template match="/">
-  <!-- * Get a title for current doc so that we let the user -->
-  <!-- * know what document we are processing at this point. -->
-  <xsl:variable name="doc.title">
-    <xsl:call-template name="get.doc.title"/>
-  </xsl:variable>
-  <xsl:choose>
-    <!-- Hack! If someone hands us a DocBook V5.x or DocBook NG document,
-         toss the namespace and continue.  Use the docbook5 namespaced
-         stylesheets for DocBook5 if you don't want to use this feature.-->
-    <!-- include extra test for Xalan quirk -->
-    <xsl:when test="false()"/>
-    <xsl:otherwise>
-  <xsl:choose>
-    <xsl:when test="$rootid != ''">
-      <xsl:choose>
-        <xsl:when test="count($profiled-nodes//*[@id=$rootid or @xml:id=$rootid]) = 0">
-          <xsl:message terminate="yes">
-            <xsl:text>ID '</xsl:text>
-            <xsl:value-of select="$rootid"/>
-            <xsl:text>' not found in document.</xsl:text>
-          </xsl:message>
-        </xsl:when>
-        <xsl:otherwise>
-          <xsl:if test="$collect.xref.targets = 'yes' or                         $collect.xref.targets = 'only'">
-            <xsl:apply-templates select="key('id', $rootid)" mode="collect.targets"/>
-          </xsl:if>
-          <xsl:if test="$collect.xref.targets != 'only'">
-            <xsl:message>Formatting from <xsl:value-of select="$rootid"/></xsl:message>
-            <xsl:apply-templates select="$profiled-nodes//*[@id=$rootid or @xml:id=$rootid]" mode="process.root"/>
-            <xsl:call-template name="etoc"/>
-            <xsl:call-template name="plugin.xml"/>
-				<xsl:call-template name="helpidx"/>
-          </xsl:if>
-        </xsl:otherwise>
-      </xsl:choose>
-    </xsl:when>
-    <xsl:otherwise>
-      <xsl:if test="$collect.xref.targets = 'yes' or                     $collect.xref.targets = 'only'">
-        <xsl:apply-templates select="$profiled-nodes" mode="collect.targets"/>
-      </xsl:if>
-      <xsl:if test="$collect.xref.targets != 'only'">
-        <xsl:apply-templates select="$profiled-nodes" mode="process.root"/>
-        <xsl:call-template name="etoc"/>
-        <xsl:call-template name="plugin.xml"/>
-		  <xsl:call-template name="helpidx"/>
-      </xsl:if>
-    </xsl:otherwise>
-  </xsl:choose>
-</xsl:otherwise>
-</xsl:choose>
-</xsl:template>
-
-<xsl:template name="etoc">
-  <xsl:call-template name="write.chunk">
-    <xsl:with-param name="filename">
-      <xsl:if test="$manifest.in.base.dir != 0">
-        <xsl:value-of select="$chunk.base.dir"/>
-      </xsl:if>
-      <xsl:value-of select="'toc.xml'"/>
-    </xsl:with-param>
-    <xsl:with-param name="method" select="'xml'"/>
-    <xsl:with-param name="encoding" select="'utf-8'"/>
-    <xsl:with-param name="indent" select="'yes'"/>
-    <xsl:with-param name="quiet" select="$chunk.quietly"/>
-    <xsl:with-param name="content">
-      <xsl:choose>
-
-        <xsl:when test="$rootid != ''">
-          <xsl:variable name="title">
-            <xsl:if test="$eclipse.autolabel=1">
-              <xsl:variable name="label.markup">
-                <xsl:apply-templates select="$profiled-nodes//*[@id=$rootid or @xml:id=$rootid]" mode="label.markup"/>
-              </xsl:variable>
-              <xsl:if test="normalize-space($label.markup)">
-                <xsl:value-of select="concat($label.markup,$autotoc.label.separator)"/>
-              </xsl:if>
-            </xsl:if>
-            <xsl:apply-templates select="$profiled-nodes//*[@id=$rootid or @xml:id=$rootid]" mode="title.markup"/>
-          </xsl:variable>
-          <xsl:variable name="href">
-            <xsl:call-template name="href.target.with.base.dir">
-              <xsl:with-param name="object" select="key('id',$rootid)"/>
-            </xsl:call-template>
-          </xsl:variable>
-          
-          <toc label="{normalize-space($title)}" topic="{$href}">
-            <xsl:apply-templates select="$profiled-nodes//*[@id=$rootid or @xml:id=$rootid]/*" mode="etoc"/>
-          </toc>
-        </xsl:when>
-
-        <xsl:otherwise>
-          <xsl:variable name="title">
-            <xsl:if test="$eclipse.autolabel=1">
-              <xsl:variable name="label.markup">
-                <xsl:apply-templates select="$profiled-nodes/*" mode="label.markup"/>
-              </xsl:variable>
-              <xsl:if test="normalize-space($label.markup)">
-                <xsl:value-of select="concat($label.markup,$autotoc.label.separator)"/>
-              </xsl:if>
-            </xsl:if>
-            <xsl:apply-templates select="$profiled-nodes/*" mode="title.markup"/>
-          </xsl:variable>
-          <xsl:variable name="href">
-            <xsl:call-template name="href.target.with.base.dir">
-              <xsl:with-param name="object" select="$profiled-nodes"/>
-            </xsl:call-template>
-          </xsl:variable>
-          
-          <toc label="{normalize-space($title)}" topic="{$href}">
-            <xsl:apply-templates select="$profiled-nodes/*/*" mode="etoc"/>
-          </toc>
-        </xsl:otherwise>
-
-      </xsl:choose>
-    </xsl:with-param>
-  </xsl:call-template>
-</xsl:template>
-
-<xsl:template match="book|part|reference|preface|chapter|bibliography|appendix|article|glossary|section|sect1|sect2|sect3|sect4|sect5|refentry|colophon|bibliodiv|index" mode="etoc">
-  <xsl:variable name="title">
-    <xsl:if test="$eclipse.autolabel=1">
-      <xsl:variable name="label.markup">
-        <xsl:apply-templates select="." mode="label.markup"/>
-      </xsl:variable>
-      <xsl:if test="normalize-space($label.markup)">
-        <xsl:value-of select="concat($label.markup,$autotoc.label.separator)"/>
-      </xsl:if>
-    </xsl:if>
-    <xsl:apply-templates select="." mode="title.markup"/>
-  </xsl:variable>
-
-  <xsl:variable name="href">
-    <xsl:call-template name="href.target.with.base.dir">
-      <xsl:with-param name="context" select="/"/>        <!-- Generate links relative to the location of root file/toc.xml file -->
-    </xsl:call-template>
-  </xsl:variable>
-
-  <topic label="{normalize-space($title)}" href="{$href}">
-    <xsl:apply-templates select="part|reference|preface|chapter|bibliography|appendix|article|glossary|section|sect1|sect2|sect3|sect4|sect5|refentry|colophon|bibliodiv|index" mode="etoc"/>
-  </topic>
-
-</xsl:template>
-
-<xsl:template match="text()" mode="etoc"/>
-
-<xsl:template name="plugin.xml">
-  <xsl:call-template name="write.chunk">
-    <xsl:with-param name="filename">
-      <xsl:if test="$manifest.in.base.dir != 0">
-        <xsl:value-of select="$chunk.base.dir"/>
-      </xsl:if>
-      <xsl:value-of select="'plugin.xml'"/>
-    </xsl:with-param>
-    <xsl:with-param name="method" select="'xml'"/>
-    <xsl:with-param name="encoding" select="'utf-8'"/>
-    <xsl:with-param name="indent" select="'yes'"/>
-    <xsl:with-param name="quiet" select="$chunk.quietly"/>
-    <xsl:with-param name="content">
-      <plugin name="{$eclipse.plugin.name}" id="{$eclipse.plugin.id}" version="1.0" provider-name="{$eclipse.plugin.provider}">
-
-		  <extension point="org.eclipse.help.toc">
-			<toc file="toc.xml" primary="true"/>
-		  </extension>
-		  <extension point="org.eclipse.help.index">
-			<index file="index.xml"/>
-		  </extension>
-      </plugin>
-    </xsl:with-param>
-  </xsl:call-template>
-</xsl:template>
-
-<!-- ==================================================================== -->
-<!-- The following templates come from the javahelp xsls with modifications needed to make them generate and ecilpse index.xml file -->
-
-<xsl:template name="helpidx">
-  <xsl:call-template name="write.chunk.with.doctype">
-    <xsl:with-param name="filename" select="concat($chunk.base.dir, 'index.xml')"/>
-    <xsl:with-param name="method" select="'xml'"/>
-    <xsl:with-param name="indent" select="'yes'"/>
-    <xsl:with-param name="doctype-public" select="''"/>
-    <xsl:with-param name="doctype-system" select="''"/>
-    <xsl:with-param name="encoding" select="'utf-8'"/>
-    <xsl:with-param name="quiet" select="$chunk.quietly"/>
-    <xsl:with-param name="content">
-      <xsl:call-template name="helpidx.content"/>
-    </xsl:with-param>
-  </xsl:call-template>
-</xsl:template>
-
-  <xsl:template name="helpidx.content">
-	<index>
-	  <xsl:choose>
-		<xsl:when test="$rootid != ''">
-		  <xsl:apply-templates select="key('id',$rootid)//indexterm" mode="idx">
-			<xsl:sort select="normalize-space(concat(primary/@sortas, primary[not(@sortas) or @sortas = '']))"/>
-			<xsl:sort select="normalize-space(concat(secondary/@sortas, secondary[not(@sortas) or @sortas = '']))"/>
-			<xsl:sort select="normalize-space(concat(tertiary/@sortas, tertiary[not(@sortas) or @sortas = '']))"/>
-		  </xsl:apply-templates>
-		</xsl:when>
-		<xsl:otherwise>
-		  <xsl:apply-templates select="//indexterm" mode="idx">
-			<xsl:sort select="normalize-space(concat(primary/@sortas, primary[not(@sortas) or @sortas = '']))"/>
-			<xsl:sort select="normalize-space(concat(secondary/@sortas, secondary[not(@sortas) or @sortas = '']))"/>
-			<xsl:sort select="normalize-space(concat(tertiary/@sortas, tertiary[not(@sortas) or @sortas = '']))"/>
-		  </xsl:apply-templates>
-		</xsl:otherwise>
-	  </xsl:choose>
-	</index>
-  </xsl:template>
-  
-  <xsl:template match="indexterm[@class='endofrange']" mode="idx"/>
-  
-  <xsl:template match="indexterm|primary|secondary|tertiary" mode="idx">
-
-	<xsl:variable name="href">
-	  <xsl:call-template name="href.target.with.base.dir">
-		<xsl:with-param name="context" select="/"/>        <!-- Generate links relative to the location of root file/toc.xml file -->
-	  </xsl:call-template>
-	</xsl:variable>
-
-	<xsl:variable name="text">
-	  <xsl:value-of select="normalize-space(.)"/>
-	  <xsl:if test="following-sibling::*[1][self::see]">
-		<xsl:text> (</xsl:text><xsl:call-template name="gentext">
-		  <xsl:with-param name="key" select="'see'"/>
-		</xsl:call-template><xsl:text> </xsl:text>
-		<xsl:value-of select="following-sibling::*[1][self::see]"/>)</xsl:if>
-	</xsl:variable>
-	
-	<xsl:choose>
-	  <xsl:when test="self::indexterm">
-		<xsl:apply-templates select="primary" mode="idx"/>
-	  </xsl:when>
-	  <xsl:when test="self::primary">
-		<entry keyword="{$text}">
-		  <topic href="{$href}"/>
-		  <xsl:apply-templates select="following-sibling::secondary" mode="idx"/>
-		</entry>
-	  </xsl:when>
-	  <xsl:otherwise>
-		<entry keyword="{$text}">
-		  <topic href="{$href}"/>
-		  <xsl:apply-templates select="following-sibling::tertiary" mode="idx"/>
-		</entry>
-	  </xsl:otherwise>
-	</xsl:choose>
-  </xsl:template>
-
-  <!-- ==================================================================== -->
-
-</xsl:stylesheet>

+ 0 - 88
stylesheets/lfs-xsl/docbook-xsl-1.78.1/epub/README

@@ -1,88 +0,0 @@
-----------------------------------------------------------------------
-              README file for the DocBook XSL Stylesheets
-----------------------------------------------------------------------
-
-These are XSL stylesheets for transforming DocBook XML document
-instances into .epub format.
-
-.epub is an open standard of the The International Digital Publishing Forum (IDPF), 
-a the trade and standards association for the digital publishing industry. 
-
-An alpha-quality reference implementation (dbtoepub) for a DocBook to .epub 
-converter (written in Ruby) is available under bin/. 
-
-From http://idpf.org
-  What is EPUB, .epub, OPS/OCF & OEB?
-
-  ".epub" is the file extension of an XML format for reflowable digital 
-  books and publications.  ".epub" is composed of three open standards, 
-  the Open Publication Structure (OPS), Open Packaging Format (OPF) and 
-  Open Container Format (OCF), produced by the IDPF. "EPUB" allows 
-  publishers to produce and send a single digital publication file 
-  through distribution and offers consumers interoperability between 
-  software/hardware for unencrypted reflowable digital books and other 
-  publications. The Open eBook Publication Structure or "OEB", 
-  originally produced in 1999, is the precursor to OPS. 
-
-----------------------------------------------------------------------
-.epub Constraints 
-----------------------------------------------------------------------
-
-.epub does not support all of the image formats that DocBook supports.
-When an image is available in an accepted format, it will be used. The
-accepted @formats are: 'GIF','GIF87a','GIF89a','JPEG','JPG','PNG','SVG'
-A mime-type for the image will be guessed from the file extension, 
-which may not work if your file extensions are non-standard.
-
-Non-supported elements:
-  * <mediaobjectco> 
-  * <inlinegraphic>, <graphic>, <textdata>, <imagedata> with text/XML 
-    @filerefs
-  * <olink>
-  * <cmdsynopsis> in lists (generic XHTML rendering inability)
-  * <footnote><para><programlisting> (just make your programlistings 
-    siblings, rather than descendents of paras)
-
-----------------------------------------------------------------------
-dbtoepub Reference Implementation
-----------------------------------------------------------------------
-
-An alpha-quality DocBook to .epub conversion program, dbtoepub, is provided
-in bin/dbtoepub. 
-
-This tool requires:
- - 'xsltproc' in your PATH
- - 'zip' in your PATH
- - Ruby 1.8.4+
-
-Windows compatibility has not been extensively tested; bug reports encouraged.
-[See http://www.zlatkovic.com/libxml.en.html and http://unxutils.sourceforge.net/]
-
-$ dbtoepub --help
-  Usage: dbtoepub [OPTIONS] [DocBook Files]
-
-  dbtoepub converts DocBook <book> and <article>s into to .epub files.
-
-  .epub is defined by the IDPF at www.idpf.org and is made up of 3 standards:
-  - Open Publication Structure (OPS)
-  - Open Packaging Format (OPF) 
-  - Open Container Format (OCF)
-
-  Specific options:
-      -d, --debug                      Show debugging output.
-      -h, --help                       Display usage info
-      -v, --verbose                    Make output verbose
-
-
-----------------------------------------------------------------------
-Validation
-----------------------------------------------------------------------
-
-The epubcheck project provides limited validation for .epub documents. 
-See http://code.google.com/p/epubcheck/ for details.
-
-----------------------------------------------------------------------
-Copyright information
-----------------------------------------------------------------------
-See the accompanying file named COPYING.
-

+ 0 - 76
stylesheets/lfs-xsl/docbook-xsl-1.78.1/epub/bin/dbtoepub

@@ -1,76 +0,0 @@
-#!/usr/bin/env ruby
-# This program converts DocBook documents into .epub files.
-# 
-# Usage: dbtoepub [OPTIONS] [DocBook Files]
-#
-# .epub is defined by the IDPF at www.idpf.org and is made up of 3 standards:
-# - Open Publication Structure (OPS)
-# - Open Packaging Format (OPF) 
-# - Open Container Format (OCF)
-#
-# Specific options:
-#     -c, --css [FILE]                 Use FILE for CSS on generated XHTML.
-#     -d, --debug                      Show debugging output.
-#     -f, --font [OTF FILE]            Embed OTF FILE in .epub.
-#     -h, --help                       Display usage info.
-#     -s, --stylesheet [XSL FILE]      Use XSL FILE as a customization
-#                                        layer (imports epub/docbook.xsl).
-#     -v, --verbose                    Make output verbose.
-
-lib = File.expand_path(File.join(File.dirname(__FILE__), 'lib'))
-$LOAD_PATH.unshift(lib) if File.exist?(lib)
-
-require 'fileutils'
-require 'optparse'
-require 'tmpdir'
-
-require 'docbook'
-
-verbose = false
-debug = false
-css_file = nil
-otf_files = []
-customization_layer = nil
-output_file = nil
-
-#$DEBUG=true
-
-# Set up the OptionParser
-opts = OptionParser.new
-opts.banner = "Usage: #{File.basename($0)} [OPTIONS] [DocBook Files]
-
-#{File.basename($0)} converts DocBook <book> and <article>s into to .epub files.
-
-.epub is defined by the IDPF at www.idpf.org and is made up of 3 standards:
-- Open Publication Structure (OPS)
-- Open Packaging Format (OPF) 
-- Open Container Format (OCF)
-
-Specific options:"
-opts.on("-c", "--css [FILE]", "Use FILE for CSS on generated XHTML.") {|f| css_file = f}
-opts.on("-d", "--debug", "Show debugging output.") {debug = true; verbose = true}
-opts.on("-f", "--font [OTF FILE]", "Embed OTF FILE in .epub.") {|f| otf_files << f}
-opts.on("-h", "--help", "Display usage info.") {puts opts.to_s; exit 0}
-opts.on("-o", "--output [OUTPUT FILE]", "Output ePub file as OUTPUT FILE.") {|f| output_file = f}
-opts.on("-s", "--stylesheet [XSL FILE]", "Use XSL FILE as a customization layer (imports epub/docbook.xsl).") {|f| customization_layer = f}
-opts.on("-v", "--verbose", "Make output verbose.") {verbose = true}
-
-db_files = opts.parse(ARGV)
-if db_files.size == 0
-  puts opts.to_s
-  exit 0
-end
-
-db_files.each {|docbook_file|
-  dir = File.expand_path(File.join(Dir.tmpdir, ".epubtmp#{Time.now.to_f.to_s}"))
-  FileUtils.mkdir_p(dir)
-  e = DocBook::Epub.new(docbook_file, dir, css_file, customization_layer, otf_files)
-
-  if output_file
-    epub_file = output_file
-  else  
-    epub_file = File.basename(docbook_file, ".xml") + ".epub"
-  end  
-  puts "Rendering DocBook file #{docbook_file} to #{epub_file}" if verbose
-  e.render_to_file(epub_file)
-}  

+ 0 - 227
stylesheets/lfs-xsl/docbook-xsl-1.78.1/epub/bin/lib/docbook.rb

@@ -1,227 +0,0 @@
-require 'fileutils'
-require 'rexml/parsers/pullparser'
-
-module DocBook
-
-  class Epub
-    CHECKER = "epubcheck"
-    STYLESHEET = File.expand_path(File.join(File.dirname(__FILE__), '..', '..', "docbook.xsl"))
-    CALLOUT_PATH = File.join('images', 'callouts')
-    CALLOUT_FULL_PATH = File.expand_path(File.join(File.dirname(__FILE__), '..', '..', '..', CALLOUT_PATH))
-    CALLOUT_LIMIT = 15
-    CALLOUT_EXT = ".png"
-    XSLT_PROCESSOR = "xsltproc"
-    OUTPUT_DIR = ".epubtmp#{Time.now.to_f.to_s}"
-    MIMETYPE = "application/epub+zip"
-    META_DIR = "META-INF"
-    OEBPS_DIR = "OEBPS"
-    ZIPPER = "zip"
-
-    attr_reader :output_dir
-
-    def initialize(docbook_file, output_dir=OUTPUT_DIR, css_file=nil, customization_layer=nil, embedded_fonts=[])
-      @docbook_file = docbook_file
-      @output_dir = output_dir
-      @meta_dir  = File.join(@output_dir, META_DIR)
-      @oebps_dir = File.join(@output_dir, OEBPS_DIR)
-      @css_file = css_file ? File.expand_path(css_file) : css_file
-      @embedded_fonts = embedded_fonts
-      @to_delete = []
-      
-      if customization_layer
-        @stylesheet = File.expand_path(customization_layer)
-      else
-        @stylesheet = STYLESHEET
-      end
-
-      unless File.exist?(@docbook_file)
-        raise ArgumentError.new("File #{@docbook_file} does not exist")
-      end
-    end
-
-    def render_to_file(output_file, verbose=false)
-      render_to_epub(output_file, verbose)
-      bundle_epub(output_file, verbose)
-      cleanup_files(@to_delete)
-    end
-
-    def self.invalid?(file)
-      # Obnoxiously, we can't just check for a non-zero output...
-      cmd = %Q(#{CHECKER} "#{file}")
-      output = `#{cmd} 2>&1`
-
-      if $?.to_i == 0
-        return false
-      else  
-        STDERR.puts output if $DEBUG
-        return output
-      end  
-    end
-
-    private
-    def render_to_epub(output_file, verbose)  
-      @collapsed_docbook_file = collapse_docbook()
-
-      chunk_quietly =   "--stringparam chunk.quietly " + (verbose ? '0' : '1')
-      callout_path =    "--stringparam callout.graphics.path #{CALLOUT_PATH}/"
-      callout_limit =   "--stringparam callout.graphics.number.limit #{CALLOUT_LIMIT}"
-      callout_ext =     "--stringparam callout.graphics.extension #{CALLOUT_EXT}" 
-      html_stylesheet = "--stringparam html.stylesheet #{File.basename(@css_file)}" if @css_file
-      base =            "--stringparam base.dir #{OEBPS_DIR}/" 
-      unless @embedded_fonts.empty? 
-        embedded_fonts = @embedded_fonts.map {|f| File.basename(f)}.join(',')
-        font =            "--stringparam epub.embedded.fonts \"#{embedded_fonts}\"" 
-      end  
-      meta =            "--stringparam epub.metainf.dir #{META_DIR}/" 
-      oebps =           "--stringparam epub.oebps.dir #{OEBPS_DIR}/" 
-      options = [chunk_quietly, 
-                 callout_path, 
-                 callout_limit, 
-                 callout_ext, 
-                 base, 
-                 font, 
-                 meta, 
-                 oebps, 
-                 html_stylesheet,
-                ].join(" ")
-      # Double-quote stylesheet & file to help Windows cmd.exe
-      db2epub_cmd = %Q(cd "#{@output_dir}" && #{XSLT_PROCESSOR} #{options} "#{@stylesheet}" "#{@collapsed_docbook_file}")
-      STDERR.puts db2epub_cmd if $DEBUG
-      success = system(db2epub_cmd)
-      raise "Could not render as .epub to #{output_file} (#{db2epub_cmd})" unless success
-      @to_delete << Dir["#{@meta_dir}/*"]
-      @to_delete << Dir["#{@oebps_dir}/*"]
-    end  
-
-    def bundle_epub(output_file, verbose)  
-
-      quiet = verbose ? "" : "-q"
-      mimetype_filename = write_mimetype()
-      meta   = File.basename(@meta_dir)
-      oebps  = File.basename(@oebps_dir)
-      images = copy_images()
-      csses  = copy_csses()
-      fonts  = copy_fonts()
-      callouts = copy_callouts()
-      # zip -X -r ../book.epub mimetype META-INF OEBPS
-      # Double-quote stylesheet & file to help Windows cmd.exe
-      zip_cmd = %Q(cd "#{@output_dir}" &&  #{ZIPPER} #{quiet} -X -r  "#{File.expand_path(output_file)}" "#{mimetype_filename}" "#{meta}" "#{oebps}")
-      puts zip_cmd if $DEBUG
-      success = system(zip_cmd)
-      raise "Could not bundle into .epub file to #{output_file}" unless success
-    end
-
-    # Input must be collapsed because REXML couldn't find figures in files that
-    # were XIncluded or added by ENTITY
-    #   http://sourceforge.net/tracker/?func=detail&aid=2750442&group_id=21935&atid=373747
-    def collapse_docbook
-      # Double-quote stylesheet & file to help Windows cmd.exe
-      collapsed_file = File.join(File.expand_path(File.dirname(@docbook_file)), 
-                                 '.collapsed.' + File.basename(@docbook_file))
-      entity_collapse_command = %Q(xmllint --loaddtd --noent -o "#{collapsed_file}" "#{@docbook_file}")
-      entity_success = system(entity_collapse_command)
-      raise "Could not collapse named entites in #{@docbook_file}" unless entity_success
-
-      xinclude_collapse_command = %Q(xmllint --xinclude -o "#{collapsed_file}" "#{collapsed_file}")
-      xinclude_success = system(xinclude_collapse_command)
-      raise "Could not collapse XIncludes in #{@docbook_file}" unless xinclude_success
-
-      @to_delete << collapsed_file
-      return collapsed_file
-    end  
-
-    def copy_callouts
-      new_callout_images = []
-      if has_callouts?
-        calloutglob = "#{CALLOUT_FULL_PATH}/*#{CALLOUT_EXT}"
-        Dir.glob(calloutglob).each {|img|
-          img_new_filename = File.join(@oebps_dir, CALLOUT_PATH, File.basename(img))
-
-          # TODO: What to rescue for these two?
-          FileUtils.mkdir_p(File.dirname(img_new_filename)) 
-          FileUtils.cp(img, img_new_filename)
-          @to_delete << img_new_filename
-          new_callout_images << img
-        }  
-      end  
-      return new_callout_images
-    end
-
-    def copy_fonts
-      new_fonts = []
-      @embedded_fonts.each {|font_file|
-        font_new_filename = File.join(@oebps_dir, File.basename(font_file))
-        FileUtils.cp(font_file, font_new_filename)
-        new_fonts << font_file
-      }
-      return new_fonts
-    end
-
-    def copy_csses
-      if @css_file 
-        css_new_filename = File.join(@oebps_dir, File.basename(@css_file))
-        FileUtils.cp(@css_file, css_new_filename)
-      end
-    end
-
-    def copy_images
-      image_references = get_image_refs()
-      new_images = []
-      image_references.each {|img|
-        # TODO: It'd be cooler if we had a filetype lookup rather than just
-        # extension
-        if img =~ /\.(svg|png|gif|jpe?g|xml)/i
-          img_new_filename = File.join(@oebps_dir, img)
-          img_full = File.join(File.expand_path(File.dirname(@docbook_file)), img)
-
-          # TODO: What to rescue for these two?
-          FileUtils.mkdir_p(File.dirname(img_new_filename)) 
-          puts(img_full + ": " + img_new_filename) if $DEBUG
-          FileUtils.cp(img_full, img_new_filename)
-          @to_delete << img_new_filename
-          new_images << img_full
-        end
-      }  
-      return new_images
-    end
-
-    def write_mimetype
-      mimetype_filename = File.join(@output_dir, "mimetype")
-      File.open(mimetype_filename, "w") {|f| f.print MIMETYPE}
-      @to_delete << mimetype_filename
-      return File.basename(mimetype_filename)
-    end  
-
-    def cleanup_files(file_list)
-      file_list.flatten.each {|f|
-        # Yikes
-        FileUtils.rm_r(f, :force => true )
-      }  
-    end  
-
-    # Returns an Array of all of the (image) @filerefs in a document
-    def get_image_refs
-      parser = REXML::Parsers::PullParser.new(File.new(@collapsed_docbook_file))
-      image_refs = []
-      while parser.has_next?
-        el = parser.pull
-        if el.start_element? and (el[0] == "imagedata" or el[0] == "graphic")
-          image_refs << el[1]['fileref'] 
-        end  
-      end
-      return image_refs.uniq
-    end  
-
-    # Returns true if the document has code callouts
-    def has_callouts?
-      parser = REXML::Parsers::PullParser.new(File.new(@collapsed_docbook_file))
-      while parser.has_next?
-        el = parser.pull
-        if el.start_element? and (el[0] == "calloutlist" or el[0] == "co")
-          return true
-        end  
-      end
-      return false
-    end  
-  end
-end

+ 0 - 12
stylesheets/lfs-xsl/docbook-xsl-1.78.1/epub/bin/xslt/obfuscate.xsl

@@ -1,12 +0,0 @@
-<?xml version="1.0"?>
-<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" version="2.0">
-  <xsl:output method="xml" omit-xml-declaration="no" doctype-public="-//OASIS//DTD DocBook XML V4.4//EN" doctype-system="http://www.oasis-open.org/docbook/xml/4.4/docbookx.dtd" indent="no"/>
-  <xsl:template match="@*|*|comment()|processing-instruction()">
-    <xsl:copy>
-      <xsl:apply-templates select="@*|node()"/>
-    </xsl:copy>
-  </xsl:template>
-  <xsl:template match="text()">
-    <xsl:value-of select="replace(replace(., '[a-z]', 'x'), '[0-9]', 'd')"/>
-  </xsl:template>
-</xsl:stylesheet>

+ 0 - 1693
stylesheets/lfs-xsl/docbook-xsl-1.78.1/epub/docbook.xsl

@@ -1,1693 +0,0 @@
-<?xml version="1.0"?>
-<xsl:stylesheet 
-  xmlns:db="http://docbook.org/ns/docbook"
-  xmlns:dc="http://purl.org/dc/elements/1.1/"  
-  xmlns:exsl="http://exslt.org/common" 
-  xmlns:h="http://www.w3.org/1999/xhtml"
-  xmlns:ncx="http://www.daisy.org/z3986/2005/ncx/"
-  xmlns:ng="http://docbook.org/docbook-ng"
-  xmlns:opf="http://www.idpf.org/2007/opf"
-  xmlns:stext="http://nwalsh.com/xslt/ext/com.nwalsh.saxon.TextFactory"
-  xmlns:str="http://exslt.org/strings"
-  xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
-  xmlns:xtext="xalan://com.nwalsh.xalan.Text"
-
-  extension-element-prefixes="stext xtext"
-  exclude-result-prefixes="exsl db dc h ncx ng opf stext str xtext"
-
-  version="1.0">
-
-  <xsl:import href="../xhtml-1_1/docbook.xsl" />
-  <xsl:import href="../xhtml-1_1/chunk-common.xsl" />
-  <xsl:include href="../xhtml-1_1/chunk-code.xsl" />
-
-
-  <!-- We want a separate TOC file, please -->
-  <xsl:param name="chunk.tocs.and.lots">1</xsl:param>
-  <xsl:param name="toc.section.depth">2</xsl:param>
-  <xsl:param name="generate.toc">
-  book   toc,title
-  </xsl:param>
-
-  <xsl:param name="ade.extensions" select="0"/>
-  <xsl:param name="epub.autolabel" select="'1'"/> 
-  <xsl:param name="epub.ncx.depth">4</xsl:param> <!-- Not functional until http://code.google.com/p/epubcheck/issues/detail?id=70 is resolved -->
-
-
-  <xsl:param name="manifest.in.base.dir" select="'1'"/> 
-  <xsl:param name="base.dir" select="$epub.oebps.dir"/>
-
-  <xsl:param name="epub.oebps.dir" select="'OEBPS/'"/> 
-  <xsl:param name="epub.ncx.filename" select="'toc.ncx'"/> 
-  <xsl:param name="epub.container.filename" select="'container.xml'"/> 
-  <xsl:param name="epub.opf.filename" select="concat($epub.oebps.dir, 'content.opf')"/> 
-  <xsl:param name="epub.cover.filename" select="concat($epub.oebps.dir, 'cover', $html.ext)"/> 
-  <xsl:param name="epub.cover.id" select="'cover'"/> 
-  <xsl:param name="epub.cover.html" select="'cover.html'" />
-  <xsl:param name="epub.cover.image.id" select="'cover-image'"/> 
-  <xsl:param name="epub.cover.linear" select="0" />
-  <xsl:param name="epub.ncx.toc.id">ncxtoc</xsl:param>
-  <xsl:param name="epub.html.toc.id">htmltoc</xsl:param>
-  <xsl:param name="epub.metainf.dir" select="'META-INF/'"/> 
-
-  <xsl:param name="epub.embedded.fonts"></xsl:param>
-
-  <!-- Turning this on crashes ADE, which is unbelievably awesome -->
-  <xsl:param name="formal.object.break.after">0</xsl:param>
-
-
-  <!-- Per Bob Stayton:
-       """Process your documents with the css.decoration parameter set to zero. 
-          That will avoid the use of style attributes in XHTML elements where they are not permitted."""
-       http://www.sagehill.net/docbookxsl/OtherOutputForms.html#StrictXhtmlValid -->
-  <xsl:param name="css.decoration" select="0"/>
-  <xsl:param name="custom.css.source"></xsl:param> <!-- FIXME: Align with current CSS parameter design -->
-
-  <xsl:param name="callout.graphics" select="1"/>
-  <xsl:param name="callout.graphics.extension">.png</xsl:param>
-  <xsl:param name="callout.graphics.number.limit" select="15"/>
-  <xsl:param name="callout.graphics.path" select="'images/callouts/'"/>
-
-  <!-- no navigation in .epub -->
-  <xsl:param name="suppress.navigation" select="'1'"/> 
-
-  <xsl:variable name="toc.params">
-    <xsl:call-template name="find.path.params">
-      <xsl:with-param name="node" select="/*"/>
-      <xsl:with-param name="table" select="normalize-space($generate.toc)"/>
-    </xsl:call-template>
-  </xsl:variable>
-  <xsl:variable name="root.is.a.chunk">
-    <xsl:choose>
-      <xsl:when test="/*[not(self::book)][not(sect1) or not(section)]">
-        <xsl:text>1</xsl:text>
-      </xsl:when>
-      <xsl:when test="/book[*[last()][self::bookinfo]]|book[bookinfo]">
-        <xsl:text>1</xsl:text>
-      </xsl:when>
-      <xsl:when test="/book[*[last()][self::info]]|book[info]">
-        <xsl:text>1</xsl:text>
-      </xsl:when>
-      <xsl:when test="/bibliography">
-        <xsl:text>1</xsl:text>
-      </xsl:when>
-      <xsl:otherwise>
-        <xsl:text>0</xsl:text>
-      </xsl:otherwise>
-    </xsl:choose>
-  </xsl:variable>
-
-  <xsl:key name="image-filerefs" match="graphic|inlinegraphic|imagedata" use="@fileref"/>
-
-  <xsl:template match="/" priority="1">
-    <!-- * Get a title for current doc so that we let the user -->
-    <!-- * know what document we are processing at this point. -->
-    <xsl:variable name="doc.title">
-      <xsl:call-template name="get.doc.title" />
-    </xsl:variable>
-    <xsl:choose>
-      <!-- Hack! If someone hands us a DocBook V5.x or DocBook NG document,
-        toss the namespace and continue.  Use the docbook5 namespaced
-        stylesheets for DocBook5 if you don't want to use this feature.-->
-      <!-- include extra test for Xalan quirk -->
-      <xsl:when test="$exsl.node.set.available != 0
-                    and (*/self::ng:* or */self::db:*)">
-        <xsl:call-template name="log.message">
-          <xsl:with-param name="level">Note</xsl:with-param>
-          <xsl:with-param name="source" select="$doc.title" />
-          <xsl:with-param name="context-desc">
-            <xsl:text>namesp. cut</xsl:text>
-          </xsl:with-param>
-          <xsl:with-param name="message">
-            <xsl:text>stripped namespace before processing</xsl:text>
-          </xsl:with-param>
-        </xsl:call-template>
-        <xsl:variable name="nons">
-          <xsl:apply-templates mode="stripNS" />
-        </xsl:variable>
-        <xsl:call-template name="log.message">
-          <xsl:with-param name="level">Note</xsl:with-param>
-          <xsl:with-param name="source" select="$doc.title" />
-          <xsl:with-param name="context-desc">
-            <xsl:text>namesp. cut</xsl:text>
-          </xsl:with-param>
-          <xsl:with-param name="message">
-            <xsl:text>processing stripped document</xsl:text>
-          </xsl:with-param>
-        </xsl:call-template>
-        <xsl:apply-templates select="exsl:node-set($nons)" />
-      </xsl:when>
-      <xsl:otherwise>
-        <xsl:choose>
-          <xsl:when test="$rootid != ''">
-            <xsl:choose>
-              <xsl:when
-                test="count(key('id',$rootid)) = 0">
-                <xsl:message terminate="yes">
-                  <xsl:text>ID '</xsl:text>
-                  <xsl:value-of select="$rootid" />
-                  <xsl:text>' not found in document.</xsl:text>
-                </xsl:message>
-              </xsl:when>
-              <xsl:otherwise>
-                <xsl:if
-                  test="$collect.xref.targets = 'yes' or
-                                $collect.xref.targets = 'only'">
-                  <xsl:apply-templates
-                    select="key('id', $rootid)" mode="collect.targets" />
-                </xsl:if>
-                <xsl:if
-                  test="$collect.xref.targets != 'only'">
-                  <xsl:message>
-                    Formatting from
-                    <xsl:value-of select="$rootid" />
-                  </xsl:message>
-                  <xsl:apply-templates
-                    select="key('id',$rootid)" mode="process.root" />
-                  <xsl:call-template name="ncx" />
-                </xsl:if>
-              </xsl:otherwise>
-            </xsl:choose>
-          </xsl:when>
-          <xsl:otherwise>
-            <xsl:if
-              test="$collect.xref.targets = 'yes' or
-                    $collect.xref.targets = 'only'">
-              <xsl:apply-templates select="/"
-                mode="collect.targets" />
-            </xsl:if>
-            <xsl:if
-              test="$collect.xref.targets != 'only'">
-              <xsl:apply-templates select="/"
-                mode="process.root" />
-              <xsl:call-template name="ncx" />
-              <xsl:call-template name="opf" />
-              <xsl:call-template name="cover" />
-              <xsl:call-template name="container" />
-            </xsl:if>
-          </xsl:otherwise>
-        </xsl:choose>
-      </xsl:otherwise>
-    </xsl:choose>
-  </xsl:template>
-
-  <xsl:template name="package-identifier">  
-    <xsl:choose>
-      <xsl:when test="/*/*[contains(name(.), 'info')]/biblioid">
-        <xsl:if test="/*/*[contains(name(.), 'info')][1]/biblioid[1][@class = 'doi' or 
-                                                                      @class = 'isbn' or
-                                                                      @class = 'isrn' or
-                                                                      @class = 'issn']">
-          <xsl:text>urn:</xsl:text>
-          <xsl:value-of select="/*/*[contains(name(.), 'info')][1]/biblioid[1]/@class"/>
-          <xsl:text>:</xsl:text>
-        </xsl:if>
-        <xsl:value-of select="/*/*[contains(name(.), 'info')][1]/biblioid[1]"/>
-      </xsl:when>
-      <xsl:when test="/*/*[contains(name(.), 'info')]/isbn">
-        <xsl:text>urn:isbn:</xsl:text>
-        <xsl:value-of select="/*/*[contains(name(.), 'info')][1]/isbn[1]"/>
-      </xsl:when>
-      <xsl:when test="/*/*[contains(name(.), 'info')]/issn">
-        <xsl:text>urn:issn:</xsl:text>
-        <xsl:value-of select="/*/*[contains(name(.), 'info')][1]/issn[1]"/>
-      </xsl:when>
-      <xsl:otherwise>
-        <xsl:choose>
-          <xsl:when test="/*/*[contains(name(.), 'info')]/invpartnumber"> <xsl:value-of select="/*/*[contains(name(.), 'info')][1]/invpartnumber[1]"/> </xsl:when>
-          <xsl:when test="/*/*[contains(name(.), 'info')]/issuenum">      <xsl:value-of select="/*/*[contains(name(.), 'info')][1]/issuenum[1]"/> </xsl:when>
-          <xsl:when test="/*/*[contains(name(.), 'info')]/productnumber"> <xsl:value-of select="/*/*[contains(name(.), 'info')][1]/productnumber[1]"/> </xsl:when>
-          <xsl:when test="/*/*[contains(name(.), 'info')]/seriesvolnums"> <xsl:value-of select="/*/*[contains(name(.), 'info')][1]/seriesvolnums[1]"/> </xsl:when>
-          <xsl:when test="/*/*[contains(name(.), 'info')]/volumenum">     <xsl:value-of select="/*/*[contains(name(.), 'info')][1]/volumenum[1]"/> </xsl:when>
-          <!-- Deprecated -->
-          <xsl:when test="/*/*[contains(name(.), 'info')]/pubsnumber">    <xsl:value-of select="/*/*[contains(name(.), 'info')][1]/pubsnumber[1]"/> </xsl:when>
-        </xsl:choose>  
-        <xsl:text>_</xsl:text>
-        <xsl:choose>
-          <xsl:when test="/*/@id">
-            <xsl:value-of select="/*/@id"/>
-          </xsl:when>
-          <xsl:when test="/*/@xml:id">
-            <xsl:value-of select="/*/@xml:id"/>
-          </xsl:when>
-          <xsl:otherwise>
-            <!-- TODO: Do UUIDs here -->
-            <xsl:value-of select="generate-id(/*)"/>
-          </xsl:otherwise>
-        </xsl:choose>
-      </xsl:otherwise>
-    </xsl:choose>
-  </xsl:template>
-
-  <xsl:template name="opf">
-    <xsl:variable name="package-identifier-id"><xsl:value-of select="concat(name(/*), 'id')"/></xsl:variable>
-    <xsl:variable name="doc.title">
-      <xsl:call-template name="get.doc.title" />
-    </xsl:variable>
-    <xsl:call-template name="write.chunk">
-      <xsl:with-param name="filename">
-        <xsl:value-of select="$epub.opf.filename" />
-      </xsl:with-param>
-      <xsl:with-param name="method" select="'xml'" />
-      <xsl:with-param name="encoding" select="'utf-8'" />
-      <xsl:with-param name="indent" select="'no'" />
-      <xsl:with-param name="quiet" select="$chunk.quietly" />
-      <xsl:with-param name="doctype-public" select="''"/> <!-- intentionally blank -->
-      <xsl:with-param name="doctype-system" select="''"/> <!-- intentionally blank -->
-      <xsl:with-param name="content">
-        <xsl:element namespace="http://www.idpf.org/2007/opf" name="package">
-          <xsl:attribute name="version">2.0</xsl:attribute>
-          <xsl:attribute name="unique-identifier"> <xsl:value-of select="$package-identifier-id"/> </xsl:attribute>
-
-          <xsl:element namespace="http://www.idpf.org/2007/opf" name="metadata">
-            <xsl:element name="dc:identifier">
-              <xsl:attribute name="id"><xsl:value-of select="$package-identifier-id"/></xsl:attribute>
-              <xsl:call-template name="package-identifier"/>
-            </xsl:element>  
-
-            <xsl:element name="dc:title">
-              <xsl:value-of select="normalize-space($doc.title)"/>
-            </xsl:element>
-
-            <xsl:apply-templates select="/*/*[contains(name(.), 'info')]/*"
-                                 mode="opf.metadata"/>        
-            <xsl:element name="dc:language">
-              <xsl:call-template name="l10n.language">
-                <xsl:with-param name="target" select="/*"/>
-              </xsl:call-template>  
-            </xsl:element>
-
-            <xsl:if test="/*/*[cover or contains(name(.), 'info')]//mediaobject[@role='cover' or ancestor::cover]"> 
-              <xsl:element namespace="http://www.idpf.org/2007/opf" name="meta">
-                <xsl:attribute name="name">cover</xsl:attribute>
-                <xsl:attribute name="content">
-                  <xsl:value-of select="$epub.cover.image.id"/>
-                </xsl:attribute>
-              </xsl:element>
-            </xsl:if>
-
-          </xsl:element>
-          <xsl:call-template name="opf.manifest"/>
-          <xsl:call-template name="opf.spine"/>
-          <xsl:call-template name="opf.guide"/>
-
-        </xsl:element>
-      </xsl:with-param>
-    </xsl:call-template>
-  </xsl:template>
-
-  <xsl:template name="container">
-    <xsl:call-template name="write.chunk">
-      <xsl:with-param name="filename">
-        <xsl:value-of select="$epub.metainf.dir" />
-        <xsl:value-of select="$epub.container.filename" />
-      </xsl:with-param>
-      <xsl:with-param name="method" select="'xml'" />
-      <xsl:with-param name="encoding" select="'utf-8'" />
-      <xsl:with-param name="indent" select="'no'" />
-      <xsl:with-param name="quiet" select="$chunk.quietly" />
-      <xsl:with-param name="doctype-public" select="''"/> <!-- intentionally blank -->
-      <xsl:with-param name="doctype-system" select="''"/> <!-- intentionally blank -->
-
-      <xsl:with-param name="content">
-        <xsl:element namespace="urn:oasis:names:tc:opendocument:xmlns:container" name="container">
-          <xsl:attribute name="version">1.0</xsl:attribute>
-          <xsl:element namespace="urn:oasis:names:tc:opendocument:xmlns:container" name="rootfiles">
-            <xsl:element namespace="urn:oasis:names:tc:opendocument:xmlns:container" name="rootfile">
-              <xsl:attribute name="full-path">
-                <xsl:value-of select="$epub.opf.filename" />
-              </xsl:attribute>
-              <xsl:attribute name="media-type">
-                <xsl:text>application/oebps-package+xml</xsl:text>
-              </xsl:attribute>
-            </xsl:element>
-          </xsl:element>
-        </xsl:element>
-      </xsl:with-param>
-    </xsl:call-template>
-  </xsl:template>
-
-  <xsl:template name="ncx">
-    <xsl:call-template name="write.chunk">
-      <xsl:with-param name="filename">
-        <xsl:if test="$manifest.in.base.dir != 0">
-          <xsl:value-of select="$chunk.base.dir" />
-        </xsl:if>
-        <xsl:value-of select="$epub.ncx.filename" />
-      </xsl:with-param>
-      <xsl:with-param name="method" select="'xml'" />
-      <xsl:with-param name="encoding" select="'utf-8'" />
-      <xsl:with-param name="indent" select="'no'" />
-      <xsl:with-param name="quiet" select="$chunk.quietly" />
-      <xsl:with-param name="doctype-public" select="''"/> <!-- intentionally blank -->
-      <xsl:with-param name="doctype-system" select="''"/> <!-- intentionally blank -->
-      <xsl:with-param name="content">
-        <xsl:element name="ncx" namespace="http://www.daisy.org/z3986/2005/ncx/">
-          <xsl:attribute name="version">2005-1</xsl:attribute>
-
-            <!-- Via Martin Goerner: On covers: the IDPF2.0 standard unfortunately does not have a provision for
-            covers. We had to add one and we did so in conjunction with the IDPF and
-            various publishers. The tag chosen to define the covers is:
-            <meta name="cover" content="-reference to a manifest item-">
-            Then, we also added a bit of logic to get rid cleanly of the HTML cover
-            people usually add because the logical cover is not specced by the IDPF. So,
-            if the HTML cover item is marked linear="no" AND there is a guide item of
-            type="cover" pointing to it AND there is a logical cover specified in a
-            <meta name="cover"> tag, THEN, the HTML cover is discarded. -->
-          <xsl:element name="head" namespace="http://www.daisy.org/z3986/2005/ncx/">
-            <xsl:if test="/*/*[cover or contains(name(.), 'info')]//mediaobject[@role='cover' or ancestor::cover]"> 
-              <xsl:element name="meta" namespace="http://www.daisy.org/z3986/2005/ncx/">
-                <xsl:attribute name="name">cover</xsl:attribute>
-                <xsl:attribute name="content">
-                  <xsl:value-of select="$epub.cover.id"/>
-                </xsl:attribute>
-              </xsl:element>
-            </xsl:if>
-            <xsl:element name="meta" namespace="http://www.daisy.org/z3986/2005/ncx/">
-              <xsl:attribute name="name">dtb:uid</xsl:attribute>
-              <xsl:attribute name="content"><xsl:call-template name="package-identifier"/></xsl:attribute>
-            </xsl:element>
-          </xsl:element>
-
-          <xsl:choose>
-            <xsl:when test="$rootid != ''">
-              <xsl:variable name="title">
-                <xsl:if test="$epub.autolabel != 0">
-                  <xsl:variable name="label.markup">
-                    <xsl:apply-templates select="key('id',$rootid)" mode="label.markup" />
-                  </xsl:variable>
-                  <xsl:if test="normalize-space($label.markup)">
-                    <xsl:value-of select="concat($label.markup,$autotoc.label.separator)" />
-                  </xsl:if>
-                </xsl:if>
-                <xsl:apply-templates select="key('id',$rootid)" mode="title.markup" />
-              </xsl:variable>
-              <xsl:variable name="href">
-                <xsl:call-template name="href.target.with.base.dir">
-                  <xsl:with-param name="object" select="key('id',$rootid)" />
-                </xsl:call-template>
-              </xsl:variable>
-              <xsl:element name="docTitle" namespace="http://www.daisy.org/z3986/2005/ncx/">
-                <xsl:element name="text" namespace="http://www.daisy.org/z3986/2005/ncx/"><xsl:value-of select="normalize-space($title)" />  </xsl:element>
-              </xsl:element>
-              <xsl:element name="navMap" namespace="http://www.daisy.org/z3986/2005/ncx/">
-                <xsl:apply-templates select="key('id',$rootid)/*" mode="ncx" />
-              </xsl:element>
-            </xsl:when>
-            <xsl:otherwise>
-              <xsl:variable name="title">
-                <xsl:if test="$epub.autolabel != 0">
-                  <xsl:variable name="label.markup">
-                    <xsl:apply-templates select="/*" mode="label.markup" />
-                  </xsl:variable>
-                  <xsl:if test="normalize-space($label.markup)">
-                    <xsl:value-of select="concat($label.markup,$autotoc.label.separator)" />
-                  </xsl:if>
-                </xsl:if>
-                <xsl:apply-templates select="/*" mode="title.markup" />
-              </xsl:variable>
-              <xsl:variable name="href">
-                <xsl:call-template name="href.target.with.base.dir">
-                  <xsl:with-param name="object" select="/" />
-                </xsl:call-template>
-              </xsl:variable>
-              <xsl:element name="docTitle" namespace="http://www.daisy.org/z3986/2005/ncx/">
-                <xsl:element name="text" namespace="http://www.daisy.org/z3986/2005/ncx/">
-                  <xsl:value-of select="normalize-space($title)" />
-                </xsl:element>
-              </xsl:element>
-              <xsl:element name="navMap" namespace="http://www.daisy.org/z3986/2005/ncx/">
-                <xsl:choose>
-                  <xsl:when test="$root.is.a.chunk != '0'">
-                    <xsl:apply-templates select="/*" mode="ncx" />
-                  </xsl:when>
-                  <xsl:otherwise>
-                    <xsl:apply-templates select="/*/*" mode="ncx" />
-                  </xsl:otherwise>
-                </xsl:choose>
-              </xsl:element>
-            </xsl:otherwise>
-
-          </xsl:choose>
-        </xsl:element>
-      </xsl:with-param>
-    </xsl:call-template>
-  </xsl:template>
-
-  <xsl:template match="book|
-                       article|
-                       part|
-                       reference|
-                       preface|
-                       chapter|
-                       bibliography|
-                       appendix|
-                       glossary|
-                       section|
-                       sect1|
-                       sect2|
-                       sect3|
-                       sect4|
-                       sect5|
-                       refentry|
-                       colophon|
-                       bibliodiv[title]|
-                       setindex|
-                       index"
-                mode="ncx">
-    <xsl:variable name="depth" select="count(ancestor::*)"/>
-    <xsl:variable name="title">
-      <xsl:if test="$epub.autolabel != 0">
-        <xsl:variable name="label.markup">
-          <xsl:apply-templates select="." mode="label.markup" />
-        </xsl:variable>
-        <xsl:if test="normalize-space($label.markup)">
-          <xsl:value-of
-            select="concat($label.markup,$autotoc.label.separator)" />
-        </xsl:if>
-      </xsl:if>
-      <xsl:apply-templates select="." mode="title.markup" />
-    </xsl:variable>
-
-    <xsl:variable name="href">
-      <xsl:call-template name="href.target.with.base.dir">
-        <xsl:with-param name="context" select="/" />
-        <!-- Generate links relative to the location of root file/toc.xml file -->
-      </xsl:call-template>
-    </xsl:variable>
-
-    <xsl:variable name="id">
-      <xsl:value-of select="generate-id(.)"/>
-    </xsl:variable>
-    <xsl:variable name="order">
-      <xsl:value-of select="$depth +
-                                  count(preceding::part|
-                                  preceding::reference|
-                                  preceding::book[parent::set]|
-                                  preceding::preface|
-                                  preceding::chapter|
-                                  preceding::bibliography|
-                                  preceding::appendix|
-                                  preceding::article|
-                                  preceding::glossary|
-                                  preceding::section[not(parent::partintro)]|
-                                  preceding::sect1[not(parent::partintro)]|
-                                  preceding::sect2[not(ancestor::partintro)]|
-                                  preceding::sect3[not(ancestor::partintro)]|
-                                  preceding::sect4[not(ancestor::partintro)]|
-                                  preceding::sect5[not(ancestor::partintro)]|
-                                  preceding::refentry|
-                                  preceding::colophon|
-                                  preceding::bibliodiv[title]|
-                                  preceding::index)"/>
-    </xsl:variable>
-
-    <xsl:element name="navPoint" namespace="http://www.daisy.org/z3986/2005/ncx/">
-      <xsl:attribute name="id">
-        <xsl:value-of select="$id"/>
-      </xsl:attribute>
-
-      <xsl:attribute name="playOrder">
-        <xsl:choose>
-          <xsl:when test="/*[self::set]">
-            <xsl:value-of select="$order"/>
-          </xsl:when>
-          <xsl:when test="$root.is.a.chunk != '0'">
-            <xsl:value-of select="$order + 1"/>
-          </xsl:when>
-          <xsl:otherwise>
-            <xsl:value-of select="$order - 0"/>
-          </xsl:otherwise>
-        </xsl:choose>
-      </xsl:attribute>
-      <xsl:element name="navLabel" namespace="http://www.daisy.org/z3986/2005/ncx/">
-        <xsl:element name="text" namespace="http://www.daisy.org/z3986/2005/ncx/"><xsl:value-of select="normalize-space($title)"/> </xsl:element>
-      </xsl:element>
-      <xsl:element name="content" namespace="http://www.daisy.org/z3986/2005/ncx/">
-        <xsl:attribute name="src">
-          <xsl:value-of select="$href"/>
-        </xsl:attribute>
-      </xsl:element>
-      <xsl:apply-templates select="book[parent::set]|part|reference|preface|chapter|bibliography|appendix|article|glossary|section|sect1|sect2|sect3|sect4|sect5|refentry|colophon|bibliodiv[title]|setindex|index" mode="ncx"/>
-    </xsl:element>
-
-  </xsl:template>
-
-  <xsl:template match="*" mode="opf.metadata">
-    <!-- override if you care -->
-  </xsl:template>
-
-  <xsl:template match="authorgroup" mode="opf.metadata">
-    <xsl:apply-templates select="author|corpauthor" mode="opf.metadata"/>
-  </xsl:template>
-
-  <xsl:template match="author|corpauthor" mode="opf.metadata">
-    <xsl:variable name="n">
-      <xsl:call-template name="person.name">
-        <xsl:with-param name="node" select="."/>
-      </xsl:call-template>
-    </xsl:variable>
-    <xsl:element name="dc:creator">
-      <xsl:attribute name="opf:file-as">
-        <xsl:call-template name="person.name.last-first">
-          <xsl:with-param name="node" select="."/>
-        </xsl:call-template>
-      </xsl:attribute>
-      <xsl:value-of select="normalize-space(string($n))"/>
-    </xsl:element>
-  </xsl:template>
-
-  <xsl:template match="date" mode="opf.metadata">
-    <xsl:element name="dc:date">
-      <xsl:value-of select="normalize-space(string(.))"/>
-    </xsl:element>
-  </xsl:template>
-
-
-  <!-- Space separate the compontents of the abstract (dropping the inline markup, sadly) -->
-  <xsl:template match="abstract" mode="opf.metadata">
-    <xsl:element name="dc:description">
-      <xsl:for-each select="formalpara|para|simpara|title">
-        <xsl:choose>
-          <xsl:when test="self::formalpara">
-            <xsl:value-of select="normalize-space(string(title))"/>
-            <xsl:text>: </xsl:text>
-            <xsl:value-of select="normalize-space(string(para))"/>
-          </xsl:when>
-          <xsl:otherwise>
-            <xsl:value-of select="normalize-space(string(.))"/>
-          </xsl:otherwise>  
-        </xsl:choose>
-        <xsl:if test="self::title">
-          <xsl:text>:</xsl:text>
-        </xsl:if>
-        <xsl:if test="not(position() = last())">
-          <xsl:text> </xsl:text>
-        </xsl:if>
-      </xsl:for-each>  
-    </xsl:element>
-  </xsl:template>
-
-  <xsl:template match="subjectset" mode="opf.metadata">
-    <xsl:apply-templates select="subject/subjectterm" mode="opf.metadata"/>
-  </xsl:template>
-  
-  <xsl:template match="subjectterm" mode="opf.metadata">
-    <xsl:element name="dc:subject">
-      <xsl:value-of select="normalize-space(string(.))"/>
-    </xsl:element>
-  </xsl:template>
-
-  <xsl:template match="publisher" mode="opf.metadata">
-    <xsl:apply-templates select="publishername" mode="opf.metadata"/>
-  </xsl:template>
-  
-  <xsl:template match="publishername" mode="opf.metadata">
-    <xsl:element name="dc:publisher">
-      <xsl:value-of select="normalize-space(string(.))"/>
-    </xsl:element>
-  </xsl:template>
-
-  <xsl:template match="copyright" mode="opf.metadata">
-    <xsl:variable name="copyright.date">
-      <xsl:call-template name="copyright.years">
-        <xsl:with-param name="years" select="year"/>
-        <xsl:with-param name="print.ranges" select="$make.year.ranges"/>
-        <xsl:with-param name="single.year.ranges" select="$make.single.year.ranges"/>
-      </xsl:call-template>
-    </xsl:variable>
-    <xsl:if test="not(../date)">
-      <xsl:element name="dc:date">
-        <xsl:call-template name="copyright.years">
-          <xsl:with-param name="years" select="year[last()]"/>
-          <xsl:with-param name="print.ranges" select="0"/>
-          <xsl:with-param name="single.year.ranges" select="0"/>
-        </xsl:call-template>
-      </xsl:element>
-    </xsl:if>
-    <xsl:element name="dc:rights">
-      <xsl:call-template name="gentext">
-        <xsl:with-param name="key" select="'Copyright'"/>
-      </xsl:call-template>
-      <xsl:call-template name="gentext.space"/>
-      <xsl:text>&#x00A9;</xsl:text>
-      <xsl:call-template name="gentext.space"/>
-      <xsl:value-of select="$copyright.date"/>
-      <xsl:call-template name="gentext.space"/>
-      <xsl:apply-templates select="holder" mode="titlepage.mode"/>
-    </xsl:element>
-  </xsl:template>
-
-  <xsl:template name="opf.guide">
-    <xsl:if test="contains($toc.params, 'toc') or 
-                  /*/*[cover or contains(name(.), 'info')]//mediaobject[@role='cover' or ancestor::cover]"> 
-      <xsl:element namespace="http://www.idpf.org/2007/opf" name="guide">
-        <xsl:if test="/*/*[cover or contains(name(.), 'info')]//mediaobject[@role='cover' or ancestor::cover]"> 
-          <xsl:element namespace="http://www.idpf.org/2007/opf" name="reference">
-            <xsl:attribute name="href">
-              <xsl:value-of select="$epub.cover.html" />
-            </xsl:attribute>
-            <xsl:attribute name="type">cover</xsl:attribute>
-            <xsl:attribute name="title">Cover</xsl:attribute>
-          </xsl:element>
-        </xsl:if>  
-
-        <xsl:if test="contains($toc.params, 'toc')">
-          <xsl:element namespace="http://www.idpf.org/2007/opf" name="reference">
-            <xsl:attribute name="href">
-              <xsl:call-template name="toc-href">
-                <xsl:with-param name="node" select="/*"/>
-              </xsl:call-template>
-            </xsl:attribute>
-            <xsl:attribute name="type">toc</xsl:attribute>
-            <xsl:attribute name="title">Table of Contents</xsl:attribute>
-          </xsl:element>
-        </xsl:if>  
-      </xsl:element>  
-    </xsl:if>  
-  </xsl:template>
-
-  <xsl:template name="opf.spine">
-
-    <xsl:element namespace="http://www.idpf.org/2007/opf" name="spine">
-      <xsl:attribute name="toc">
-        <xsl:value-of select="$epub.ncx.toc.id"/>
-      </xsl:attribute>
-
-      <xsl:if test="/*/*[cover or contains(name(.), 'info')]//mediaobject[@role='cover' or ancestor::cover]"> 
-        <xsl:element namespace="http://www.idpf.org/2007/opf" name="itemref">
-          <xsl:attribute name="idref">
-            <xsl:value-of select="$epub.cover.id"/>
-          </xsl:attribute>
-          <xsl:attribute name="linear">
-          <xsl:choose>
-            <xsl:when test="$epub.cover.linear">
-              <xsl:text>yes</xsl:text>
-            </xsl:when>
-            <xsl:otherwise>no</xsl:otherwise>
-          </xsl:choose>
-          </xsl:attribute>
-        </xsl:element>
-      </xsl:if>
-
-
-      <xsl:if test="contains($toc.params, 'toc')">
-        <xsl:element namespace="http://www.idpf.org/2007/opf" name="itemref">
-          <xsl:attribute name="idref"> <xsl:value-of select="$epub.html.toc.id"/> </xsl:attribute>
-          <xsl:attribute name="linear">yes</xsl:attribute>
-        </xsl:element>
-      </xsl:if>  
-
-      <!-- TODO: be nice to have a idref="titlepage" here -->
-      <xsl:choose>
-        <xsl:when test="$root.is.a.chunk != '0'">
-          <xsl:apply-templates select="/*" mode="opf.spine"/>
-        </xsl:when>
-        <xsl:otherwise>
-          <xsl:apply-templates select="/*/*" mode="opf.spine"/>
-        </xsl:otherwise>
-      </xsl:choose>
-                                   
-    </xsl:element>
-  </xsl:template>
-
-  <xsl:template match="*" mode="opf.spine">
-    <xsl:variable name="is.chunk">
-      <xsl:call-template name="chunk">
-        <xsl:with-param name="node" select="."/>
-      </xsl:call-template>
-    </xsl:variable>
-
-    <xsl:if test="$is.chunk != 0">
-      <xsl:element namespace="http://www.idpf.org/2007/opf" name="itemref">
-        <xsl:attribute name="idref">
-          <xsl:value-of select="generate-id(.)"/>
-        </xsl:attribute>
-      </xsl:element>
-      <xsl:apply-templates select="*|.//refentry" mode="opf.spine"/>
-    </xsl:if>
-  </xsl:template>
-
-  <xsl:template name="opf.manifest">
-    <xsl:element namespace="http://www.idpf.org/2007/opf" name="manifest">
-      <xsl:element namespace="http://www.idpf.org/2007/opf" name="item">
-        <xsl:attribute name="id"> <xsl:value-of select="$epub.ncx.toc.id"/> </xsl:attribute>
-        <xsl:attribute name="media-type">application/x-dtbncx+xml</xsl:attribute>
-        <xsl:attribute name="href"><xsl:value-of select="$epub.ncx.filename"/> </xsl:attribute>
-      </xsl:element>
-
-      <xsl:if test="contains($toc.params, 'toc')">
-        <xsl:element namespace="http://www.idpf.org/2007/opf" name="item">
-          <xsl:attribute name="id"> <xsl:value-of select="$epub.html.toc.id"/> </xsl:attribute>
-          <xsl:attribute name="media-type">application/xhtml+xml</xsl:attribute>
-          <xsl:attribute name="href">
-            <xsl:call-template name="toc-href">
-              <xsl:with-param name="node" select="/*"/>
-            </xsl:call-template>
-          </xsl:attribute>
-        </xsl:element>
-      </xsl:if>  
-
-      <xsl:if test="$html.stylesheet != ''">
-        <xsl:element namespace="http://www.idpf.org/2007/opf" name="item">
-          <xsl:attribute name="media-type">text/css</xsl:attribute>
-          <xsl:attribute name="id">css</xsl:attribute>
-          <xsl:attribute name="href"><xsl:value-of select="$html.stylesheet"/></xsl:attribute>
-        </xsl:element>
-      </xsl:if>
-
-      <xsl:if test="/*/*[cover or contains(name(.), 'info')]//mediaobject[@role='cover' or ancestor::cover]"> 
-        <xsl:element namespace="http://www.idpf.org/2007/opf" name="item">
-          <xsl:attribute name="id"> <xsl:value-of select="$epub.cover.id"/> </xsl:attribute>
-          <xsl:attribute name="href"> 
-            <xsl:value-of select="$epub.cover.html"/>
-          </xsl:attribute>
-          <xsl:attribute name="media-type">application/xhtml+xml</xsl:attribute>
-        </xsl:element>
-      </xsl:if>  
-
-      <xsl:choose>
-        <xsl:when test="$epub.embedded.fonts != '' and not(contains($epub.embedded.fonts, ','))">
-          <xsl:call-template name="embedded-font-item">
-            <xsl:with-param name="font.file" select="$epub.embedded.fonts"/> <!-- There is just one -->
-          </xsl:call-template>
-        </xsl:when>
-        <xsl:when test="$epub.embedded.fonts != ''">
-          <xsl:variable name="font.file.tokens" select="str:tokenize($epub.embedded.fonts, ',')"/>
-          <xsl:for-each select="exsl:node-set($font.file.tokens)">
-            <xsl:call-template name="embedded-font-item">
-              <xsl:with-param name="font.file" select="."/>
-              <xsl:with-param name="font.order" select="position()"/>
-            </xsl:call-template>
-          </xsl:for-each>
-        </xsl:when>
-      </xsl:choose>
-
-      <!-- TODO: be nice to have a id="titlepage" here -->
-      <xsl:apply-templates select="//part|
-                                   //book[*[last()][self::bookinfo]]|
-                                   //book[bookinfo]|
-                                   //book[*[last()][self::info]]|
-                                   //book[info]|
-                                   /set|
-                                   /set/book|
-                                   //reference|
-                                   //preface|
-                                   //chapter|
-                                   //bibliography|
-                                   //appendix|
-                                   //article|
-                                   //glossary|
-                                   //section|
-                                   //sect1|
-                                   //sect2|
-                                   //sect3|
-                                   //sect4|
-                                   //sect5|
-                                   //refentry|
-                                   //colophon|
-                                   //bibliodiv[title]|
-                                   //index|
-                                   //setindex|
-                                   //graphic|
-                                   //inlinegraphic|
-                                   //mediaobject|
-                                   //mediaobjectco|
-                                   //inlinemediaobject" 
-                           mode="opf.manifest"/>
-      <xsl:call-template name="opf.calloutlist"/>
-    </xsl:element>
-  </xsl:template>
-
-  <xsl:template name="opf.calloutlist">
-    <xsl:variable name="format">
-      <xsl:call-template name="guess-media-type">
-        <xsl:with-param name="ext" select="$callout.graphics.extension"/>
-      </xsl:call-template>
-    </xsl:variable>  
-    <xsl:if test="(//calloutlist|//co)">
-      <xsl:call-template name="opf.reference.callout">
-        <xsl:with-param name="conum" select="1"/>
-        <xsl:with-param name="format" select="$format"/>
-      </xsl:call-template>
-    </xsl:if>
-  </xsl:template>
-
-  <xsl:template name="opf.reference.callout">
-    <xsl:param name="conum"/>
-    <xsl:param name="format"/>
-
-    <xsl:variable name="filename" select="concat($callout.graphics.path, $conum, $callout.graphics.extension)"/>
-
-    <xsl:element namespace="http://www.idpf.org/2007/opf" name="item">
-      <xsl:attribute name="id"> <xsl:value-of select="concat(generate-id(.), 'callout', $conum)"/> </xsl:attribute>
-      <xsl:attribute name="href"> <xsl:value-of select="$filename"/> </xsl:attribute>
-      <xsl:attribute name="media-type">
-        <xsl:value-of select="$format"/>
-      </xsl:attribute>
-    </xsl:element>
-    <xsl:if test="($conum &lt; $callout.graphics.number.limit)">
-      <xsl:call-template name="opf.reference.callout">
-        <xsl:with-param name="conum" select="$conum + 1"/>
-        <xsl:with-param name="format" select="$format"/>
-      </xsl:call-template>
-    </xsl:if>
-  </xsl:template>
-
-  <xsl:template name="guess-media-type">
-    <xsl:param name="ext"></xsl:param>
-    <xsl:choose>
-      <xsl:when test="contains($ext, '.gif')">
-        <xsl:text>image/gif</xsl:text>
-      </xsl:when>
-      <xsl:when test="contains($ext, 'GIF')">
-        <xsl:text>image/gif</xsl:text>
-      </xsl:when>
-      <xsl:when test="contains($ext, '.png')">
-        <xsl:text>image/png</xsl:text>
-      </xsl:when>
-      <xsl:when test="contains($ext, 'PNG')">
-        <xsl:text>image/png</xsl:text>
-      </xsl:when>
-      <xsl:when test="contains($ext, '.jpeg')">
-        <xsl:text>image/jpeg</xsl:text>
-      </xsl:when>
-      <xsl:when test="contains($ext, 'JPEG')">
-        <xsl:text>image/jpeg</xsl:text>
-      </xsl:when>
-      <xsl:when test="contains($ext, '.jpg')">
-        <xsl:text>image/jpeg</xsl:text>
-      </xsl:when>
-      <xsl:when test="contains($ext, 'JPG')">
-        <xsl:text>image/jpeg</xsl:text>
-      </xsl:when>
-      <xsl:when test="contains($ext, '.svg')">
-        <xsl:text>image/svg+xml</xsl:text>
-      </xsl:when>
-      <xsl:when test="contains($ext, 'SVG')">
-        <xsl:text>image/svg+xml</xsl:text>
-      </xsl:when>
-      <xsl:otherwise>
-        <!-- we failed -->
-        <xsl:text></xsl:text>
-      </xsl:otherwise>
-    </xsl:choose>
-  </xsl:template>
-
-  <xsl:template match="mediaobject|
-                       mediaobjectco|
-                       inlinemediaobject" 
-                mode="opf.manifest">
-
-    <xsl:variable name="olist" select="imageobject|imageobjectco                      |videoobject|audioobject                      |textobject"/>
-
-    <xsl:variable name="object.index">
-      <xsl:call-template name="select.mediaobject.index">
-        <xsl:with-param name="olist" select="$olist"/>
-        <xsl:with-param name="count" select="1"/>
-      </xsl:call-template>
-    </xsl:variable>
-
-    <xsl:variable name="object" select="$olist[position() = $object.index]"/>
-
-    <xsl:choose>
-      <xsl:when test="$object/descendant::imagedata[@format = 'GIF' or 
-                                                    @format = 'GIF87a' or 
-                                                    @format = 'GIF89a' or 
-                                                    @format = 'JPEG' or 
-                                                    @format = 'JPG' or 
-                                                    @format = 'PNG' or 
-                                                    @format = 'SVG']">
-        <xsl:apply-templates select="$object[descendant::imagedata[@format = 'GIF' or 
-                                                                   @format = 'GIF87a' or 
-                                                                   @format = 'GIF89a' or 
-                                                                   @format = 'JPEG' or 
-                                                                   @format = 'JPG' or 
-                                                                   @format = 'PNG' or 
-                                                                   @format = 'SVG']][1]/imagedata"
-                             mode="opf.manifest"/>              
-      </xsl:when>
-      <xsl:otherwise>
-        <xsl:apply-templates select="$object/imagedata[1]"
-                             mode="opf.manifest"/>              
-      </xsl:otherwise>
-    </xsl:choose>  
-  </xsl:template>
-
-  <xsl:template match="cover/mediaobject|
-                       mediaobject[@role='cover']"
-                mode="opf.manifest">
-    <xsl:choose>
-      <xsl:when test="imageobject[@role='front-large']">
-        <xsl:apply-templates select="imageobject[@role='front-large']/imagedata"
-                             mode="opf.manifest"/>              
-      </xsl:when>
-      <xsl:otherwise>
-        <xsl:apply-templates select="imageobject/imagedata[1]"
-                             mode="opf.manifest"/>              
-      </xsl:otherwise>
-    </xsl:choose>  
-  </xsl:template>
-
-  <xsl:template match="mediaobjectco"
-                mode="opf.manifest">
-    <xsl:message>WARNING: mediaobjectco almost certainly will not render as expected in .epub!</xsl:message>
-    <xsl:apply-templates select="imageobjectco/imageobject/imagedata" 
-                         mode="opf.manifest"/>              
-  </xsl:template>
-
-  <!-- TODO: Barf (xsl:message terminate=yes) if you find a graphic with no reasonable format or a mediaobject w/o same? [option to not die?] -->
-
-  <!-- wish I had XSLT2 ...-->
-  <!-- TODO: priority a hack -->
-  <xsl:template match="graphic[not(@format)]|
-                       inlinegraphic[not(@format)]|
-                       imagedata[not(@format)]"
-                mode="opf.manifest">        
-    <xsl:variable name="filename">
-      <xsl:choose>
-        <xsl:when test="contains(name(.), 'graphic')">
-          <xsl:choose>
-            <xsl:when test="@entityref">
-              <xsl:value-of select="unparsed-entity-uri(@entityref)"/>
-            </xsl:when>
-            <xsl:otherwise>
-              <xsl:apply-templates select="@fileref"/>
-            </xsl:otherwise>
-          </xsl:choose>
-        </xsl:when>
-        <xsl:otherwise>
-          <xsl:call-template name="mediaobject.filename">
-            <xsl:with-param name="object" select=".."/>
-          </xsl:call-template>
-        </xsl:otherwise>
-      </xsl:choose>
-    </xsl:variable>  
-    <xsl:variable name="format"> 
-      <xsl:call-template name="guess-media-type">
-        <xsl:with-param name="ext" select="@fileref"/>
-      </xsl:call-template>
-    </xsl:variable>
-    <xsl:variable name="fr" select="@fileref"/>
-    <xsl:if test="$format != ''">
-      <!-- only do this if we're the first file to match -->
-      <!-- TODO: Why can't this be simple equality?? (I couldn't get it to work) -->
-      <xsl:if test="generate-id(.) = generate-id(key('image-filerefs', $fr)[1])">
-        <xsl:element namespace="http://www.idpf.org/2007/opf" name="item">
-          <xsl:attribute name="id"> 
-            <xsl:choose>
-              <xsl:when test="ancestor::mediaobject[@role='cover'] and parent::*[@role='front-large']">
-                <xsl:value-of select="$epub.cover.image.id"/>
-              </xsl:when>
-              <xsl:when test="ancestor::mediaobject[@role='cover'] and (count(ancestor::mediaobject//imageobject) = 1)">
-                <xsl:value-of select="$epub.cover.image.id"/>
-              </xsl:when>
-              <xsl:when test="ancestor::cover">
-                <xsl:value-of select="$epub.cover.image.id"/>
-              </xsl:when>
-              <xsl:otherwise>
-                <xsl:value-of select="generate-id(.)"/> 
-              </xsl:otherwise>
-            </xsl:choose>
-          </xsl:attribute>  
-          <xsl:attribute name="href"> <xsl:value-of select="$filename"/> </xsl:attribute>
-          <xsl:attribute name="media-type">
-            <xsl:value-of select="$format"/>
-          </xsl:attribute>
-        </xsl:element>
-      </xsl:if>
-    </xsl:if>
-  </xsl:template>
-
-  <!-- Note: Selection of the first interesting imagedata is done in the select -->
-  <xsl:template match="graphic[@format = 'GIF' or @format = 'GIF87a' or @format = 'GIF89a' or @format = 'JPEG' or @format = 'JPG' or @format = 'PNG' or @format = 'SVG']|
-                       inlinegraphic[@format = 'GIF' or @format = 'GIF87a' or @format = 'GIF89a' or @format = 'JPEG' or @format = 'JPG' or @format = 'PNG' or @format = 'SVG']|
-                       imagedata[@format]"
-                mode="opf.manifest">
-    <xsl:variable name="filename">
-      <xsl:choose>
-        <xsl:when test="contains(name(.), 'graphic')">
-          <xsl:choose>
-            <xsl:when test="@entityref">
-              <xsl:value-of select="unparsed-entity-uri(@entityref)"/>
-            </xsl:when>
-            <xsl:otherwise>
-              <xsl:apply-templates select="@fileref"/>
-            </xsl:otherwise>
-          </xsl:choose>
-        </xsl:when>
-        <xsl:otherwise>
-          <xsl:call-template name="mediaobject.filename">
-            <xsl:with-param name="object" select=".."/>
-          </xsl:call-template>
-        </xsl:otherwise>
-      </xsl:choose>
-    </xsl:variable>  
-    <xsl:variable name="fr" select="@fileref"/>
-    <!-- only do this if we're the first file to match -->
-    <!-- TODO: Why can't this be simple equality?? (I couldn't get it to work) -->
-    <xsl:if test="generate-id(.) = generate-id(key('image-filerefs', $fr)[1])">
-      <xsl:element namespace="http://www.idpf.org/2007/opf" name="item">
-        <xsl:attribute name="id"> 
-          <xsl:choose>
-            <xsl:when test="ancestor::mediaobject[@role='cover'] and parent::*[@role='front-large']">
-              <xsl:value-of select="$epub.cover.image.id"/>
-            </xsl:when>
-            <xsl:when test="ancestor::mediaobject[@role='cover'] and (count(ancestor::mediaobject//imageobject) = 1)">
-              <xsl:value-of select="$epub.cover.image.id"/>
-            </xsl:when>
-            <xsl:when test="ancestor::cover">
-              <xsl:value-of select="$epub.cover.image.id"/>
-            </xsl:when>
-            <xsl:otherwise>
-              <xsl:value-of select="generate-id(.)"/> 
-            </xsl:otherwise>
-          </xsl:choose>
-        </xsl:attribute>
-        <xsl:attribute name="href"> <xsl:value-of select="$filename"/> </xsl:attribute>
-        <xsl:attribute name="media-type">
-          <xsl:call-template name="guess-media-type">
-            <xsl:with-param name="ext" select="@format"/>
-          </xsl:call-template>
-        </xsl:attribute>
-      </xsl:element>
-    </xsl:if>
-  </xsl:template>
-
-  <!-- Warning: While the test indicate this match list is accurate, it may 
-       need further tweaking to ensure _never_ dropping generated content (XHTML)
-       from the manifest (OPF file) -->
-  <xsl:template
-      match="set|
-            book[parent::set]|
-            book[*[last()][self::bookinfo]]|
-            book[bookinfo]|
-            book[*[last()][self::info]]|
-            book[info]|
-            article|
-            part|
-            reference|
-            preface|
-            chapter|
-            bibliography|
-            appendix|
-            glossary|
-            section|
-            sect1|
-            sect2|
-            sect3|
-            sect4|
-            sect5|
-            refentry|
-            colophon|
-            bibliodiv[title]|
-            setindex|
-            index"
-      mode="opf.manifest">
-    <xsl:variable name="href">
-      <xsl:call-template name="href.target.with.base.dir">
-        <xsl:with-param name="context" select="/" />
-        <!-- Generate links relative to the location of root file/toc.xml file -->
-      </xsl:call-template>
-    </xsl:variable>
-
-    <xsl:variable name="id">
-      <xsl:value-of select="generate-id(.)"/>
-    </xsl:variable>
-
-    <xsl:variable name="is.chunk">
-      <xsl:call-template name="chunk">
-        <xsl:with-param name="node" select="."/>
-      </xsl:call-template>
-    </xsl:variable>
-
-    <xsl:if test="$is.chunk != 0">
-      <xsl:element namespace="http://www.idpf.org/2007/opf" name="item">
-        <xsl:attribute name="id"> <xsl:value-of select="$id"/> </xsl:attribute>
-        <xsl:attribute name="href"> <xsl:value-of select="$href"/> </xsl:attribute>
-        <xsl:attribute name="media-type">application/xhtml+xml</xsl:attribute>
-      </xsl:element>
-    </xsl:if>  
-  </xsl:template>  
-
-  <xsl:template match="text()" mode="ncx" />
-
-  <xsl:template name="html.head">
-    <xsl:param name="prev" select="/foo"/>
-    <xsl:param name="next" select="/foo"/>
-    <xsl:variable name="this" select="."/>
-    <xsl:variable name="home" select="/*[1]"/>
-    <xsl:variable name="up" select="parent::*"/>
-
-    <head xmlns="http://www.w3.org/1999/xhtml">
-      <xsl:call-template name="system.head.content"/>
-      <xsl:call-template name="head.content"/>
-
-      <xsl:call-template name="user.head.content"/>
-    </head>
-  </xsl:template>
-
-  <!-- OVERRIDES xhtml-1_1/graphics.xsl -->
-  <!-- we can't deal with no img/@alt, because it's required. Try grabbing a title before it instead (hopefully meaningful) -->
-  <xsl:template name="process.image.attributes">
-    <xsl:param name="alt"/>
-    <xsl:param name="html.width"/>
-    <xsl:param name="html.depth"/>
-    <xsl:param name="longdesc"/>
-    <xsl:param name="scale"/>
-    <xsl:param name="scalefit"/>
-    <xsl:param name="scaled.contentdepth"/>
-    <xsl:param name="scaled.contentwidth"/>
-    <xsl:param name="viewport"/>
-
-    <xsl:choose>
-      <xsl:when test="@contentwidth or @contentdepth">
-        <!-- ignore @width/@depth, @scale, and @scalefit if specified -->
-        <xsl:if test="@contentwidth and $scaled.contentwidth != ''">
-          <xsl:attribute name="width">
-            <xsl:value-of select="$scaled.contentwidth"/>
-          </xsl:attribute>
-        </xsl:if>
-        <xsl:if test="@contentdepth and $scaled.contentdepth != ''">
-          <xsl:attribute name="height">
-            <xsl:value-of select="$scaled.contentdepth"/>
-          </xsl:attribute>
-        </xsl:if>
-      </xsl:when>
-
-      <xsl:when test="number($scale) != 1.0">
-        <!-- scaling is always uniform, so we only have to specify one dimension -->
-        <!-- ignore @scalefit if specified -->
-        <xsl:attribute name="width">
-          <xsl:value-of select="$scaled.contentwidth"/>
-        </xsl:attribute>
-      </xsl:when>
-
-      <xsl:when test="$scalefit != 0">
-        <xsl:choose>
-          <xsl:when test="contains($html.width, '%')">
-            <xsl:choose>
-              <xsl:when test="$viewport != 0">
-                <!-- The *viewport* will be scaled, so use 100% here! -->
-                <xsl:attribute name="width">
-                  <xsl:value-of select="'100%'"/>
-                </xsl:attribute>
-              </xsl:when>
-              <xsl:otherwise>
-                <xsl:attribute name="width">
-                  <xsl:value-of select="$html.width"/>
-                </xsl:attribute>
-              </xsl:otherwise>
-            </xsl:choose>
-          </xsl:when>
-
-          <xsl:when test="contains($html.depth, '%')">
-            <!-- HTML doesn't deal with this case very well...do nothing -->
-          </xsl:when>
-
-          <xsl:when test="$scaled.contentwidth != '' and $html.width != ''                         and $scaled.contentdepth != '' and $html.depth != ''">
-            <!-- scalefit should not be anamorphic; figure out which direction -->
-            <!-- has the limiting scale factor and scale in that direction -->
-            <xsl:choose>
-              <xsl:when test="$html.width div $scaled.contentwidth &gt;                             $html.depth div $scaled.contentdepth">
-                <xsl:attribute name="height">
-                  <xsl:value-of select="$html.depth"/>
-                </xsl:attribute>
-              </xsl:when>
-              <xsl:otherwise>
-                <xsl:attribute name="width">
-                  <xsl:value-of select="$html.width"/>
-                </xsl:attribute>
-              </xsl:otherwise>
-            </xsl:choose>
-          </xsl:when>
-
-          <xsl:when test="$scaled.contentwidth != '' and $html.width != ''">
-            <xsl:attribute name="width">
-              <xsl:value-of select="$html.width"/>
-            </xsl:attribute>
-          </xsl:when>
-
-          <xsl:when test="$scaled.contentdepth != '' and $html.depth != ''">
-            <xsl:attribute name="height">
-              <xsl:value-of select="$html.depth"/>
-            </xsl:attribute>
-          </xsl:when>
-        </xsl:choose>
-      </xsl:when>
-    </xsl:choose>
-
-    <!-- AN OVERRIDE -->
-    <xsl:if test="not(@format ='SVG')">
-      <xsl:attribute name="alt">
-        <xsl:choose>
-          <xsl:when test="$alt != ''">
-            <xsl:value-of select="normalize-space($alt)"/>
-          </xsl:when>
-          <xsl:when test="preceding::title[1]">
-            <xsl:value-of select="normalize-space(preceding::title[1])"/>
-          </xsl:when>
-          <xsl:otherwise>
-            <xsl:text>(missing alt)</xsl:text>
-          </xsl:otherwise>
-        </xsl:choose>
-      </xsl:attribute>
-    </xsl:if>
-    <!-- END OF OVERRIDE -->
-
-    <xsl:if test="$longdesc != ''">
-      <xsl:attribute name="longdesc">
-        <xsl:value-of select="$longdesc"/>
-      </xsl:attribute>
-    </xsl:if>
-
-    <xsl:if test="@align and $viewport = 0">
-      <xsl:attribute name="style"><xsl:text>text-align: </xsl:text>
-        <xsl:choose>
-          <xsl:when test="@align = 'center'">middle</xsl:when>
-          <xsl:otherwise>
-            <xsl:value-of select="@align"/>
-          </xsl:otherwise>
-        </xsl:choose>
-      </xsl:attribute>
-    </xsl:if>
-  </xsl:template>
-  
-  <!-- OVERRIDES xhtml-1_1/chunk-common.xsl   -->
-  <!-- make a bibliography always a chunk -->
-  <xsl:template name="chunk">       
-    <xsl:param name="node" select="."/>
-    <!-- returns 1 if $node is a chunk -->
-
-    <!-- ==================================================================== -->
-    <!-- What's a chunk?
-
-        The root element
-        appendix
-        article
-        bibliography  ### NO LONGER TRUE in article or part or book
-        book
-        chapter
-        colophon
-        glossary      in article or part or book
-        index         in article or part or book
-        part
-        preface
-        refentry
-        reference
-        sect{1,2,3,4,5}  if position()>1 && depth < chunk.section.depth
-        section          if position()>1 && depth < chunk.section.depth
-        set
-        setindex
-                                                                              -->
-    <!-- ==================================================================== -->
-
-  <!--
-    <xsl:message>
-      <xsl:text>chunk: </xsl:text>
-      <xsl:value-of select="name($node)"/>
-      <xsl:text>(</xsl:text>
-      <xsl:value-of select="$node/@id"/>
-      <xsl:text>)</xsl:text>
-      <xsl:text> csd: </xsl:text>
-      <xsl:value-of select="$chunk.section.depth"/>
-      <xsl:text> cfs: </xsl:text>
-      <xsl:value-of select="$chunk.first.sections"/>
-      <xsl:text> ps: </xsl:text>
-      <xsl:value-of select="count($node/parent::section)"/>
-      <xsl:text> prs: </xsl:text>
-      <xsl:value-of select="count($node/preceding-sibling::section)"/>
-    </xsl:message>
-  -->
-
-    <xsl:choose>
-      <xsl:when test="not($node/parent::*)">1</xsl:when>
-
-      <xsl:when test="local-name($node) = 'sect1'                     and $chunk.section.depth &gt;= 1                     and ($chunk.first.sections != 0                          or count($node/preceding-sibling::sect1) &gt; 0)">
-        <xsl:text>1</xsl:text>
-      </xsl:when>
-      <xsl:when test="local-name($node) = 'sect2'                     and $chunk.section.depth &gt;= 2                     and ($chunk.first.sections != 0                          or count($node/preceding-sibling::sect2) &gt; 0)">
-        <xsl:call-template name="chunk">
-          <xsl:with-param name="node" select="$node/parent::*"/>
-        </xsl:call-template>
-      </xsl:when>
-      <xsl:when test="local-name($node) = 'sect3'                     and $chunk.section.depth &gt;= 3                     and ($chunk.first.sections != 0                          or count($node/preceding-sibling::sect3) &gt; 0)">
-        <xsl:call-template name="chunk">
-          <xsl:with-param name="node" select="$node/parent::*"/>
-        </xsl:call-template>
-      </xsl:when>
-      <xsl:when test="local-name($node) = 'sect4'                     and $chunk.section.depth &gt;= 4                     and ($chunk.first.sections != 0                          or count($node/preceding-sibling::sect4) &gt; 0)">
-        <xsl:call-template name="chunk">
-          <xsl:with-param name="node" select="$node/parent::*"/>
-        </xsl:call-template>
-      </xsl:when>
-      <xsl:when test="local-name($node) = 'sect5'                     and $chunk.section.depth &gt;= 5                     and ($chunk.first.sections != 0                          or count($node/preceding-sibling::sect5) &gt; 0)">
-        <xsl:call-template name="chunk">
-          <xsl:with-param name="node" select="$node/parent::*"/>
-        </xsl:call-template>
-      </xsl:when>
-      <xsl:when test="local-name($node) = 'section'                     and $chunk.section.depth &gt;= count($node/ancestor::section)+1                     and ($chunk.first.sections != 0                          or count($node/preceding-sibling::section) &gt; 0)">
-        <xsl:call-template name="chunk">
-          <xsl:with-param name="node" select="$node/parent::*"/>
-        </xsl:call-template>
-      </xsl:when>
-
-      <xsl:when test="local-name($node)='preface'">1</xsl:when>
-      <xsl:when test="local-name($node)='chapter'">1</xsl:when>
-      <xsl:when test="local-name($node)='appendix'">1</xsl:when>
-      <xsl:when test="local-name($node)='article'">1</xsl:when>
-      <xsl:when test="local-name($node)='part'">1</xsl:when>
-      <xsl:when test="local-name($node)='reference'">1</xsl:when>
-      <xsl:when test="local-name($node)='refentry'">1</xsl:when>
-      <xsl:when test="local-name($node)='index' and ($generate.index != 0 or count($node/*) &gt; 0)                     and (local-name($node/parent::*) = 'article'                     or local-name($node/parent::*) = 'book'                     or local-name($node/parent::*) = 'part'                     )">1</xsl:when>
-      <!-- AN OVERRIDE -->
-      <xsl:when test="local-name($node)='bibliography'">1</xsl:when>
-      <!-- END OF OVERRIDE -->
-      <xsl:when test="local-name($node)='glossary'                     and (local-name($node/parent::*) = 'article'                     or local-name($node/parent::*) = 'book'                     or local-name($node/parent::*) = 'part'                     )">1</xsl:when>
-      <xsl:when test="local-name($node)='colophon'">1</xsl:when>
-      <xsl:when test="local-name($node)='book'">1</xsl:when>
-      <xsl:when test="local-name($node)='set'">1</xsl:when>
-      <xsl:when test="local-name($node)='setindex'">1</xsl:when>
-      <xsl:when test="local-name($node)='legalnotice'                     and $generate.legalnotice.link != 0">1</xsl:when>
-      <xsl:otherwise>0</xsl:otherwise>
-    </xsl:choose>
-  </xsl:template>
-
-  <!-- OVERRIDES xhtml-1_1/chunk-code.xsl   -->
-  <!-- Add chunking for bibliography as root element -->
-  <!-- AN OVERRIDE --> 
-  <xsl:template match="set|
-                       book|
-                       part|
-                       preface|
-                       chapter|
-                       appendix|
-                       article|
-                       reference|
-                       refentry|
-                       book/glossary|
-                       article/glossary|
-                       part/glossary|
-                       bibliography|
-                       colophon"
-                priority="1">       
-  <!-- END OF OVERRIDE --> 
-    <xsl:choose>
-      <xsl:when test="$onechunk != 0 and parent::*">
-        <xsl:apply-imports/>
-      </xsl:when>
-      <xsl:otherwise>
-        <xsl:call-template name="process-chunk-element"/>
-      </xsl:otherwise>
-    </xsl:choose>
-  </xsl:template>
-
-  <!-- OVERRIDES xhtml-1_1/graphics.xsl   -->
-  <!-- Do _NOT_ output any xlink garbage, so if you don't have 
-       processor with extensions, you're screwed and we're terminating -->
-  <xsl:template match="inlinegraphic">
-    <xsl:variable name="filename">
-      <xsl:choose>
-        <xsl:when test="@entityref">
-          <xsl:value-of select="unparsed-entity-uri(@entityref)"/>
-        </xsl:when>
-        <xsl:otherwise>
-          <xsl:apply-templates select="@fileref"/>
-        </xsl:otherwise>
-      </xsl:choose>
-    </xsl:variable>
-
-    <xsl:call-template name="anchor"/>
-
-    <xsl:choose>
-      <xsl:when test="@format='linespecific'">
-        <xsl:choose>
-          <xsl:when test="$use.extensions != '0'                         and $textinsert.extension != '0'">
-            <xsl:choose>
-              <xsl:when test="element-available('stext:insertfile')">
-                <stext:insertfile href="{$filename}" encoding="{$textdata.default.encoding}"/>
-              </xsl:when>
-              <xsl:when test="element-available('xtext:insertfile')">
-                <xtext:insertfile href="{$filename}"/>
-              </xsl:when>
-              <xsl:otherwise>
-                <xsl:message terminate="yes">
-                  <xsl:text>No insertfile extension available.</xsl:text>
-                </xsl:message>
-              </xsl:otherwise>
-            </xsl:choose>
-          </xsl:when>
-          <xsl:otherwise>
-            <!-- AN OVERRIDE --> 
-            <xsl:message terminate="yes">
-              <xsl:text>No insertfile extension available. Use a different processor (with extensions) or turn on $use.extensions and $textinsert.extension (see docs for more).  </xsl:text>
-            </xsl:message>
-            <!-- END OF OVERRIDE --> 
-          </xsl:otherwise>
-        </xsl:choose>
-      </xsl:when>
-      <xsl:otherwise>
-        <xsl:call-template name="process.image"/>
-      </xsl:otherwise>
-    </xsl:choose>
-  </xsl:template>  
-
-  <xsl:template name="cover">
-    <xsl:apply-templates select="/*/*[contains(name(.), 'info')]//mediaobject[@role='cover' or ancestor::cover]"/>
-  </xsl:template>  
-
-  <xsl:template match="/*/*[cover or contains(name(.), 'info')]//mediaobject[@role='cover' or ancestor::cover]">
-    <xsl:call-template name="write.chunk">
-      <xsl:with-param name="filename">
-        <xsl:value-of select="$epub.cover.filename" />
-      </xsl:with-param>
-      <xsl:with-param name="method" select="'xml'" />
-      <xsl:with-param name="encoding" select="'utf-8'" />
-      <xsl:with-param name="indent" select="'no'" />
-      <xsl:with-param name="quiet" select="$chunk.quietly" />
-      <xsl:with-param name="content">
-        <xsl:element namespace="http://www.w3.org/1999/xhtml" name="html">
-          <xsl:element namespace="http://www.w3.org/1999/xhtml" name="head">
-            <xsl:element namespace="http://www.w3.org/1999/xhtml" name="title">Cover</xsl:element>
-            <xsl:element namespace="http://www.w3.org/1999/xhtml" name="style">
-              <xsl:attribute name="type">text/css</xsl:attribute>
-              <!-- Help the cover image scale nicely in the CSS then apply a max-width to look better in Adobe Digital Editions -->
-              <xsl:text> img { max-width: 100%; }</xsl:text>
-            </xsl:element>
-          </xsl:element>
-          <xsl:element namespace="http://www.w3.org/1999/xhtml" name="body">
-            <xsl:element namespace="http://www.w3.org/1999/xhtml" name="div">
-              <xsl:attribute name="id">
-                <xsl:value-of select="$epub.cover.image.id"/>
-              </xsl:attribute>
-              <xsl:choose>
-                <xsl:when test="imageobject[@role='front-large']">
-                  <xsl:apply-templates select="imageobject[@role='front-large']"/>
-                </xsl:when>
-                <xsl:otherwise>
-                  <xsl:apply-templates select="imageobject[1]"/>
-                </xsl:otherwise>
-              </xsl:choose>
-            </xsl:element>
-            <!-- If this is defined as an explicit cover page, then process
-            any remaining text -->
-            <xsl:if test="ancestor::cover">
-              <xsl:apply-templates select="ancestor::cover/para"/>
-            </xsl:if>
-          </xsl:element>
-        </xsl:element>
-      </xsl:with-param>  
-    </xsl:call-template>  
-  </xsl:template>
-
-  <xsl:template name="cover-svg">
-    <xsl:param name="node"/>
-  </xsl:template>
-
-  <xsl:template name="toc-href">
-    <xsl:param name="node" select="."/>
-    <xsl:apply-templates select="$node" mode="recursive-chunk-filename">
-      <xsl:with-param name="recursive" select="true()"/>
-    </xsl:apply-templates>
-    <xsl:text>-toc</xsl:text>
-    <xsl:value-of select="$html.ext"/>
-  </xsl:template>
-
-  <xsl:template match="bibliodiv[title]" mode="label.markup">
-  </xsl:template>
-
-  <xsl:template match="token" mode="opf.manifest.font">
-    <xsl:call-template name="embedded-font-item">
-      <xsl:with-param name="font.file" select="."/>
-    </xsl:call-template>
-  </xsl:template>
-
-  <xsl:template name="embedded-font-item">
-    <xsl:param name="font.file"/>
-    <xsl:param name="font.order" select="1"/>
-
-    <xsl:element namespace="http://www.idpf.org/2007/opf" name="item">
-      <xsl:attribute name="id">
-        <xsl:value-of select="concat('epub.embedded.font.', $font.order)"/>
-      </xsl:attribute>
-      <xsl:attribute name="href"><xsl:value-of select="$font.file"/></xsl:attribute>
-      <xsl:choose>
-        <xsl:when test="contains($font.file, 'otf')">
-          <xsl:attribute name="media-type">font/opentype</xsl:attribute>
-        </xsl:when>
-        <xsl:otherwise>
-          <xsl:message>
-            <xsl:text>WARNING: OpenType fonts should be supplied! (</xsl:text>
-            <xsl:value-of select="$font.file"/>
-            <xsl:text>)</xsl:text>
-          </xsl:message>
-        </xsl:otherwise>  
-      </xsl:choose>
-    </xsl:element>
-  </xsl:template>
-
-<!-- Change section.heading to improve SEO on generated HTML by doing heading levels 
-     "correctly". SEO rules are sometimes silly silly, but this does actually create 
-     a semantic improvement.
-     Note: This template needs to be manually maintained outside of the html/sections.xsl 
-     code, so make sure important changes get reintegrated. -->
-<xsl:template name="section.heading">
-  <xsl:param name="section" select="."/>
-  <xsl:param name="level" select="1"/>
-  <xsl:param name="allow-anchors" select="1"/>
-  <xsl:param name="title"/>
-  <xsl:param name="class" select="'title'"/>
-
-  <xsl:variable name="id">
-    <xsl:choose>
-      <!-- Make sure the subtitle doesn't get the same id as the title -->
-      <xsl:when test="self::subtitle">
-        <xsl:call-template name="object.id">
-          <xsl:with-param name="object" select="."/>
-        </xsl:call-template>
-      </xsl:when>
-      <!-- if title is in an *info wrapper, get the grandparent -->
-      <xsl:when test="contains(local-name(..), 'info')">
-        <xsl:call-template name="object.id">
-          <xsl:with-param name="object" select="../.."/>
-        </xsl:call-template>
-      </xsl:when>
-      <xsl:otherwise>
-        <xsl:call-template name="object.id">
-          <xsl:with-param name="object" select=".."/>
-        </xsl:call-template>
-      </xsl:otherwise>
-    </xsl:choose>
-  </xsl:variable>
-
-  <!-- For SEO, we try to actually ensure we *always* output one and only one h1,
-       so unlike the regular stylesheets, we don't add one to the section level and
-       we get the right behavior because of chunking. -->
-  <xsl:variable name="hlevel">
-    <xsl:choose>
-      <!-- highest valid HTML H level is H6; so anything nested deeper
-           than 7 levels down just becomes H6 -->
-      <xsl:when test="$level &gt; 6">6</xsl:when>
-      <xsl:otherwise>
-        <xsl:value-of select="$level"/>
-      </xsl:otherwise>
-    </xsl:choose>
-  </xsl:variable>
-  <xsl:element name="h{$hlevel}" namespace="http://www.w3.org/1999/xhtml">
-    <xsl:attribute name="class"><xsl:value-of select="$class"/></xsl:attribute>
-    <xsl:if test="$css.decoration != '0'">
-      <xsl:if test="$hlevel&lt;3">
-        <xsl:attribute name="style">clear: both</xsl:attribute>
-      </xsl:if>
-    </xsl:if>
-    <xsl:if test="$allow-anchors != 0 and $generate.id.attributes = 0">
-      <xsl:call-template name="anchor">
-        <xsl:with-param name="node" select="$section"/>
-        <xsl:with-param name="conditional" select="0"/>
-      </xsl:call-template>
-    </xsl:if>
-    <xsl:if test="$generate.id.attributes != 0 and not(local-name(.) = 'appendix')">
-      <xsl:attribute name="id"><xsl:value-of select="$id"/></xsl:attribute>
-    </xsl:if>
-    <xsl:copy-of select="$title"/>
-  </xsl:element>
-</xsl:template>
-
-<!-- ==================================================================== -->
-
-<xsl:template match="bridgehead">
-  <xsl:variable name="container" select="(ancestor::appendix                         |ancestor::article                         |ancestor::bibliography                         |ancestor::chapter                         |ancestor::glossary                         |ancestor::glossdiv                         |ancestor::index                         |ancestor::partintro                         |ancestor::preface                         |ancestor::refsect1                         |ancestor::refsect2                         |ancestor::refsect3                         |ancestor::sect1                         |ancestor::sect2                         |ancestor::sect3                         |ancestor::sect4                         |ancestor::sect5                         |ancestor::section                         |ancestor::setindex                         |ancestor::simplesect)[last()]"/>
-
-  <xsl:variable name="clevel">
-    <xsl:choose>
-      <xsl:when test="local-name($container) = 'appendix'                       or local-name($container) = 'chapter'                       or local-name($container) = 'article'                       or local-name($container) = 'bibliography'                       or local-name($container) = 'glossary'                       or local-name($container) = 'index'                       or local-name($container) = 'partintro'                       or local-name($container) = 'preface'                       or local-name($container) = 'setindex'">1</xsl:when>
-      <xsl:when test="local-name($container) = 'glossdiv'">
-        <xsl:value-of select="count(ancestor::glossdiv)+1"/>
-      </xsl:when>
-      <xsl:when test="local-name($container) = 'sect1'                       or local-name($container) = 'sect2'                       or local-name($container) = 'sect3'                       or local-name($container) = 'sect4'                       or local-name($container) = 'sect5'                       or local-name($container) = 'refsect1'                       or local-name($container) = 'refsect2'                       or local-name($container) = 'refsect3'                       or local-name($container) = 'section'                       or local-name($container) = 'simplesect'">
-        <xsl:variable name="slevel">
-          <xsl:call-template name="section.level">
-            <xsl:with-param name="node" select="$container"/>
-          </xsl:call-template>
-        </xsl:variable>
-        <xsl:value-of select="$slevel + 1"/>
-      </xsl:when>
-      <xsl:otherwise>1</xsl:otherwise>
-    </xsl:choose>
-  </xsl:variable>
-
-  <!-- HTML H level is one higher than section level -->
-  <xsl:variable name="hlevel">
-    <xsl:choose>
-      <xsl:when test="@renderas = 'sect1'">1</xsl:when>
-      <xsl:when test="@renderas = 'sect2'">2</xsl:when>
-      <xsl:when test="@renderas = 'sect3'">3</xsl:when>
-      <xsl:when test="@renderas = 'sect4'">4</xsl:when>
-      <xsl:when test="@renderas = 'sect5'">5</xsl:when>
-      <xsl:otherwise>
-        <xsl:value-of select="$clevel + 1"/>
-      </xsl:otherwise>
-    </xsl:choose>
-  </xsl:variable>
-
-  <xsl:element name="h{$hlevel}" namespace="http://www.w3.org/1999/xhtml">
-    <xsl:call-template name="anchor">
-      <xsl:with-param name="conditional" select="0"/>
-    </xsl:call-template>
-    <xsl:apply-templates/>
-  </xsl:element>
-</xsl:template>
-
-<!-- SEO customization #2 -->
-<xsl:template name="component.title">
-  <xsl:param name="node" select="."/>
-
-  <xsl:variable name="level">
-    <xsl:choose>
-      <xsl:when test="ancestor::section">
-        <xsl:value-of select="count(ancestor::section)+1"/>
-      </xsl:when>
-      <xsl:when test="ancestor::sect5">6</xsl:when>
-      <xsl:when test="ancestor::sect4">5</xsl:when>
-      <xsl:when test="ancestor::sect3">4</xsl:when>
-      <xsl:when test="ancestor::sect2">3</xsl:when>
-      <xsl:when test="ancestor::sect1">2</xsl:when>
-      <xsl:otherwise>1</xsl:otherwise>
-    </xsl:choose>
-  </xsl:variable>
-
-  <xsl:element name="h{$level}" namespace="http://www.w3.org/1999/xhtml">
-    <xsl:attribute name="class">title</xsl:attribute>
-    <xsl:if test="$generate.id.attributes = 0">
-      <xsl:call-template name="anchor">
-	<xsl:with-param name="node" select="$node"/>
-	<xsl:with-param name="conditional" select="0"/>
-      </xsl:call-template>
-    </xsl:if>
-      <xsl:apply-templates select="$node" mode="object.title.markup">
-      <xsl:with-param name="allow-anchors" select="1"/>
-    </xsl:apply-templates>
-  </xsl:element>
-</xsl:template>
-
-</xsl:stylesheet>

+ 0 - 329
stylesheets/lfs-xsl/docbook-xsl-1.78.1/epub3/README

@@ -1,329 +0,0 @@
-DocBook stylesheets for EPUB 3 output 
-=============================================
-
-This directory contains XSL stylesheets
-for generating EPUB3 output from DocBook content.
-For more information on EPUB3, see:
-
-http://idpf.org/epub/30
-
-These EPUB3 stylesheets are a customization layer on
-top of the xhtml5/ stylesheets in this distribution, which
-are in turn a customization layer on top of the 
-xhtml/ stylesheets in this distribution. 
-Using a customization layer enables the EPUB3
-stylesheets to inherit all the features of the
-XHTML stylesheets while making the minimum changes
-for them to produce valid EPUB3.
-
-Usage
------------
-The general process for creating an EPUB3 ebook is:
-
-1.  Generate chunked XHTML5 content that validates against
-the EPUB3 schemas, and generate the EPUB3 package
-files.
-
-2.  Copy any image files into the output directory.
-
-3.  Run a zip command to create an .epub file.
-
-4.  Validate the .epub file.
-
-
-Following are the steps in more detail.
-
-1.  Create the XHTML5 files.
------------------------------
-
-The first step is handled by these stylesheets.
-To generate EPUB3-compatible XHTML5 files,
-use one of the following stylesheets as you would any
-other DocBook XSL stylesheet:
-
-epub3/chunk.xsl           - Chunked output.
-epub3/profile-chunk.xsl   - Profiled chunk output.
-
-Although the stylesheet directory contains a docbook.xsl
-stylesheet for single file output, that is not useful for
-generated EPUB3.  
-
-You should set the $base.dir stylesheet param to the 
-subdirectory that will contain the .xhtml files and
-the epub package files.  Here is an example using xsltproc:
-
-xsltproc \
-  --stringparam base.dir ebook1/OEBPS/  \
-  epub3/chunk.xsl \
-  mybook.xml
-
-After processing a document with this setting, you should find
-the following output:
-
-ebook1/mimetype                - required mimetype file.
-ebook1/META-INF/container.xml  - required container file
-ebook1/OEBPS/package.opf       - required package file
-ebook1/OEBPS/toc.ncx           - optional NCX file for backwards compatibility
-ebook1/OEBPS/docbook-epub.css  - CSS file
-ebook1/OEBPS/*.xhtml           - The chunked content files.
-
-
-2.  Copy image files
----------------------------
-
-Manually copy any image files used in the document
-into the corresponding locations in the $base.dir
-directory.  For example, if your document contains:
-
-  <imagedata fileref="images/caution.png"/>
-
-In this example base.dir, you would copy the file to:
-
-  ebook1/OEBPS/images/caution.png
-
-You can get a list of image files from the manifest file
-named ebook1/OEBPS/package.opf that is created by the
-stylesheet.  It includes references to image files for
-callouts and admonitions if they are used in the output.
-Note that the header and footer images are turned off for
-EPUB3 output.
-
-
-3.  Create the epub3 file.
------------------------------
-Change to the directory containing the base.dir (ebook1
-in this example), and run the following zip command to
-create the epub file:
-
-zip -r -X mybook.epub mimetype META-INF OEBPS 
-
-The -r option means recursively include all directories.
-The -X option excludes extra file attributes (required by epub3).
-The "mybook.epub" in this example is the output file.
-The other three arguments must appear in this order.
-
-
-4.  Validating with epubcheck 3
------------------------------------
-
-There is a java program that can be used to check an
-epub3 file for conformance.  It is currently available 
-from this website:
-
-  http://code.google.com/p/epubcheck/wiki/EPUBCheck30
-
-That website provides a download link, and information on
-how to run the command.
-
-
-Testing with EPUB readers
-----------------------------
-The EPUB3 standard is not yet widely supported.  The output of
-these stylesheets has been tested in the following readers:
-
-Apple iBooks on an iPod and iPad.
-   - Handles videodata and audiodata.
-   - Does not format MathML yet.
-   - Handles SVG.
-
-Firefox browser with the EPUBReader version 1.4.10 add-on.
-   - Formats MathML nicely.
-   - Does not handle videodata or audiodata yet.
-   - Handles SVG.
-
-Ibis EPUB3 preview version
-   - Does not format MathML yet.
-   - Does not handle videodata or audiodata yet.
-   - Handles SVG with external viewer.
-
-
-EPUB metadata
-========================
-The info child of the document's root element is used
-by the stylesheet to create EPUB metadata.  Note that
-metadata is plain text, so element content is converted
-to text using the XSL normalize-space() function.
-
-Here is the current mapping of info elements to EPUB
-metadata.  Any others are ignored for metadata, but
-may appear on the EPUB HTML titlepage, depending on the
-titlepage customization.
-
-NOTE: the <dc:*> elements (not attributes of meta) duplicate
-the meta elements for backwards compatibility, per the
-EPUB3 specification.  They can be turned off with the 
-$epub.include.optional.metadata.dc.elements parameter.
-
-abstract
----------
-The content must be converted to a text string for the
-OPF metadata. The stylesheet converts only title, para,
-formalpara, and simpara children in an abstract.  All other
-child elements are ignored.  It puts any title first.
-The OPF output appears as:
-
-<meta property="dcterms:description">title: abstract text</meta>
-<dc:description>title: abstract text</dc:description>
-
-
-author
--------
-If uses a personname child, then it applies the
-DocBook XSL person.name template to arrange the name.
-Otherwise processes org or orgname into the content.
-Then it outputs:
-
-<meta id="meta-creator1" property="dcterms:creator">Firstname Surname</meta>
-<dc:creator id="pub-creator1">Firstname Surname</dc:creator>
-
-If there are multiple authors, the number in the id attribute
-is incremented each time.
-
-
-authorgroup
--------------
-Applies templates to all of its children.
-
-
-bibliocoverage
----------------
-<meta property="dcterms:coverage">bibliocoverage text</meta>
-<dc:coverage>bibliocoverage text</dc:coverage>
-
-
-biblioid
---------------
-This usually has @class="isbn" for the ISBN number.  It is used
-as the EPUB3 unique-identifier.  That isbn value
-is also output as follows:
-
-<meta id="meta-identifier" property="dcterms:identifier">urn:isbn:value</meta>
-<dc:identifier id="pub-identifier">urn:isbn:value</dc:identifier>
-
-A biblioid element with other class names are converted in a similar manner.
-
-
-bibliorelation
-----------------
-<meta property="dcterms:relation">bibliorelation text</meta>
-<dc:relation>bibliorelation text</dc:relation>
-
-
-bibliosource
-----------------
-<meta property="dcterms:source">bibliosource text</meta>
-<dc:source>bibliosource text</dc:source>
-
-
-collab
-------------
-If a personname child is used, then it calls the
-person.name template, otherwise is uses the orgname or
-collabname text.
-
-<meta property="dcterms:contributor">collab text</meta>
-<dc:contributor>collab text</dc:contributor>
-
-
-copyright
--------------
-Arranges the copyright elements into a text string with
-copyright symbol, dates, and holder, and then
-generates:
-
-<meta property="dcterms:right">Copyright text</meta>
-<dc:right>Copyright text</dc:right>
-
-Also, if there is no info/date element, then the copyright
-year is used to generate:
-
-<meta property="dcterms:date">year</meta>
-<dc:date>year</dc:date>
-
-
-corpauthor
-------------
-<meta id="meta-creator1" property="dcterms:creator">corpauthor text</meta>
-<dc:creator id="pub-creator1">corpauthor text</dc:creator>
-
-
-corpcredit
-------------
-<meta property="dcterms:contributor">corpcredit text</meta>
-<dc:contributor>corpcredit text</dc:contributor>
-
-
-date
--------------
-<meta property="dcterms:date">date text</meta>
-<dc:date>date text</dc:date>
-
-See also: copyright.
-
-
-editor
---------------
-If a personname child is used, then it calls the
-person.name template, otherwise is uses the orgname text.
-
-An editor can be considered as either a creator (when there
-is no author) or a contributor.  The stylesheet parameter
-'editor.property' can be set to either 'creator' or
-'contributor' (default) at runtime.  So the output is either:
-
-<meta property="dcterms:contributor">editor text</meta>
-<dc:contributor>editor text</dc:contributor>
-
-or
-
-<meta property="dcterms:creator">editor text</meta>
-<dc:creator>editor text</dc:creator>
-
-
-isbn, issn, etc.
------------------
-Handled like biblioid @class="isbn".
-
-
-keyword
------------
-<meta property="dcterms:subject">keyword text</meta>
-<dc:subject>keyword text</dc:subject>
-
-
-keywordset
-------------
-Applies templates to its children.
-
-
-othercredit
-------------
-Handled like collab.
-
-
-pubdate 
-------------
-Handled like date.
-
-
-publisher
---------------
-Applies templates only to publishername.
-
-
-publishername
----------------
-<meta property="dcterms:publisher">publishername text</meta>
-<dc:publisher>publishername text</dc:publisher>
-
-
-subjectset
---------------
-Applies templates to subject/subjecterm descendants.
-
-
-subjectterm
-------------------
-<meta property="dcterms:subject">subjecterm text</meta>
-<dc:subject>subjecterm text</dc:subject>
-

+ 0 - 29
stylesheets/lfs-xsl/docbook-xsl-1.78.1/epub3/chunk.xsl

@@ -1,29 +0,0 @@
-<?xml version="1.0" encoding="utf-8"?>
-<xsl:stylesheet 
-  xmlns:xsl="http://www.w3.org/1999/XSL/Transform" 
-  xmlns:exsl="http://exslt.org/common"
-  xmlns:epub="http://www.idpf.org/2007/ops"
-  exclude-result-prefixes="exsl"
-  version="1.0">
-
-<!-- $Id: chunk.xsl,v 1.1 2011-09-16 21:43:45 bobs Exp $ -->
-
-<!-- This is the main driver stylesheet file.  It imports or
-includes all the components that it needs. -->
-
-<!-- Import the module that customizes docbook elements -->
-<!-- Put any customizations of element content in this module. -->
-<xsl:import href="docbook.xsl"/>
-
-<xsl:import href="../xhtml/chunk-common.xsl"/>
-
-<xsl:include href="../xhtml/chunk-code.xsl"/>
-
-<!-- The following module has templates that override the stock
-     xhtml templates for HTML5 output.  
-     It contains match templates with priority="1" attributes,
-     and named templates.  These override any templates that
-     handle chunking behavior -->
-<xsl:include href="epub3-chunk-mods.xsl"/>
-
-</xsl:stylesheet>

+ 0 - 69
stylesheets/lfs-xsl/docbook-xsl-1.78.1/epub3/chunkfast.xsl

@@ -1,69 +0,0 @@
-<?xml version="1.0" encoding="ASCII"?>
-<!--This file was created automatically by html2xhtml-->
-<!--from the HTML stylesheets.-->
-<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" xmlns:exsl="http://exslt.org/common" xmlns:cf="http://docbook.sourceforge.net/xmlns/chunkfast/1.0" xmlns="http://www.w3.org/1999/xhtml" version="1.0" exclude-result-prefixes="cf exsl">
-
-<!-- ********************************************************************
-     $Id: chunkfast.xsl,v 1.1 2011-09-16 21:43:45 bobs Exp $
-     ********************************************************************
-
-     This file is part of the XSL DocBook Stylesheet distribution.
-     See ../README or http://docbook.sf.net/release/xsl/current/ for
-     copyright and other information.
-
-     ******************************************************************** -->
-
-<!-- ==================================================================== -->
-
-<xsl:import href="chunk.xsl"/>
-<xsl:param name="chunk.fast" select="1"/>
-
-<xsl:variable name="chunks" select="exsl:node-set($chunk.hierarchy)//cf:div"/>
-
-<!-- ==================================================================== -->
-
-<xsl:template name="process-chunk-element">
-  <xsl:choose>
-    <xsl:when test="$chunk.fast != 0 and $exsl.node.set.available != 0">
-      <xsl:variable name="genid" select="generate-id()"/>
-
-      <xsl:variable name="div" select="$chunks[@id=$genid or @xml:id=$genid]"/>
-
-      <xsl:variable name="prevdiv" select="($div/preceding-sibling::cf:div|$div/preceding::cf:div|$div/parent::cf:div)[last()]"/>
-      <xsl:variable name="prev" select="key('genid', ($prevdiv/@id|$prevdiv/@xml:id)[1])"/>
-
-      <xsl:variable name="nextdiv" select="($div/following-sibling::cf:div|$div/following::cf:div|$div/cf:div)[1]"/>
-      <xsl:variable name="next" select="key('genid', ($nextdiv/@id|$nextdiv/@xml:id)[1])"/>
-
-      <xsl:choose>
-        <xsl:when test="$onechunk != 0 and parent::*">
-          <xsl:apply-imports/>
-        </xsl:when>
-        <xsl:otherwise>
-          <xsl:call-template name="process-chunk">
-            <xsl:with-param name="prev" select="$prev"/>
-            <xsl:with-param name="next" select="$next"/>
-          </xsl:call-template>
-        </xsl:otherwise>
-      </xsl:choose>
-    </xsl:when>
-    <xsl:otherwise>
-      <xsl:choose>
-        <xsl:when test="$onechunk != 0 and not(parent::*)">
-          <xsl:call-template name="chunk-all-sections"/>
-        </xsl:when>
-        <xsl:when test="$onechunk != 0">
-          <xsl:apply-imports/>
-        </xsl:when>
-        <xsl:when test="$chunk.first.sections = 0">
-          <xsl:call-template name="chunk-first-section-with-parent"/>
-        </xsl:when>
-        <xsl:otherwise>
-          <xsl:call-template name="chunk-all-sections"/>
-        </xsl:otherwise>
-      </xsl:choose>
-    </xsl:otherwise>
-  </xsl:choose>
-</xsl:template>
-
-</xsl:stylesheet>

+ 0 - 142
stylesheets/lfs-xsl/docbook-xsl-1.78.1/epub3/docbook-epub.css.xml

@@ -1,142 +0,0 @@
-<?xml version="1.0"?>
-<style>
-
-/********************************/
-/* start of styles in block.xsl */
-
-.formalpara-title {
-  font-weight: bold;
-}
-
-div.blockquote-title {
-  font-weight: bold;
-  margin-top: 1em;
-  margin-bottom: 1em;
-}
-
-span.msgmain-title {
-  font-weight: bold;
-}
-
-span.msgsub-title {
-  font-weight: bold;
-}
-
-span.msgrel-title {
-  font-weight: bold;
-}
-
-div.msglevel, div.msgorig, div.msgaud {
-  margin-top: 1em;
-  margin-bottom: 1em;
-}
-
-span.msglevel-title, span.msgorig-title, span.msgaud-title {
-  font-weight: bold;
-}
-
-div.msgexplan {
-  margin-top: 1em;
-  margin-bottom: 1em;
-}
-
-span.msgexplan-title {
-  font-weight: bold;
-}
-
-div.sidebar {
-  border: 0.5pt solid black;
-  margin-top: 1em;
-  margin-bottom: 1em;
-  padding: 8px;
-}
-
-/* end of styles in block.xsl */
-/********************************/
-
-/********************************/
-/* start of styles in autotoc.xsl */
-
-/* top level entries */
-nav&gt;ol&gt;li&gt;a {
-  margin-top: 1em;
-  margin-bottom: 1em;
-}
-
-
-/* end of styles in autotoc.xsl */
-/********************************/
-
-/********************************/
-/* start of styles in formal.xsl */
-
-div.figure-title {
-  font-weight: bold;
-}
-
-div.example-title {
-  font-weight: bold;
-}
-
-div.equation-title {
-  font-weight: bold;
-}
-
-div.table-title {
-  font-weight: bold;
-}
-
-div.sidebar-title {
-  font-weight: bold;
-}
-
-
-/* end of styles in formal.xsl */
-/********************************/
-
-/********************************/
-/* start of styles in verbatim.xsl */
-
-div.programlisting {
-  white-space: pre-wrap;
-  font-family: monospace;
-}
-
-div.screen {
-  white-space: pre-wrap;
-  font-family: monospace;
-}
-
-div.synopsis {
-  white-space: pre-wrap;
-  font-family: monospace;
-}
-
-/* end of styles in verbatim.xsl */
-/********************************/
-
-/********************************/
-/* NAVIGATION */
-
-nav ol {
-list-style-type: none;
-margin: 0 0 0 2em;
-padding: 0 0 0 0;
-}
-
-nav ol li {
-margin: 0 0 0 0;
-padding: 0 0 0 0;
-}
-
-nav ol li a {
-text-decoration: none;
-color: black;
-font-family: sans-serif;
-}
-
-#guide {
-display: none;
-}
-
-</style>

+ 0 - 19
stylesheets/lfs-xsl/docbook-xsl-1.78.1/epub3/docbook.xsl

@@ -1,19 +0,0 @@
-<?xml version="1.0" encoding="utf-8"?>
-<!DOCTYPE xsl:stylesheet [
-<!ENTITY uppercase "'ABCDEFGHIJKLMNOPQRSTUVWXYZ'">
-<!ENTITY lowercase "'abcdefghijklmnopqrstuvwxyz'">
-]>
-
-<xsl:stylesheet 
-  xmlns:xsl="http://www.w3.org/1999/XSL/Transform" 
-  xmlns="http://www.w3.org/1999/xhtml"
-  exclude-result-prefixes="#default"
-  version="1.0">
-
-<!-- $Id: docbook.xsl,v 1.1 2011-09-16 21:43:45 bobs Exp $ -->
-
-<xsl:import href="../xhtml5/docbook.xsl"/>
-
-<xsl:include href="epub3-element-mods.xsl"/>
-
-</xsl:stylesheet>

+ 0 - 51
stylesheets/lfs-xsl/docbook-xsl-1.78.1/epub3/epub3-chunk-mods.xsl

@@ -1,51 +0,0 @@
-<?xml version="1.0" encoding="utf-8"?>
-<xsl:stylesheet 
-  xmlns:xsl="http://www.w3.org/1999/XSL/Transform" 
-  xmlns:exsl="http://exslt.org/common"
-  xmlns:epub="http://www.idpf.org/2007/ops"
-  xmlns:dc="http://purl.org/dc/elements/1.1/"  
-  xmlns:ncx="http://www.daisy.org/z3986/2005/ncx/"
-  xmlns:db="http://docbook.org/ns/docbook"
-  xmlns:opf="http://www.idpf.org/2007/opf"
-  xmlns:stext="http://nwalsh.com/xslt/ext/com.nwalsh.saxon.TextFactory"
-  xmlns:str="http://exslt.org/strings"
-  xmlns:xtext="xalan://com.nwalsh.xalan.Text"
-  extension-element-prefixes="stext xtext"
-  exclude-result-prefixes="exsl dc ncx opf stext str xtext"
-  version="1.0">
-
-<!-- $Id: epub3-chunk-mods.xsl,v 1.1 2011-09-16 21:43:45 bobs Exp $ -->
-
-<xsl:include href="../xhtml5/html5-chunk-mods.xsl"/>
-
-<!--==============================================================-->
-<!--  DocBook XSL Parameter settings                              -->
-<!--==============================================================-->
-
-<!--==============================================================-->
-<!--  Template customizations                                     -->
-<!--==============================================================-->
-
-<!-- EPUB3: customize to generate package files -->
-<xsl:template match="*" mode="process.root" priority="2">
-  <xsl:call-template name="check.for.xalan"/>
-  <xsl:apply-templates select="."/>
-  <xsl:call-template name="generate.css.files"/>
-
-  <xsl:call-template name="generate.epub.files"/>
-
-</xsl:template>
-
-<xsl:template name="check.for.xalan">
-  <xsl:if test="contains(system-property('xsl:vendor'), 'Apache Software Foundation')">
-    <xsl:message terminate="yes">
-      <xsl:text>&#10;</xsl:text>
-      <xsl:text>FATAL ERROR: </xsl:text>
-      <xsl:text>Xalan processor not supported by DocBook Epub3 stylesheets. </xsl:text>
-      <xsl:text>Xalan does not properly support XSL output method="text", </xsl:text>
-      <xsl:text>which is required for the various epub support files.</xsl:text>
-    </xsl:message>
-  </xsl:if>
-</xsl:template>
-
-</xsl:stylesheet>

+ 0 - 2506
stylesheets/lfs-xsl/docbook-xsl-1.78.1/epub3/epub3-element-mods.xsl

@@ -1,2506 +0,0 @@
-<?xml version="1.0" encoding="utf-8"?>
-<!DOCTYPE xsl:stylesheet [
-<!ENTITY uppercase "'ABCDEFGHIJKLMNOPQRSTUVWXYZ'">
-<!ENTITY lowercase "'abcdefghijklmnopqrstuvwxyz'">
-]>
-
-<xsl:stylesheet 
-  xmlns:xsl="http://www.w3.org/1999/XSL/Transform" 
-  xmlns:exsl="http://exslt.org/common"
-  xmlns:set="http://exslt.org/sets"
-  xmlns="http://www.w3.org/1999/xhtml"
-  xmlns:epub="http://www.idpf.org/2007/ops"
-  xmlns:m="http://www.w3.org/1998/Math/MathML"
-  xmlns:pls="http://www.w3.org/2005/01/pronunciation-lexicon"
-  xmlns:ssml="http://www.w3.org/2001/10/synthesis"
-  xmlns:svg="http://www.w3.org/2000/svg"
-  xmlns:opf="http://www.idpf.org/2007/opf"
-  xmlns:dc="http://purl.org/dc/elements/1.1/"  
-  xmlns:cf="http://docbook.sourceforge.net/xmlns/chunkfast/1.0"
-  xmlns:date="http://exslt.org/dates-and-times"
-  xmlns:dcterms="http://purl.org/dc/terms/"
-  xmlns:ncx="http://www.daisy.org/z3986/2005/ncx/"
-  xmlns:db="http://docbook.org/ns/docbook"
-  xmlns:stext="http://nwalsh.com/xslt/ext/com.nwalsh.saxon.TextFactory"
-  xmlns:str="http://exslt.org/strings"
-  xmlns:xtext="xalan://com.nwalsh.xalan.Text"
-
-  extension-element-prefixes="stext xtext"
-  exclude-result-prefixes="#default cf date db dc dcterms epub exsl m ncx opf pls set ssml stext str svg xtext"
-  version="1.0">
-
-<!-- $Id: epub3-element-mods.xsl,v 1.1 2011-09-16 21:43:45 bobs Exp $ -->
-
-<xsl:import href="titlepage.templates.xsl"/>
-
-<!--
-<xsl:key name="image-filerefs" match="graphic|inlinegraphic|imagedata" use="@fileref"/>
--->
-
-<!--==============================================================-->
-<!--  DocBook XSL Parameter settings                              -->
-<!--==============================================================-->
-<!-- separate file for toc -->
-<xsl:param name="chunk.tocs.and.lots" select="1"/>
-<xsl:param name="toc.section.depth" select="2"/>
-<xsl:param name="generate.toc">
-book  toc,title,figure,table,example,equation
-article  toc,title,figure,table,example,equation
-</xsl:param>
-<xsl:param name="generate.manifest" select="0"/>
-<xsl:param name="manifest.in.base.dir" select="1"/>
-<xsl:param name="base.dir" select="'OEBPS/'"/>
-<xsl:param name="index.links.to.section" select="0"/>
-
-<!-- Epub does not yet support external links -->
-<xsl:param name="activate.external.olinks" select="0"/>
-
-<!-- Turning this on crashes ADE, which is unbelievably awesome -->
-<xsl:param name="formal.object.break.after">0</xsl:param>
-
-<xsl:param name="callout.graphics" select="1"/>
-<xsl:param name="callout.graphics.extension">.png</xsl:param>
-<xsl:param name="callout.graphics.number.limit" select="15"/>
-<xsl:param name="callout.graphics.path" select="'images/callouts/'"/>
-<xsl:param name="show.comments" select="0"/>
-
-<!-- no navigation in .epub -->
-<xsl:param name="suppress.navigation" select="'1'"/> 
-
-<!-- EPUB3: use ol lists in table of contents -->
-<xsl:param name="toc.list.type">ol</xsl:param>
-<xsl:param name="autotoc.label.in.hyperlink" select="1"/>
-
-<xsl:param name="css.decoration" select="1"/>
-<!-- generate the css file from a source file -->
-<xsl:param name="make.clean.html" select="1"/>
-<!-- specify the default epub3 stylesheet -->
-<xsl:param name="docbook.css.source">docbook-epub.css.xml</xsl:param>
-<!-- for custom CSS, use the custom.css.source param -->
-<xsl:param name="custom.css.source"></xsl:param>
-
-<!--==============================================================-->
-<!--  New EPUB3 Parameters                                        -->
-<!--==============================================================-->
-<xsl:param name="epub.version">3.0</xsl:param>
-<!-- optional ncx for backwards compatibility -->
-<xsl:param name="epub.include.ncx" select="1"/>
-<xsl:param name="epub.ncx.depth">4</xsl:param> <!-- Not functional until http://code.google.com/p/epubcheck/issues/detail?id=70 is resolved -->
-<!-- currently optional duplicate dcterms properties, may be required in future -->
-<xsl:param name="epub.include.metadata.dcterms" select="1"/>
-<!-- optional guide element for backwards compatibility -->
-<xsl:param name="epub.include.guide" select="1"/>
-<!-- some dc: currently required, to be replaced in future version -->
-<xsl:param name="epub.include.metadata.dc.elements" select="1"/>
-<!-- Some dc: elements will remain optional according to the spec -->
-<xsl:param name="epub.include.optional.metadata.dc.elements" select="1"/>
-<xsl:param name="epub.autolabel" select="0"/>
-<xsl:param 
-  name="epub.vocabulary.profile.content">http://www.idpf.org/epub/30/profile/content/</xsl:param>
-<xsl:param 
-  name="epub.vocabulary.profile.package">http://www.idpf.org/epub/30/profile/package/</xsl:param>
-<xsl:param name="epub.output.epub.types" select="1"/>
-<xsl:param name="epub.oebps.dir" select="'OEBPS'"/> 
-<xsl:param name="epub.metainf.dir" select="'META-INF/'"/> 
-<xsl:param name="epub.ncx.filename" select="'toc.ncx'"/> 
-<xsl:param name="epub.mimetype.filename" select="'mimetype'"/> 
-<xsl:param name="epub.mimetype.value" select="'application/epub+zip'"/> 
-<xsl:param name="epub.container.filename" select="'container.xml'"/> 
-<xsl:param name="epub.package.filename" select="'package.opf'"/> 
-<xsl:param name="epub.cover.filename" select="concat('cover', $html.ext)"/> 
-<xsl:param name="epub.cover.linear" select="0" />
-
-<!-- names of id attributes used in package files -->
-<xsl:param name="epub.meta.identifier.id">meta-identifier</xsl:param> 
-<xsl:param name="epub.dc.identifier.id">pub-identifier</xsl:param> 
-<xsl:param name="epub.meta.title.id">meta-title</xsl:param> 
-<xsl:param name="epub.dc.title.id">pub-title</xsl:param> 
-<xsl:param name="epub.meta.language.id">meta-language</xsl:param> 
-<xsl:param name="epub.dc.language.id">pub-language</xsl:param> 
-<xsl:param name="epub.meta.creator.id">meta-creator</xsl:param> 
-<xsl:param name="epub.dc.creator.id">pub-creator</xsl:param> 
-<xsl:param name="epub.ncx.toc.id">ncxtoc</xsl:param>
-<xsl:param name="epub.ncx.manifest.id">ncx</xsl:param>
-<xsl:param name="epub.ncx.mediatype">application/x-dtbncx+xml</xsl:param>
-<xsl:param name="epub.xhtml.mediatype">application/xhtml+xml</xsl:param>
-<xsl:param name="epub.html.toc.id">htmltoc</xsl:param>
-<xsl:param name="epub.cover.filename.id" select="'cover'"/> 
-<xsl:param name="epub.cover.image.id" select="'cover-image'"/> 
-
-<xsl:param name="epub.embedded.fonts"></xsl:param>
-<xsl:param name="epub.namespace">http://www.idpf.org/2007/ops</xsl:param>
-<xsl:param name="opf.namespace">http://www.idpf.org/2007/opf</xsl:param>
-<xsl:param name="ncx.namespace">http://www.daisy.org/z3986/2005/ncx/</xsl:param>
-<xsl:param name="dc.namespace">http://purl.org/dc/elements/1.1/</xsl:param>
-<!-- prefix generated ids in package elements so they differ from content ids -->
-<xsl:param name="epub.package.id.prefix">id-</xsl:param>
-<!-- editor is either a creator or contributor -->
-<xsl:param name="editor.property">contributor</xsl:param> 
-
-<!-- Generate full output path -->
-<xsl:param name="epub.package.dir" select="concat($chunk.base.dir, '../')"/>
-
-<xsl:param name="epub.ncx.pathname" 
-           select="concat($chunk.base.dir, $epub.ncx.filename)"/>
-<xsl:param name="epub.container.pathname"
-           select="concat($epub.package.dir, $epub.metainf.dir, 
-           $epub.container.filename)"/>
-<xsl:param name="epub.package.pathname"
-           select="concat($chunk.base.dir, $epub.package.filename)"/>
-<xsl:param name="epub.cover.pathname"
-           select="concat($chunk.base.dir, $epub.cover.filename)"/>
-<xsl:param name="epub.mimetype.pathname"
-           select="concat($epub.package.dir, $epub.mimetype.filename)"/>
-
-<xsl:param name="kindle.extensions" select="0"/>
-
-<!--==============================================================-->
-<!--  Internal variables used for computing certain metadata      -->
-<!--==============================================================-->
-<xsl:variable name="epub3.chunk.hierarchy">
-  <xsl:apply-templates select="/*" mode="find.chunks"/>
-</xsl:variable>
-
-<xsl:variable name="chunkset" select="exsl:node-set($epub3.chunk.hierarchy)//cf:div"/>
-
-<!--==============================================================-->
-<!--  Template customizations                                     -->
-<!--==============================================================-->
-
-<!-- This is used only by ncx piece -->
-<xsl:variable name="root.is.a.chunk">
-  <xsl:choose>
-    <xsl:when test="/*[not(self::book)][not(sect1) or not(section)]">
-      <xsl:text>1</xsl:text>
-    </xsl:when>
-    <xsl:when test="/book[*[last()][self::bookinfo]]|book[bookinfo]">
-      <xsl:text>1</xsl:text>
-    </xsl:when>
-    <xsl:when test="/book[*[last()][self::info]]|book[info]">
-      <xsl:text>1</xsl:text>
-    </xsl:when>
-    <xsl:when test="/bibliography">
-      <xsl:text>1</xsl:text>
-    </xsl:when>
-    <xsl:otherwise>
-      <xsl:text>0</xsl:text>
-    </xsl:otherwise>
-  </xsl:choose>
-</xsl:variable>
-
-<!-- EPUB3: Add generation of epub publication files -->
-<xsl:template match="*" mode="process.root">
-  <xsl:variable name="doc" select="self::*"/>
-
-  <xsl:call-template name="user.preroot"/>
-  <xsl:call-template name="root.messages"/>
-
-  <html>
-    <head>
-      <xsl:call-template name="system.head.content">
-        <xsl:with-param name="node" select="$doc"/>
-      </xsl:call-template>
-      <xsl:call-template name="head.content">
-        <xsl:with-param name="node" select="$doc"/>
-      </xsl:call-template>
-      <xsl:call-template name="user.head.content">
-        <xsl:with-param name="node" select="$doc"/>
-      </xsl:call-template>
-    </head>
-    <body>
-      <xsl:call-template name="body.attributes"/>
-      <xsl:call-template name="user.header.content">
-        <xsl:with-param name="node" select="$doc"/>
-      </xsl:call-template>
-      <xsl:apply-templates select="."/>
-      <xsl:call-template name="user.footer.content">
-        <xsl:with-param name="node" select="$doc"/>
-      </xsl:call-template>
-    </body>
-  </html>
-  <xsl:value-of select="$html.append"/>
-  
-  <!-- Generate any css files only once, not once per chunk -->
-  <xsl:call-template name="generate.css.files"/>
-
-  <xsl:call-template name="generate.epub.files"/>
-
-</xsl:template>
-
-<xsl:template name="generate.epub.files">
-  <!-- Generate epub3 files -->
-  <xsl:message>
-    <xsl:text>Generating EPUB package files.</xsl:text>
-  </xsl:message>
-
-  <xsl:apply-templates select="." mode="opf"/>
-  <xsl:apply-templates select="." mode="container"/>
-  <xsl:call-template name="mimetype"/>
-  <xsl:if test="$epub.include.ncx != 0">
-    <xsl:call-template name="ncx"/>
-  </xsl:if>
-</xsl:template>
-
-<!-- Generate the package file -->
-<xsl:template match="*" mode="opf">
-
-  <xsl:variable name="lang">
-    <xsl:call-template name="l10n.language"/>
-  </xsl:variable>
-
-  <xsl:variable name="content">
-    <!-- use xsl:element so output does not have a namespace prefix -->
-    <xsl:element name="package" namespace="{$opf.namespace}">
-      <!-- Add the package namespaces at the top -->
-      <xsl:call-template name="add.package.namespaces"/>
-
-      <xsl:attribute name="version">
-        <xsl:value-of select="$epub.version"/>
-      </xsl:attribute>
-      <xsl:attribute name="xml:lang">
-        <xsl:value-of select="$lang"/>
-      </xsl:attribute>
-      <!-- No profile att in 2011-09-06 spec 
-      <xsl:attribute name="profile">
-        <xsl:value-of select="$epub.vocabulary.profile.package"/>
-      </xsl:attribute>
-      -->
-      <xsl:attribute name="unique-identifier">
-        <xsl:value-of select="$epub.dc.identifier.id"/>
-      </xsl:attribute>
-
-
-      <xsl:call-template name="package.metadata"/>
-      <xsl:call-template name="package.manifest"/>
-      <xsl:call-template name="package.spine"/>
-
-      <xsl:if test="$epub.include.guide != 0">
-        <xsl:call-template name="package.guide"/>
-      </xsl:if>
-
-    </xsl:element>
-  </xsl:variable>
-
-  <xsl:call-template name="write.chunk">
-    <xsl:with-param name="filename">
-      <xsl:value-of select="$epub.package.pathname" />
-    </xsl:with-param>
-    <xsl:with-param name="content" select="$content"/>
-    <xsl:with-param name="method" select="'xml'" />
-    <xsl:with-param name="encoding" select="'utf-8'" />
-    <xsl:with-param name="indent" select="'yes'" />
-    <xsl:with-param name="quiet" select="$chunk.quietly" />
-    <xsl:with-param name="doctype-public" select="''"/> <!-- intentionally blank -->
-    <xsl:with-param name="doctype-system" select="''"/> <!-- intentionally blank -->
-  </xsl:call-template>
-</xsl:template>
-
-<xsl:template name="package.metadata">
-
-  <xsl:element name="metadata" namespace="{$opf.namespace}">
-
-    <xsl:call-template name="metadata.identifier"/>
-    <xsl:call-template name="metadata.title"/>
-    <xsl:call-template name="metadata.language"/>
-    <xsl:call-template name="metadata.modified"/>
-    <xsl:call-template name="metadata.cover"/>
-    <xsl:call-template name="metadata.other.info"/>
-    
-  </xsl:element>
-</xsl:template>
-
-<xsl:template name="doc.title">
-  <xsl:apply-templates select="." mode="title.markup"/>
-</xsl:template>
-
-<xsl:template name="metadata.identifier">
-  <xsl:variable name="package.id.value">
-    <xsl:call-template name="package-identifier"/>
-  </xsl:variable>
-
-  <xsl:if test="$epub.include.metadata.dc.elements != 0">
-    <!-- dc:identifier element -->
-    <dc:identifier>
-      <xsl:attribute name="id">
-        <xsl:value-of select="$epub.dc.identifier.id"/>
-      </xsl:attribute>
-      <!--
-      <xsl:attribute name="prefer">
-        <xsl:value-of select="$epub.meta.identifier.id"/>
-      </xsl:attribute>
-      -->
-      <xsl:copy-of select="$package.id.value"/>
-    </dc:identifier>
-  </xsl:if>
-
-  <xsl:if test="$epub.include.metadata.dcterms != 0">
-    <!-- equivalent meta identifier element -->
-    <xsl:element name="meta" namespace="{$opf.namespace}">
-      <xsl:attribute name="id">
-        <xsl:value-of select="$epub.meta.identifier.id"/>
-      </xsl:attribute>
-      <xsl:attribute name="property">dcterms:identifier</xsl:attribute>
-      <xsl:copy-of select="$package.id.value"/>
-    </xsl:element>
-  </xsl:if>
-</xsl:template>
-
-<xsl:template name="metadata.title">
-  <xsl:variable name="doc.title">
-    <xsl:call-template name="doc.title"/>
-  </xsl:variable>
-
-  <xsl:if test="$epub.include.metadata.dc.elements != 0">
-    <dc:title>
-      <xsl:attribute name="id">
-        <xsl:value-of select="$epub.dc.title.id"/>
-      </xsl:attribute>
-      <!--
-      <xsl:attribute name="prefer">
-        <xsl:value-of select="$epub.meta.title.id"/>
-      </xsl:attribute>
-      -->
-      <xsl:value-of select="normalize-space($doc.title)"/>
-    </dc:title>
-  </xsl:if>
-
-  <xsl:if test="$epub.include.metadata.dcterms != 0">
-  <!-- equivalent meta title element -->
-    <xsl:element name="meta" namespace="{$opf.namespace}">
-      <xsl:attribute name="property">dcterms:title</xsl:attribute>
-      <xsl:attribute name="id">
-        <xsl:value-of select="$epub.meta.title.id"/>
-      </xsl:attribute>
-      <xsl:value-of select="normalize-space($doc.title)"/>
-    </xsl:element>
-  </xsl:if>
-</xsl:template>
-
-<xsl:template name="metadata.language">
-  <xsl:variable name="lang">
-    <xsl:call-template name="l10n.language"/>
-  </xsl:variable>
-
-  <xsl:if test="$epub.include.metadata.dc.elements != 0">
-    <dc:language>
-      <xsl:if test="$kindle.extensions = 0">
-        <xsl:attribute name="id">
-          <xsl:value-of select="$epub.dc.language.id"/>
-        </xsl:attribute>
-      </xsl:if>
-      <xsl:value-of select="$lang"/>
-    </dc:language>
-  </xsl:if>
-
-  <xsl:if test="$epub.include.metadata.dcterms != 0">
-  <!-- equivalent meta lang element -->
-    <xsl:element name="meta" namespace="{$opf.namespace}">
-      <xsl:attribute name="property">dcterms:language</xsl:attribute>
-      <xsl:attribute name="id">
-        <xsl:value-of select="$epub.meta.language.id"/>
-      </xsl:attribute>
-      <xsl:value-of select="$lang"/>
-    </xsl:element>
-  </xsl:if>
-</xsl:template>
-  
-<xsl:template name="metadata.modified">
-  <xsl:variable name="local.datetime" select="date:date-time()"/>
-  <xsl:variable name="utc.datetime">
-    <xsl:call-template name="convert.date.to.utc">
-      <xsl:with-param name="date" select="$local.datetime"/>
-    </xsl:call-template>
-  </xsl:variable>
-  <xsl:choose>
-    <xsl:when test="string-length($utc.datetime) != 0">
-      <xsl:element name="meta" namespace="{$opf.namespace}">
-        <xsl:attribute name="property">dcterms:modified</xsl:attribute>
-        <xsl:value-of select="$utc.datetime"/>
-      </xsl:element>
-      <xsl:comment>The preceding date value is actually local time (not UTC) in UTC format because there is no function in XSLT 1.0 to generate a correct UTC time</xsl:comment>
-    </xsl:when>
-    <xsl:otherwise>
-      <xsl:message terminate="yes">
-        <xsl:text>ERROR: no last-modified date value could be determined, </xsl:text>
-        <xsl:text>so cannot output required meta element with </xsl:text>
-        <xsl:text>dcterms:modified attribute. Exiting.</xsl:text>
-      </xsl:message>
-    </xsl:otherwise>
-  </xsl:choose>
-</xsl:template>
-
-<xsl:template name="convert.date.to.utc">
-  <xsl:param name="date" select="''"/>
-  <!-- input format is YYYY-MM-DDTHH:MM:SS-X:00
-     where -X:00 is the offset from UTC. -->
-
-  <!-- output format is YYYY-MM-DDTHH:MM:SSZ with no offset -->
-  <!-- FIX ME:  Not so easy without a proper UTC date function. -->
-  <!-- Currently it just converts the local time to this format, which is
-       not the correct UTC time. -->
-  <xsl:value-of select="concat(substring($date,1,19), 'Z')"/>
-</xsl:template>
-
-<!-- This cover meta element used by kindlegen, at least -->
-<xsl:template name="metadata.cover">
-  <xsl:variable name="info" select="./*[contains(local-name(.), 'info')][1]"/>
-  <xsl:variable name="cover.image" 
-                select="$info//mediaobject[@role='cover' or ancestor::cover]"/>
-
-  <xsl:if test="$cover.image">
-    <xsl:element name="meta" namespace="{$opf.namespace}">
-      <xsl:attribute name="content">
-        <xsl:value-of select="$epub.cover.image.id"/>
-      </xsl:attribute>
-      <xsl:attribute name="name">cover</xsl:attribute>
-    </xsl:element>
-  </xsl:if>
-</xsl:template>
-
-<xsl:template name="metadata.other.info">
-  <!-- Take info relative to selected root element -->
-  <xsl:variable name="info" select="./*[contains(local-name(.), 'info')][1]"/>
-
-  <xsl:apply-templates select="$info/*" mode="opf.metadata"/>        
-</xsl:template>
-
-<xsl:template match="*" mode="opf.metadata">
-  <!-- default is no output -->
-</xsl:template>
-
-<xsl:template match="authorgroup" mode="opf.metadata">
-  <xsl:apply-templates select="*" mode="opf.metadata"/>
-</xsl:template>
-
-<xsl:template match="author|corpauthor" mode="opf.metadata">
-  <xsl:variable name="n">
-    <xsl:choose>
-      <xsl:when test="self::corpauthor">
-        <xsl:apply-templates/>
-      </xsl:when>
-      <xsl:when test="org/orgname">
-        <xsl:apply-templates select="org/orgname"/>
-      </xsl:when>
-      <xsl:when test="orgname">
-        <xsl:apply-templates select="orgname"/>
-      </xsl:when>
-      <xsl:otherwise>
-        <xsl:call-template name="person.name">
-          <xsl:with-param name="node" select="."/>
-        </xsl:call-template>
-      </xsl:otherwise>
-    </xsl:choose>
-  </xsl:variable>
-
-  <xsl:if test="string-length($n) != 0">
-    <xsl:element name="meta" namespace="{$opf.namespace}">
-      <xsl:attribute name="id">
-        <xsl:value-of select="concat($epub.meta.creator.id, position())"/>
-      </xsl:attribute>
-      <xsl:attribute name="property">dcterms:creator</xsl:attribute>
-      <xsl:value-of select="normalize-space(string($n))"/>
-    </xsl:element>
-
-    <xsl:if test="$epub.include.optional.metadata.dc.elements != 0">
-      <dc:creator>
-        <xsl:attribute name="id">
-          <xsl:value-of select="concat($epub.dc.creator.id, position())"/>
-        </xsl:attribute>
-        <xsl:value-of select="$n"/>
-      </dc:creator>
-    </xsl:if>
-  </xsl:if>
-</xsl:template>
-
-<xsl:template match="editor" mode="opf.metadata">
-  <xsl:variable name="n">
-    <xsl:choose>
-      <xsl:when test="orgname">
-        <xsl:apply-templates select="orgname"/>
-      </xsl:when>
-      <xsl:otherwise>
-        <xsl:call-template name="person.name">
-          <xsl:with-param name="node" select="."/>
-        </xsl:call-template>
-      </xsl:otherwise>
-    </xsl:choose>
-  </xsl:variable>
-
-  <xsl:variable name="name">
-    <xsl:choose>
-      <xsl:when test="string-length($editor.property) != 0">
-        <xsl:value-of select="$editor.property"/>
-      </xsl:when>
-      <xsl:otherwise>
-        <xsl:text>contributor</xsl:text>
-      </xsl:otherwise>
-    </xsl:choose>
-  </xsl:variable>
-
-  <xsl:element name="meta" namespace="{$opf.namespace}">
-    <xsl:attribute name="property">
-      <xsl:text>dcterms:</xsl:text>
-      <xsl:value-of select="$name"/>
-    </xsl:attribute>
-    <xsl:value-of select="normalize-space($n)"/>
-  </xsl:element>
-
-  <xsl:if test="$epub.include.optional.metadata.dc.elements != 0">
-    <xsl:choose>
-      <xsl:when test="$name = 'creator'">
-        <dc:creator>
-          <xsl:value-of select="normalize-space($n)"/>
-        </dc:creator>
-      </xsl:when>
-      <xsl:when test="$name = 'contributor'">
-        <dc:contributor>
-          <xsl:value-of select="normalize-space($n)"/>
-        </dc:contributor>
-      </xsl:when>
-      <xsl:otherwise>
-        <xsl:element namespace="{$dc.namespace}" name="{$name}">
-          <xsl:value-of select="normalize-space($n)"/>
-        </xsl:element>
-      </xsl:otherwise>
-    </xsl:choose>
-  </xsl:if>
-
-</xsl:template>
-
-<xsl:template match="corpcredit" mode="opf.metadata">
-  <xsl:element name="meta" namespace="{$opf.namespace}">
-    <xsl:attribute name="property">dcterms:contributor</xsl:attribute>
-    <xsl:value-of select="normalize-space(.)"/>
-  </xsl:element>
-
-  <xsl:if test="$epub.include.optional.metadata.dc.elements != 0">
-    <dc:contributor>
-      <xsl:value-of select="normalize-space(.)"/>
-    </dc:contributor>
-  </xsl:if>
-</xsl:template>
-
-<xsl:template match="collab|othercredit" mode="opf.metadata">
-  <xsl:variable name="content">
-    <xsl:choose>
-      <xsl:when test="collabname">
-        <xsl:apply-templates select="collabname"/>
-      </xsl:when>
-      <xsl:when test="org/orgname">
-        <xsl:apply-templates select="org/orgname"/>
-      </xsl:when>
-      <xsl:when test="orgname">
-        <xsl:apply-templates select="orgname"/>
-      </xsl:when>
-      <xsl:when test="personname|firstname|surname|othername">
-        <xsl:call-template name="person.name"/>
-      </xsl:when>
-      <xsl:otherwise>
-        <xsl:value-of select="."/>
-      </xsl:otherwise>
-    </xsl:choose>
-  </xsl:variable>
-
-  <xsl:element name="meta" namespace="{$opf.namespace}">
-    <xsl:attribute name="property">dcterms:contributor</xsl:attribute>
-    <xsl:value-of select="normalize-space($content)"/>
-  </xsl:element>
-
-  <xsl:if test="$epub.include.optional.metadata.dc.elements != 0">
-    <dc:contributor>
-      <xsl:value-of select="normalize-space($content)"/>
-    </dc:contributor>
-  </xsl:if>
-
-</xsl:template>
-
-<xsl:template match="date|pubdate" mode="opf.metadata">
-  <xsl:variable name="date">
-    <xsl:call-template name="format.meta.date">
-      <xsl:with-param name="string" select="normalize-space(.)"/>
-    </xsl:call-template>
-  </xsl:variable>
-
-  <xsl:if test="string-length($date) != 0">
-    <xsl:element name="meta" namespace="{$opf.namespace}">
-      <xsl:attribute name="property">dcterms:date</xsl:attribute>
-      <xsl:value-of select="$date"/>
-    </xsl:element>
-  
-    <xsl:if test="$epub.include.optional.metadata.dc.elements != 0">
-      <dc:date>
-        <xsl:value-of select="$date"/>
-      </dc:date>
-    </xsl:if>
-  </xsl:if>
-
-</xsl:template>
-
-<!-- EPUB3 meta date should be of the form:
-  YYYY, YYYY-MM or YYYY-MM-DD -->
-<xsl:template name="format.meta.date">
-  <xsl:param name="string" select="''"/>
-  <xsl:param name="node" select="."/>
-  
-  <!-- FIXME: this needs further work, so just check the
-  string format and return the date string for now -->
-  <xsl:variable name="normalized" 
-                select="translate($string, '0123456789', '##########')"/>
-
-  <xsl:variable name="date.ok">
-    <xsl:choose>
-      <xsl:when test="string-length($string) = 4 and
-                      $normalized = '####'">1</xsl:when>
-      <xsl:when test="string-length($string) = 7 and
-                      $normalized = '####-##'">1</xsl:when>
-      <xsl:when test="string-length($string) = 10 and
-                      $normalized = '####-##-##'">1</xsl:when>
-      <xsl:when test="string-length($string) = 10 and
-                      $normalized = '####-##-##'">1</xsl:when>
-      <xsl:otherwise>0</xsl:otherwise>
-    </xsl:choose>
-  </xsl:variable>
-
-  <xsl:if test="$date.ok = 0">
-    <xsl:message>
-      <xsl:text>WARNING: wrong metadata date format: '</xsl:text>
-      <xsl:value-of select="$string"/>
-      <xsl:text>' in element </xsl:text>
-      <xsl:value-of select="local-name($node/..)"/>
-      <xsl:text>/</xsl:text>
-      <xsl:value-of select="local-name($node)"/>
-      <xsl:text>. It must be in one of these forms: </xsl:text>
-      <xsl:text>YYYY, YYYY-MM, or YYYY-MM-DD.</xsl:text>
-    </xsl:message>
-  </xsl:if>
-
-  <!-- return the string anyway -->
-  <xsl:value-of select="$string"/>
-
-</xsl:template>
-
-
-<!-- Space separate the compontents of the abstract (dropping the inline markup, sadly) -->
-<xsl:template match="abstract" mode="opf.metadata">
-  <xsl:variable name="content">
-    <xsl:for-each select="formalpara|para|simpara|title">
-      <xsl:choose>
-        <xsl:when test="self::formalpara">
-          <xsl:value-of select="normalize-space(string(title))"/>
-          <xsl:text>: </xsl:text>
-          <xsl:value-of select="normalize-space(string(para))"/>
-        </xsl:when>
-        <xsl:otherwise>
-          <xsl:value-of select="normalize-space(string(.))"/>
-        </xsl:otherwise>  
-      </xsl:choose>
-      <xsl:if test="self::title">
-        <xsl:text>:</xsl:text>
-      </xsl:if>
-      <xsl:if test="not(position() = last())">
-        <xsl:text> </xsl:text>
-      </xsl:if>
-    </xsl:for-each>  
-  </xsl:variable>
-
-  <xsl:element name="meta" namespace="{$opf.namespace}">
-    <xsl:attribute name="property">dcterms:description</xsl:attribute>
-    <xsl:copy-of select="$content"/>
-  </xsl:element>
-
-  <xsl:if test="$epub.include.optional.metadata.dc.elements != 0">
-    <dc:description>
-      <xsl:copy-of select="$content"/>
-    </dc:description>
-  </xsl:if>
-</xsl:template>
-
-<xsl:template match="subjectset" mode="opf.metadata">
-  <xsl:apply-templates select="subject/subjectterm" mode="opf.metadata"/>
-</xsl:template>
-
-<xsl:template match="subjectterm" mode="opf.metadata">
-  <xsl:element name="meta" namespace="{$opf.namespace}">
-    <xsl:attribute name="property">dcterms:subject</xsl:attribute>
-    <xsl:value-of select="normalize-space(string(.))"/>
-  </xsl:element>
-
-  <xsl:if test="$epub.include.optional.metadata.dc.elements != 0">
-    <dc:subject>
-      <xsl:value-of select="normalize-space(string(.))"/>
-    </dc:subject>
-  </xsl:if>
-</xsl:template>
-
-<xsl:template match="keywordset" mode="opf.metadata">
-  <xsl:apply-templates select="keyword" mode="opf.metadata"/>
-</xsl:template>
-
-<xsl:template match="keyword" mode="opf.metadata">
-  <xsl:element name="meta" namespace="{$opf.namespace}">
-    <xsl:attribute name="property">dcterms:subject</xsl:attribute>
-    <xsl:value-of select="normalize-space(string(.))"/>
-  </xsl:element>
-
-  <xsl:if test="$epub.include.optional.metadata.dc.elements != 0">
-    <dc:subject>
-      <xsl:value-of select="normalize-space(string(.))"/>
-    </dc:subject>
-  </xsl:if>
-</xsl:template>
-
-<xsl:template match="publisher" mode="opf.metadata">
-  <xsl:apply-templates select="publishername" mode="opf.metadata"/>
-</xsl:template>
-
-<xsl:template match="publishername" mode="opf.metadata">
-  <xsl:element name="meta" namespace="{$opf.namespace}">
-    <xsl:attribute name="property">dcterms:publisher</xsl:attribute>
-    <xsl:value-of select="normalize-space(string(.))"/>
-  </xsl:element>
-
-  <xsl:if test="$epub.include.optional.metadata.dc.elements != 0">
-    <dc:publisher>
-      <xsl:value-of select="normalize-space(string(.))"/>
-    </dc:publisher>
-  </xsl:if>
-</xsl:template>
-
-<xsl:template match="bibliocoverage" mode="opf.metadata">
-  <xsl:element name="meta" namespace="{$opf.namespace}">
-    <xsl:attribute name="property">dcterms:coverage</xsl:attribute>
-    <xsl:value-of select="normalize-space(string(.))"/>
-  </xsl:element>
-
-  <xsl:if test="$epub.include.optional.metadata.dc.elements != 0">
-    <dc:coverage>
-      <xsl:value-of select="normalize-space(string(.))"/>
-    </dc:coverage>
-  </xsl:if>
-</xsl:template>
-
-<xsl:template match="bibliorelation" mode="opf.metadata">
-  <xsl:element name="meta" namespace="{$opf.namespace}">
-    <xsl:attribute name="property">dcterms:relation</xsl:attribute>
-    <xsl:value-of select="normalize-space(string(.))"/>
-  </xsl:element>
-
-  <xsl:if test="$epub.include.optional.metadata.dc.elements != 0">
-    <dc:relation>
-      <xsl:value-of select="normalize-space(string(.))"/>
-    </dc:relation>
-  </xsl:if>
-</xsl:template>
-
-<xsl:template match="bibliosource" mode="opf.metadata">
-  <xsl:element name="meta" namespace="{$opf.namespace}">
-    <xsl:attribute name="property">dcterms:source</xsl:attribute>
-    <xsl:value-of select="normalize-space(string(.))"/>
-  </xsl:element>
-
-  <xsl:if test="$epub.include.optional.metadata.dc.elements != 0">
-    <dc:source>
-      <xsl:value-of select="normalize-space(string(.))"/>
-    </dc:source>
-  </xsl:if>
-</xsl:template>
-
-<xsl:template match="copyright" mode="opf.metadata">
-  <xsl:variable name="copyright.date">
-    <xsl:call-template name="copyright.years">
-      <xsl:with-param name="years" select="year"/>
-      <xsl:with-param name="print.ranges" select="$make.year.ranges"/>
-      <xsl:with-param name="single.year.ranges" select="$make.single.year.ranges"/>
-    </xsl:call-template>
-  </xsl:variable>
-
-  <!-- if no docbook date element, use copyright year for single date metadata -->
-  <xsl:if test="not(../date)">
-    <xsl:variable name="date.content">
-      <xsl:call-template name="format.meta.date">
-        <xsl:with-param name="string">
-          <xsl:call-template name="copyright.years">
-            <xsl:with-param name="years" select="year[last()]"/>
-            <xsl:with-param name="print.ranges" select="0"/>
-            <xsl:with-param name="single.year.ranges" select="0"/>
-          </xsl:call-template>
-        </xsl:with-param>
-      </xsl:call-template>
-    </xsl:variable>
-    <xsl:element name="meta" namespace="{$opf.namespace}">
-      <xsl:attribute name="property">dcterms:date</xsl:attribute>
-      <xsl:copy-of select="$date.content"/>
-    </xsl:element>
-    <xsl:if test="$epub.include.optional.metadata.dc.elements != 0">
-      <dc:date>
-        <xsl:copy-of select="$date.content"/>
-      </dc:date>
-    </xsl:if>
-  </xsl:if>
-
-  <xsl:variable name="rights.content">
-    <xsl:call-template name="gentext">
-      <xsl:with-param name="key" select="'Copyright'"/>
-    </xsl:call-template>
-    <xsl:call-template name="gentext.space"/>
-    <xsl:text>&#x00A9;</xsl:text>
-    <xsl:call-template name="gentext.space"/>
-    <xsl:value-of select="$copyright.date"/>
-    <xsl:call-template name="gentext.space"/>
-    <xsl:apply-templates select="holder" mode="titlepage.mode"/>
-  </xsl:variable>
-
-  <xsl:element name="meta" namespace="{$opf.namespace}">
-    <xsl:attribute name="property">dcterms:rights</xsl:attribute>
-    <xsl:copy-of select="$rights.content"/>
-  </xsl:element>
-  <xsl:if test="$epub.include.optional.metadata.dc.elements != 0">
-    <dc:rights>
-      <xsl:copy-of select="$rights.content"/>
-    </dc:rights>
-  </xsl:if>
-
-  <xsl:element name="meta" namespace="{$opf.namespace}">
-    <xsl:attribute name="property">dcterms:rightsHolder</xsl:attribute>
-    <xsl:apply-templates select="holder" mode="titlepage.mode"/>
-  </xsl:element>
-</xsl:template>
-
-<xsl:template name="package.guide">
-
-  <xsl:variable name="info" select="./*[contains(local-name(.), 'info')][1]"/>
-
-  <xsl:variable name="toc.params">
-    <xsl:call-template name="find.path.params">
-      <xsl:with-param name="node" select="."/>
-      <xsl:with-param name="table" select="normalize-space($generate.toc)"/>
-    </xsl:call-template>
-  </xsl:variable>
-
-  <xsl:if test="contains($toc.params, 'toc') or 
-                $info/cover or 
-                $info//mediaobject[@role='cover' or ancestor::cover]"> 
-    <xsl:element namespace="{$opf.namespace}" name="guide">
-      <xsl:if test="$info/cover or 
-                    $info//mediaobject[@role='cover' or ancestor::cover]"> 
-        <xsl:element namespace="{$opf.namespace}" name="reference">
-          <xsl:attribute name="href">
-            <xsl:value-of select="$epub.cover.filename" />
-          </xsl:attribute>
-          <xsl:attribute name="type">cover</xsl:attribute>
-          <xsl:attribute name="title">Cover</xsl:attribute>
-        </xsl:element>
-      </xsl:if>  
-
-      <xsl:if test="contains($toc.params, 'toc')">
-        <xsl:element namespace="{$opf.namespace}" name="reference">
-          <xsl:attribute name="href">
-            <xsl:call-template name="toc-href">
-              <xsl:with-param name="node" select="."/>
-            </xsl:call-template>
-          </xsl:attribute>
-          <xsl:attribute name="type">toc</xsl:attribute>
-          <xsl:attribute name="title">Table of Contents</xsl:attribute>
-        </xsl:element>
-      </xsl:if>  
-    </xsl:element>  
-  </xsl:if>  
-</xsl:template>
-
-
-<xsl:template name="package-identifier">  
-
-  <xsl:variable name="info" select="./*[contains(local-name(.), 'info')][1]"/>
-
-  <xsl:choose>
-    <xsl:when test="$info/biblioid">
-      <xsl:if test="$info/biblioid[1][@class = 'doi' or 
-                                      @class = 'isbn' or
-                                      @class = 'isrn' or
-                                      @class = 'istc' or
-                                      @class = 'issn']">
-        <xsl:text>urn:</xsl:text>
-        <xsl:value-of select="$info/biblioid[1]/@class"/>
-        <xsl:text>:</xsl:text>
-      </xsl:if>
-      <xsl:value-of select="normalize-space($info/biblioid[1])"/>
-    </xsl:when>
-    <xsl:when test="$info/isbn">
-      <xsl:text>urn:isbn:</xsl:text>
-      <xsl:value-of select="$info/isbn[1]"/>
-    </xsl:when>
-    <xsl:when test="$info/issn">
-      <xsl:text>urn:issn:</xsl:text>
-      <xsl:value-of select="$info/issn[1]"/>
-    </xsl:when>
-    <xsl:otherwise>
-      <xsl:choose>
-        <xsl:when test="$info/invpartnumber">
-          <xsl:value-of select="$info/invpartnumber[1]"/>
-        </xsl:when>
-        <xsl:when test="$info/issuenum">
-          <xsl:value-of select="$info/issuenum[1]"/>
-        </xsl:when>
-        <xsl:when test="$info/productnumber">
-          <xsl:value-of select="$info/productnumber[1]"/>
-        </xsl:when>
-        <xsl:when test="$info/seriesvolnums">
-          <xsl:value-of select="$info/seriesvolnums[1]"/>
-        </xsl:when>
-        <xsl:when test="$info/volumenum">
-          <xsl:value-of select="$info/volumenum[1]"/>
-        </xsl:when>
-        <!-- Deprecated -->
-        <xsl:when test="$info/pubsnumber">
-          <xsl:value-of select="$info/pubsnumber[1]"/>
-        </xsl:when>
-      </xsl:choose>  
-      <xsl:text>_</xsl:text>
-      <xsl:choose>
-        <xsl:when test="@id">
-          <xsl:value-of select="@id"/>
-        </xsl:when>
-        <xsl:when test="@xml:id">
-          <xsl:value-of select="@xml:id"/>
-        </xsl:when>
-        <xsl:otherwise>
-          <!-- TODO: Do UUIDs here -->
-          <xsl:value-of select="generate-id(.)"/>
-        </xsl:otherwise>
-      </xsl:choose>
-    </xsl:otherwise>
-  </xsl:choose>
-</xsl:template>
-
-<!-- EPUB3: add epub:type attribute where appropriate -->
-<xsl:template match="*" mode="common.html.attributes">
-  <xsl:param name="class" select="local-name(.)"/>
-  <xsl:param name="inherit" select="0"/>
-  <xsl:call-template name="generate.html.lang"/>
-  <xsl:call-template name="dir">
-    <xsl:with-param name="inherit" select="$inherit"/>
-  </xsl:call-template>
-  <xsl:apply-templates select="." mode="class.attribute">
-    <xsl:with-param name="class" select="$class"/>
-  </xsl:apply-templates>
-  <xsl:call-template name="generate.html.title"/>
-  <xsl:apply-templates select="." mode="epub.type"/>
-</xsl:template>
-
-<xsl:template match="*" mode="epub.type" priority="-1"/>
-
-<xsl:template match="chapter
-                    |appendix
-                    |epigraph
-                    |warning
-                    |preface
-                    |index
-                    |colophon
-                    |glossary
-                    |biblioentry
-                    |bibliography
-                    |dedication
-                    |sidebar
-                    |footnote
-                    |glossterm
-                    |glossdef
-                    |bridgehead
-                    |part" mode="epub.type">
-  <xsl:variable name="type" select="local-name()"/>
-
-  <xsl:if test="$epub.output.epub.types != 0">
-    <xsl:attribute name="epub:type">
-      <xsl:value-of select="$type"/>
-    </xsl:attribute>
-  </xsl:if>
-</xsl:template>
-
-<xsl:template match="section[parent::chapter] | sect1" mode="epub.type">
-  <xsl:if test="$epub.output.epub.types != 0">
-    <xsl:attribute name="epub:type">subchapter</xsl:attribute>
-  </xsl:if>
-</xsl:template>
-
-<xsl:template match="section[not(parent::chapter)] |
-                     sect2 |
-                     sect3 |
-                     sect4 |
-                     sect5 |
-                     sect6" mode="epub.type">
-  <xsl:if test="$epub.output.epub.types != 0">
-    <xsl:attribute name="epub:type">division</xsl:attribute>
-  </xsl:if>
-</xsl:template>
-
-<xsl:template match="note|tip|caution|important" mode="epub.type">
-  <xsl:if test="$epub.output.epub.types != 0">
-    <xsl:attribute name="epub:type">notice</xsl:attribute>
-  </xsl:if>
-</xsl:template>
-
-<xsl:template match="orderedlist|itemizedlist|variablelist|simplelist" mode="epub.type">
-  <xsl:if test="$epub.output.epub.types != 0">
-    <xsl:attribute name="epub:type">list</xsl:attribute>
-  </xsl:if>
-</xsl:template>
-
-<xsl:template match="listitem" mode="epub.type">
-  <xsl:if test="$epub.output.epub.types != 0">
-    <xsl:attribute name="epub:type">list-item</xsl:attribute>
-  </xsl:if>
-</xsl:template>
-
-<!-- EPUB3: to add attributes to root output element -->
-<xsl:template name="root.attributes">
-  <!-- collect and output all namespace declarations -->
-  <xsl:call-template name="all.namespaces"/>
-</xsl:template>
-
-<xsl:template name="all.namespaces">
-  <!-- add the epub3 namespaces to the top output element -->
-  <xsl:variable name="temp">
-    <epub:foo/>
-    <m:foo/>
-    <pls:foo/>
-    <ssml:foo/>
-    <svg:foo/>
-  </xsl:variable>
-
-  <xsl:variable name="nodes" select="exsl:node-set($temp)"/>
-  <xsl:for-each select="$nodes//*/namespace::*">
-    <xsl:copy-of select="."/>
-  </xsl:for-each>
-
-</xsl:template>
-
-<xsl:template name="add.package.namespaces">
-  <!-- add the epub3 package namespaces to the top output element -->
-  <xsl:variable name="temp">
-    <dc:foo/>
-    <dcterms:foo/>
-  </xsl:variable>
-
-  <xsl:variable name="nodes" select="exsl:node-set($temp)"/>
-  <xsl:for-each select="$nodes//*[local-name(.) ='foo']/namespace::*">
-    <xsl:if test="contains(., 'purl.org')">
-      <xsl:copy-of select="."/>
-    </xsl:if>
-  </xsl:for-each>
-
-</xsl:template>
-
-
-<xsl:template name="footnotes.attributes">
-  <xsl:if test="$epub.output.epub.types != 0">
-    <xsl:attribute name="epub:type">footnotes</xsl:attribute>
-  </xsl:if>
-</xsl:template>
-
-<xsl:template name="package.manifest">
-  <xsl:element name="manifest" namespace="{$opf.namespace}">
-    <xsl:if test="$epub.include.ncx != 0">
-      <xsl:call-template name="manifest.ncx"/>
-    </xsl:if>
-    <xsl:call-template name="manifest.fonts"/>
-    <xsl:call-template name="manifest.toc"/>
-    <xsl:call-template name="manifest.css"/>
-    <xsl:call-template name="manifest.cover"/>
-    <xsl:call-template name="manifest.other.items"/>
-    <xsl:call-template name="manifest.content.items"/>
-    <xsl:call-template name="user.manifest.items"/>
-  </xsl:element>
-</xsl:template>
-
-<xsl:template name="user.manifest.items"/>
-
-<xsl:template name="manifest.css">
-  <xsl:if test="$html.stylesheet != ''">
-    <xsl:call-template name="css.item">
-      <xsl:with-param name="stylesheets" select="$html.stylesheet"/>
-    </xsl:call-template>
-  </xsl:if>
-  <xsl:if test="string-length($docbook.css.source) != 0">
-    <xsl:variable name="dfilename">
-      <xsl:call-template name="css.output.filename">
-        <xsl:with-param name="src" select="$docbook.css.source"/>
-      </xsl:call-template>
-    </xsl:variable>
-    <xsl:element namespace="{$opf.namespace}" name="item">
-      <xsl:attribute name="media-type">text/css</xsl:attribute>
-      <xsl:attribute name="id">docbook-css</xsl:attribute>
-      <xsl:attribute name="href">
-        <xsl:value-of select="$dfilename"/>
-      </xsl:attribute>
-    </xsl:element>
-  </xsl:if>
-  <xsl:if test="string-length($custom.css.source) != 0">
-    <xsl:variable name="cfilename">
-      <xsl:call-template name="css.output.filename">
-        <xsl:with-param name="src" select="$custom.css.source"/>
-      </xsl:call-template>
-    </xsl:variable>
-    <xsl:element namespace="{$opf.namespace}" name="item">
-      <xsl:attribute name="media-type">text/css</xsl:attribute>
-      <xsl:attribute name="id">custom-css</xsl:attribute>
-      <xsl:attribute name="href">
-        <xsl:value-of select="$cfilename"/>
-      </xsl:attribute>
-    </xsl:element>
-  </xsl:if>
-</xsl:template>
-
-<xsl:template name="css.item">
-  <xsl:param name="stylesheets" select="''"/>
-  <xsl:param name="count" select="1"/>
-
-  <xsl:choose>
-    <xsl:when test="contains($stylesheets, ' ')">
-      <xsl:variable name="css.filename" select="substring-before($stylesheets, ' ')"/>
-      <xsl:if test="$css.filename != ''">
-        <xsl:element namespace="{$opf.namespace}" name="item">
-          <xsl:attribute name="media-type">text/css</xsl:attribute>
-          <xsl:attribute name="id">
-            <xsl:text>html-css</xsl:text>
-            <xsl:if test="$count &gt; 1">
-              <xsl:value-of select="$count"/>
-            </xsl:if>
-          </xsl:attribute>
-          <xsl:attribute name="href">
-            <xsl:value-of select="$css.filename"/>
-          </xsl:attribute>
-        </xsl:element>
-      </xsl:if>
-
-      <xsl:call-template name="css.item">
-        <xsl:with-param name="stylesheets" select="substring-after($stylesheets, ' ')"/>
-        <xsl:with-param name="count" select="$count + 1"/>
-      </xsl:call-template>
-    </xsl:when>
-    <xsl:otherwise>
-      <xsl:if test="$stylesheets != ''">
-        <xsl:element namespace="{$opf.namespace}" name="item">
-          <xsl:attribute name="media-type">text/css</xsl:attribute>
-          <xsl:attribute name="id">
-            <xsl:text>html-css</xsl:text>
-            <xsl:if test="$count &gt; 1">
-              <xsl:value-of select="$count"/>
-            </xsl:if>
-          </xsl:attribute>
-          <xsl:attribute name="href">
-            <xsl:value-of select="$stylesheets"/>
-          </xsl:attribute>
-        </xsl:element>
-      </xsl:if>
-    </xsl:otherwise>
-  </xsl:choose>
-</xsl:template>
-
-<xsl:template name="manifest.ncx">
-  <xsl:element name="item" namespace="{$opf.namespace}">
-    <xsl:attribute name="id">
-      <xsl:value-of select="$epub.ncx.manifest.id"/>
-    </xsl:attribute>
-    <xsl:attribute name="href">
-      <xsl:value-of select="$epub.ncx.filename"/>
-    </xsl:attribute>
-    <xsl:attribute name="media-type">
-      <xsl:value-of select="$epub.ncx.mediatype"/>
-    </xsl:attribute>
-  </xsl:element>
-</xsl:template>
-
-<xsl:template name="manifest.fonts"/>
-
-<!--Misc items in the manifest based on content -->
-<xsl:template name="manifest.other.items">
-</xsl:template>
-
-
-<xsl:template name="manifest.cover">
-  <xsl:variable name="info" select="./*[contains(local-name(.), 'info')][1]"/>
-  <xsl:variable name="cover.image" 
-                select="$info//mediaobject[@role='cover' or ancestor::cover]"/>
-
-  <xsl:if test="$cover.image">
-
-    <!-- generate the manifest link to that page -->
-    <xsl:variable name="olist" select="$cover.image/imageobject|$cover.image/imageobjectco
-                       |$cover.image/videoobject|$cover.image/audioobject
-                       |$cover.image/textobject"/>
-  
-    <xsl:variable name="object.index">
-      <xsl:call-template name="select.mediaobject.index">
-        <xsl:with-param name="olist" select="$olist"/>
-        <xsl:with-param name="count" select="1"/>
-      </xsl:call-template>
-    </xsl:variable>
-  
-    <xsl:variable name="object" select="$olist[position() = $object.index]"/>
-
-    <xsl:variable name="output_filename">
-      <xsl:call-template name="mediaobject.filename">
-        <xsl:with-param name="object" select="$object"/>
-      </xsl:call-template>
-    </xsl:variable>
-
-    <xsl:variable name="image.filename">
-       <xsl:if test="$img.src.path != '' and
-                       not(starts-with($output_filename, '/')) and
-                       not(contains($output_filename, '://'))">
-         <xsl:value-of select="$img.src.path"/>
-       </xsl:if>
-       <xsl:value-of select="$output_filename"/>
-    </xsl:variable>
-    <xsl:variable name="image.extension">
-      <xsl:call-template name="filename-extension">
-        <xsl:with-param name="filename" select="$image.filename"/>
-      </xsl:call-template>
-    </xsl:variable>
-
-    <xsl:variable name="image.type">
-      <xsl:call-template name="graphic.format.content-type">
-        <xsl:with-param name="format" select="translate($image.extension, 
-                   &lowercase;, &uppercase;)"/>
-      </xsl:call-template>
-    </xsl:variable>
-
-    <!-- Reference to cover html file -->
-    <xsl:element namespace="{$opf.namespace}" name="item">
-      <xsl:attribute name="id">
-        <xsl:value-of select="$epub.cover.filename.id"/>
-      </xsl:attribute>
-      <xsl:attribute name="href">
-        <xsl:value-of select="$epub.cover.filename"/>
-      </xsl:attribute>
-      <xsl:attribute name="media-type">
-        <xsl:value-of select="$epub.xhtml.mediatype"/>
-      </xsl:attribute>
-    </xsl:element>
-
-    <!-- special item with property="cover-image" -->
-    <xsl:element namespace="{$opf.namespace}" name="item">
-      <xsl:attribute name="id">
-        <xsl:value-of select="$epub.cover.image.id"/>
-      </xsl:attribute>
-      <xsl:attribute name="properties">cover-image</xsl:attribute>
-      <xsl:attribute name="href">
-        <xsl:value-of select="$image.filename"/>
-      </xsl:attribute>
-      <xsl:if test="$image.type">
-        <xsl:attribute name="media-type">
-          <xsl:value-of select="$image.type"/>
-        </xsl:attribute>
-      </xsl:if>
-    </xsl:element>
-
-    <!-- And generate the cover html file -->
-    <xsl:apply-templates select="$cover.image"/>
-
-  </xsl:if>
-</xsl:template>
-
-<xsl:template name="manifest.toc">
-  <xsl:variable name="toc.params">
-    <xsl:call-template name="find.path.params">
-      <xsl:with-param name="node" select="."/>
-      <xsl:with-param name="table" select="normalize-space($generate.toc)"/>
-    </xsl:call-template>
-  </xsl:variable>
-
-  <xsl:if test="contains($toc.params, 'toc')">
-    <xsl:element namespace="{$opf.namespace}" name="item">
-      <xsl:attribute name="id">
-        <xsl:value-of select="$epub.html.toc.id"/>
-      </xsl:attribute>
-      <xsl:attribute name="properties">nav</xsl:attribute>
-      <xsl:attribute name="media-type">
-        <xsl:value-of select="$epub.xhtml.mediatype"/>
-      </xsl:attribute>
-      <xsl:attribute name="href">
-        <xsl:call-template name="toc-href">
-          <xsl:with-param name="node" select="."/>
-        </xsl:call-template>
-      </xsl:attribute>
-    </xsl:element>
-  </xsl:if>  
-</xsl:template>
-
-<xsl:template name="toc-href">
-  <xsl:param name="node" select="."/>
-  <!-- FIXME -->
-  <xsl:apply-templates select="$node" mode="recursive-chunk-filename">
-    <xsl:with-param name="recursive" select="true()"/>
-  </xsl:apply-templates>
-  <xsl:text>-toc</xsl:text>
-  <xsl:value-of select="$html.ext"/>
-</xsl:template>
-
-<xsl:template match="*" mode="recursive-chunk-filename">
-  <!-- placeholder for real template in chunking stylesheet -->
-  <xsl:value-of select="concat(local-name(.), '-', generate-id(.))"/>
-</xsl:template>
-
-<xsl:template name="manifest.content.items">
-  <xsl:apply-templates select="." mode="package.manifest"/>
-  <xsl:call-template name="manifest.images"/>
-</xsl:template>
-
-<xsl:template match="text()" mode="package.manifest"/>
-
-<xsl:template match="mediaobject|mediaobjectco|inlinemediaobject" priority="1"
-              mode="package.manifest">
-  <!-- These are handled out of line so a unique list is created
-       to remove duplicate references -->
-</xsl:template>
-
-<xsl:template match="*" mode="package.manifest">
-
-  <xsl:variable name="is.chunk">
-    <xsl:call-template name="chunk">
-      <xsl:with-param name="node" select="."/>
-    </xsl:call-template>
-  </xsl:variable>
-
-  <xsl:if test="$is.chunk != 0">
-    <xsl:variable name="href">
-      <xsl:call-template name="href.target.with.base.dir">
-        <xsl:with-param name="context" select="/"/>
-      </xsl:call-template>
-    </xsl:variable>
-  
-    <xsl:variable name="id" select="concat($epub.package.id.prefix, generate-id())"/>
-
-    <xsl:variable name="properties.set">
-      <xsl:call-template name="svg.property"/>
-      <xsl:text> </xsl:text>
-      <xsl:call-template name="mathml.property"/>
-    </xsl:variable>
-
-    <xsl:variable name="properties" select="normalize-space($properties.set)"/>
-
-    <xsl:element namespace="{$opf.namespace}" name="item">
-      <xsl:attribute name="id">
-        <xsl:value-of select="$id"/>
-      </xsl:attribute>
-      <xsl:attribute name="href">
-        <xsl:value-of select="$href"/>
-      </xsl:attribute>
-      <xsl:attribute name="media-type">application/xhtml+xml</xsl:attribute>
-      <xsl:if test="string-length($properties) != 0">
-        <xsl:attribute name="properties">
-          <xsl:value-of select="$properties"/>
-        </xsl:attribute>
-      </xsl:if>
-    </xsl:element>
-  </xsl:if>  
-  <xsl:apply-templates mode="package.manifest"/>
-
-</xsl:template>
-
-<xsl:template name="svg.property">
-  <xsl:param name="this.chunk" select="."/>
-
-  <xsl:variable name="genid" select="generate-id($this.chunk)"/>
-
-  <!-- get the chunkfast div element for this chunk -->
-  <xsl:variable name="div" select="$chunkset[@id=$genid or @xml:id=$genid]"/>
-
-  <!-- get the chunkfast div element the next chunk -->
-  <xsl:variable name="nextdiv"
-                select="($div/following-sibling::cf:div|
-                         $div/following::cf:div|
-                         $div/cf:div)[1]"/>
-
-  <!-- get the element corresponding to the next chunk -->
-  <xsl:variable name="next.chunk" select="key('genid', ($nextdiv/@id|$nextdiv/@xml:id)[1])"/>
-
-  <xsl:choose>
-    <xsl:when test="$next.chunk">
-      <xsl:variable name="this.imagedata"
-                    select="$this.chunk//mediaobject"/>
-      <xsl:variable name="before.next"
-                    select="$next.chunk/preceding::mediaobject"/>
-      
-      <!-- select for an SVG imagedata in the intersection of them -->
-      <xsl:variable name="mediaobject.set"
-          select="$this.imagedata[count(.|$before.next) = count($before.next)]"/>
-      <xsl:variable name="svg.imagedata">
-        <xsl:for-each select="$mediaobject.set">
-          <xsl:variable name="olist" select="imageobject[not(@role = 'poster')] |
-                                             imageobjectco"/>
-          <xsl:variable name="mediaobject.index">
-            <xsl:call-template name="select.mediaobject.index">
-              <xsl:with-param name="olist" select="$olist"/>
-            </xsl:call-template>
-          </xsl:variable>
-          <xsl:variable name="object" select="$olist[position() = $mediaobject.index]"/>
-          <xsl:if test="$object/imagedata[contains(
-                      substring(@fileref, string-length(@fileref)-3,4), '.svg')]">
-            <xsl:text>svg</xsl:text>
-          </xsl:if>
-        </xsl:for-each>
-      </xsl:variable>
-    
-      <xsl:if test="contains($svg.imagedata, 'svg')">
-        <xsl:text>svg</xsl:text>
-     </xsl:if>
-    </xsl:when>
-    <xsl:otherwise>
-      <xsl:variable name="mediaobject.set"
-                    select="$this.chunk//mediaobject"/>
-      <xsl:variable name="svg.imagedata">
-        <xsl:for-each select="$mediaobject.set">
-          <xsl:variable name="olist" select="imageobject[not(@role = 'poster')] |
-                                             imageobjectco"/>
-          <xsl:variable name="mediaobject.index">
-            <xsl:call-template name="select.mediaobject.index">
-              <xsl:with-param name="olist" select="$olist"/>
-            </xsl:call-template>
-          </xsl:variable>
-          <xsl:variable name="object" select="$olist[position() = $mediaobject.index]"/>
-          <xsl:if test="$object/imagedata[contains(
-                      substring(@fileref, string-length(@fileref)-3,4), '.svg')]">
-            <xsl:text>svg</xsl:text>
-          </xsl:if>
-        </xsl:for-each>
-      </xsl:variable>
-    
-      <xsl:if test="contains($svg.imagedata, 'svg')">
-        <xsl:text>svg</xsl:text>
-     </xsl:if>
-    </xsl:otherwise>
-  </xsl:choose>
-
-</xsl:template>
-
-<xsl:template name="mathml.property">
-  <xsl:param name="this.chunk" select="."/>
-
-  <xsl:variable name="genid" select="generate-id($this.chunk)"/>
-
-  <!-- get the chunkfast div element for this chunk -->
-  <xsl:variable name="div" select="$chunkset[@id=$genid or @xml:id=$genid]"/>
-
-  <!-- get the chunkfast div element the next chunk -->
-  <xsl:variable name="nextdiv"
-                select="($div/following-sibling::cf:div|
-                         $div/following::cf:div|
-                         $div/cf:div)[1]"/>
-
-  <!-- get the element corresponding to the next chunk -->
-  <xsl:variable name="next.chunk" select="key('genid', ($nextdiv/@id|$nextdiv/@xml:id)[1])"/>
-
-  <xsl:variable name="this.math"
-                select="$this.chunk//m:*"/>
-  <xsl:variable name="before.next"
-                select="$next.chunk/preceding::m:*"/>
-  
-  <!-- select for an SVG imagedata in the intersection of them -->
-  <xsl:variable name="intersection"
-      select="$this.math[count(.|$before.next) = count($before.next)]"/>
-
-  <xsl:if test="count($intersection) != 0">
-    <xsl:text>mathml</xsl:text>
- </xsl:if>
-</xsl:template>
-
-<xsl:template name="manifest.image.item">
-</xsl:template>
-
-<!-- Need a uniqued list of images -->
-<xsl:template name="manifest.images">
-  <xsl:message>Generating image list ...</xsl:message>
-  <xsl:variable name="imagelist">
-    <xsl:choose>
-      <xsl:when test="$rootid != ''">
-        <xsl:apply-templates select="key('id', $rootid)" mode="enumerate-images"/>
-      </xsl:when>
-      <xsl:otherwise>
-        <xsl:apply-templates select="/" mode="enumerate-images"/>
-      </xsl:otherwise>
-    </xsl:choose>
-  </xsl:variable>
-
-  <xsl:choose>
-    <xsl:when test="$exsl.node.set.available != 0 and 
-                    function-available('set:distinct')">
-      <xsl:for-each select="set:distinct(exsl:node-set($imagelist)/*)">
-        <xsl:if test="string-length(tmp-href) != 0">
-          <!-- convert the child elements to attributes -->
-          <xsl:element name="item" namespace="{$opf.namespace}">
-            <xsl:attribute name="id">
-              <xsl:value-of select="generate-id()"/>
-            </xsl:attribute>
-            <xsl:attribute name="href">
-              <xsl:value-of select="tmp-href"/>
-            </xsl:attribute>
-            <xsl:attribute name="media-type">
-              <xsl:value-of select="media-type"/>
-            </xsl:attribute>
-          </xsl:element>
-        </xsl:if>
-      </xsl:for-each>
-    </xsl:when>
-    <xsl:when test="$exsl.node.set.available != 0">
-      <xsl:for-each select="exsl:node-set($imagelist)/*">
-        <xsl:element name="item" namespace="{$opf.namespace}">
-          <xsl:attribute name="id">
-            <xsl:value-of select="generate-id()"/>
-          </xsl:attribute>
-          <xsl:attribute name="href">
-            <xsl:value-of select="tmp-href"/>
-          </xsl:attribute>
-          <xsl:attribute name="media-type">
-            <xsl:value-of select="media-type"/>
-          </xsl:attribute>
-        </xsl:element>
-      </xsl:for-each>
-    </xsl:when>
-    <xsl:otherwise>
-      <xsl:message terminate="yes">
-        <xsl:text>ERROR: cannot process images list without </xsl:text>
-        <xsl:text>exsl:node-set() function</xsl:text>
-      </xsl:message>
-      <!-- cannot do this without node-set() -->
-    </xsl:otherwise>
-  </xsl:choose>
-
-</xsl:template>
-
-<xsl:template match="*" mode="enumerate-images">
-  <xsl:apply-templates mode="enumerate-images"/>
-</xsl:template>
-
-<xsl:template match="text()" mode="enumerate-images"/>
-
-<xsl:template match="graphic|inlinegraphic[@format!='linespecific']" 
-              mode="enumerate-images">
-</xsl:template>
-
-<!-- cover image handled separates to give it an extra property attribute -->
-<xsl:template match="mediaobject[@role='cover' or ancestor::cover]"
-              mode="enumerate-images"/>
-
-<xsl:template match="mediaobject|inlinemediaobject" mode="enumerate-images">
-
-  <xsl:variable name="olist" 
-                select="imageobject[not(@role = 'poster')] 
-                       |imageobjectco
-                       |videoobject
-                       |audioobject
-                       |textobject"/>
- 
-  <xsl:variable name="object.index">
-    <xsl:call-template name="select.mediaobject.index">
-      <xsl:with-param name="olist" select="$olist"/>
-      <xsl:with-param name="count" select="1"/>
-    </xsl:call-template>
-  </xsl:variable>
-  
-  <xsl:variable name="object" select="$olist[position() = $object.index]"/>
-
-  <xsl:apply-templates select="$object" mode="enumerate-images"/>
-
-  <!-- also include a poster image if present -->
-  <xsl:apply-templates select="imageobject[@role = 'poster']" mode="enumerate-images"/>
-
-</xsl:template>
-
-<xsl:template match="imageobject|videoobject|audioobject" mode="enumerate-images">
-  <xsl:param name="object" select="."/>
-
-  <xsl:if test="$object">
-    <xsl:variable name="output_filename">
-      <xsl:call-template name="mediaobject.filename">
-        <xsl:with-param name="object" select="$object"/>
-      </xsl:call-template>
-    </xsl:variable>
-
-    <xsl:variable name="image.filename">
-       <xsl:if test="$img.src.path != '' and
-                       not(starts-with($output_filename, '/')) and
-                       not(contains($output_filename, '://'))">
-         <xsl:value-of select="$img.src.path"/>
-       </xsl:if>
-       <xsl:value-of select="$output_filename"/>
-    </xsl:variable>
-
-    <xsl:variable name="image.extension">
-      <xsl:call-template name="filename-extension">
-        <xsl:with-param name="filename" select="$image.filename"/>
-      </xsl:call-template>
-    </xsl:variable>
-
-    <xsl:variable name="image.type">
-      <xsl:call-template name="graphic.format.content-type">
-        <xsl:with-param name="format" select="translate($image.extension, 
-                   &lowercase;, &uppercase;)"/>
-      </xsl:call-template>
-    </xsl:variable>
-
-    <xsl:element name="tmp-filename" namespace="">
-      <xsl:element name="tmp-href" namespace="">
-        <xsl:value-of select="$image.filename"/>
-      </xsl:element>
-      <xsl:element name="media-type" namespace="">
-        <xsl:value-of select="$image.type"/>
-      </xsl:element>
-    </xsl:element>
-
-  </xsl:if>
-</xsl:template>
- 
-<!-- Add in the generated images -->
-<xsl:template match="note|caution|warning|important|tip" mode="enumerate-images">
-  <xsl:if test="$admon.graphics != 0">
-    <xsl:variable name="image.filename">
-      <xsl:call-template name="admon.graphic"/>
-    </xsl:variable>
-
-    <xsl:variable name="image.type">
-      <xsl:call-template name="graphic.format.content-type">
-        <xsl:with-param name="format" select="translate(
-               substring-after($admon.graphics.extension,'.'), 
-                   &lowercase;, &uppercase;)"/>
-      </xsl:call-template>
-    </xsl:variable>
-
-    <xsl:element name="tmp-filename" namespace="">
-      <xsl:element name="tmp-href" namespace="">
-        <xsl:value-of select="$image.filename"/>
-      </xsl:element>
-      <xsl:element name="media-type" namespace="">
-        <xsl:value-of select="$image.type"/>
-      </xsl:element>
-    </xsl:element>
-
-  </xsl:if>
-</xsl:template>
-
-<xsl:template match="callout" mode="enumerate-images">
-  <!-- process arearefs to get name of callout bug image files -->
-  <xsl:if test="$callout.graphics != 0">
-    <xsl:variable name="arearefs">
-      <xsl:call-template name="callout.arearefs">
-        <xsl:with-param name="arearefs" select="@arearefs"/>
-      </xsl:call-template>
-    </xsl:variable>
-
-    <xsl:variable name="nodes" select="exsl:node-set($arearefs)"/>
-
-    <xsl:for-each select="$nodes//*[@src]">
-      <xsl:variable name="image.filename" select="@src"/>
-
-      <xsl:variable name="image.type">
-        <xsl:call-template name="graphic.format.content-type">
-          <xsl:with-param name="format" select="translate(
-                 substring-after($callout.graphics.extension,'.'), 
-                     &lowercase;, &uppercase;)"/>
-        </xsl:call-template>
-      </xsl:variable>
-
-      <xsl:element name="tmp-filename" namespace="">
-        <xsl:element name="tmp-href" namespace="">
-          <xsl:value-of select="$image.filename"/>
-        </xsl:element>
-        <xsl:element name="media-type" namespace="">
-          <xsl:value-of select="$image.type"/>
-        </xsl:element>
-      </xsl:element>
-    </xsl:for-each>
-
-  </xsl:if>
-</xsl:template>
-
-<xsl:template match="co" mode="enumerate-images">
-  <!-- process co to get name of callout bug image file -->
-  <xsl:if test="$callout.graphics != 0">
-    <xsl:variable name="result">
-      <xsl:apply-templates select="." mode="callout-bug"/>
-    </xsl:variable>
-
-    <xsl:variable name="nodes" select="exsl:node-set($result)"/>
-
-    <xsl:for-each select="$nodes//*[@src]">
-      <xsl:variable name="image.filename" select="@src"/>
-
-      <xsl:variable name="image.type">
-        <xsl:call-template name="graphic.format.content-type">
-          <xsl:with-param name="format" select="translate(
-                 substring-after($callout.graphics.extension,'.'), 
-                     &lowercase;, &uppercase;)"/>
-        </xsl:call-template>
-      </xsl:variable>
-
-      <xsl:element name="tmp-filename" namespace="">
-        <xsl:element name="tmp-href" namespace="">
-          <xsl:value-of select="$image.filename"/>
-        </xsl:element>
-        <xsl:element name="media-type" namespace="">
-          <xsl:value-of select="$image.type"/>
-        </xsl:element>
-      </xsl:element>
-    </xsl:for-each>
-
-  </xsl:if>
-
-</xsl:template>
-
-<!-- ======================================================== -->
-<!-- NCX templates are for backwards compatibility with EPUB2 -->
-<!-- ======================================================== -->
-
-<xsl:template name="ncx">
-  <xsl:message>Generating NCX file ...</xsl:message>
-  <xsl:call-template name="write.chunk">
-    <xsl:with-param name="filename">
-      <xsl:value-of select="$epub.ncx.pathname" />
-    </xsl:with-param>
-    <xsl:with-param name="method" select="'xml'" />
-    <xsl:with-param name="encoding" select="'utf-8'" />
-    <xsl:with-param name="indent" select="'no'" />
-    <xsl:with-param name="quiet" select="$chunk.quietly" />
-    <xsl:with-param name="doctype-public" select="''"/> <!-- intentionally blank -->
-    <xsl:with-param name="doctype-system" select="''"/> <!-- intentionally blank -->
-    <xsl:with-param name="content">
-      <xsl:element name="ncx" namespace="{$ncx.namespace}">
-        <xsl:attribute name="version">2005-1</xsl:attribute>
-
-          <!-- Via Martin Goerner: On covers: the IDPF2.0 standard unfortunately does not have a provision for
-          covers. We had to add one and we did so in conjunction with the IDPF and
-          various publishers. The tag chosen to define the covers is:
-          <meta name="cover" content="-reference to a manifest item-">
-          Then, we also added a bit of logic to get rid cleanly of the HTML cover
-          people usually add because the logical cover is not specced by the IDPF. So,
-          if the HTML cover item is marked linear="no" AND there is a guide item of
-          type="cover" pointing to it AND there is a logical cover specified in a
-          <meta name="cover"> tag, THEN, the HTML cover is discarded. -->
-        <xsl:element name="head" namespace="{$ncx.namespace}">
-          <xsl:if test="/*/*[cover or contains(name(.), 'info')]//mediaobject[@role='cover' or ancestor::cover]"> 
-            <xsl:element name="meta" namespace="{$ncx.namespace}">
-              <xsl:attribute name="name">cover</xsl:attribute>
-              <xsl:attribute name="content">
-                <xsl:value-of select="$epub.cover.filename.id"/>
-              </xsl:attribute>
-            </xsl:element>
-          </xsl:if>
-          <xsl:element name="meta" namespace="{$ncx.namespace}">
-            <xsl:attribute name="name">dtb:uid</xsl:attribute>
-            <xsl:attribute name="content"><xsl:call-template name="package-identifier"/></xsl:attribute>
-          </xsl:element>
-        </xsl:element>
-
-        <xsl:choose>
-          <xsl:when test="$rootid != ''">
-            <xsl:variable name="title">
-              <xsl:if test="$epub.autolabel != 0">
-                <xsl:variable name="label.markup">
-                  <xsl:apply-templates select="key('id',$rootid)" mode="label.markup" />
-                </xsl:variable>
-                <xsl:if test="normalize-space($label.markup)">
-                  <xsl:value-of select="concat($label.markup,$autotoc.label.separator)" />
-                </xsl:if>
-              </xsl:if>
-              <xsl:apply-templates select="key('id',$rootid)" mode="title.markup" />
-            </xsl:variable>
-            <xsl:variable name="href">
-              <xsl:call-template name="href.target.with.base.dir">
-                <xsl:with-param name="object" select="key('id',$rootid)" />
-              </xsl:call-template>
-            </xsl:variable>
-            <xsl:element name="docTitle" namespace="{$ncx.namespace}">
-              <xsl:element name="text" namespace="{$ncx.namespace}"><xsl:value-of select="normalize-space($title)" />  </xsl:element>
-            </xsl:element>
-            <xsl:element name="navMap" namespace="{$ncx.namespace}">
-              <xsl:apply-templates select="key('id',$rootid)/*" mode="ncx" />
-            </xsl:element>
-          </xsl:when>
-          <xsl:otherwise>
-            <xsl:variable name="title">
-              <xsl:if test="$epub.autolabel != 0">
-                <xsl:variable name="label.markup">
-                  <xsl:apply-templates select="/*" mode="label.markup" />
-                </xsl:variable>
-                <xsl:if test="normalize-space($label.markup)">
-                  <xsl:value-of select="concat($label.markup,$autotoc.label.separator)" />
-                </xsl:if>
-              </xsl:if>
-              <xsl:apply-templates select="/*" mode="title.markup" />
-            </xsl:variable>
-            <xsl:variable name="href">
-              <xsl:call-template name="href.target.with.base.dir">
-                <xsl:with-param name="object" select="/" />
-              </xsl:call-template>
-            </xsl:variable>
-            <xsl:element name="docTitle" namespace="{$ncx.namespace}">
-              <xsl:element name="text" namespace="{$ncx.namespace}">
-                <xsl:value-of select="normalize-space($title)" />
-              </xsl:element>
-            </xsl:element>
-            <xsl:element name="navMap" namespace="{$ncx.namespace}">
-              <xsl:choose>
-                <xsl:when test="$root.is.a.chunk != '0'">
-                  <xsl:apply-templates select="/*" mode="ncx" />
-                  <xsl:apply-templates select="/*/*" mode="ncx" />
-                </xsl:when>
-                <xsl:otherwise>
-                  <xsl:apply-templates select="/*/*" mode="ncx" />
-                </xsl:otherwise>
-              </xsl:choose>
-            </xsl:element>
-          </xsl:otherwise>
-
-        </xsl:choose>
-      </xsl:element>
-    </xsl:with-param>
-  </xsl:call-template>
-</xsl:template>
-
-<xsl:template match="book|
-                     article|
-                     topic|
-                     part|
-                     reference|
-                     preface|
-                     chapter|
-                     bibliography|
-                     appendix|
-                     glossary|
-                     section|
-                     sect1|
-                     sect2|
-                     sect3|
-                     sect4|
-                     sect5|
-                     refentry|
-                     colophon|
-                     bibliodiv[title]|
-                     setindex|
-                     index"
-              mode="ncx">
-  <xsl:variable name="depth" select="count(ancestor::*)"/>
-  <xsl:variable name="title">
-    <xsl:if test="$epub.autolabel != 0">
-      <xsl:variable name="label.markup">
-        <xsl:apply-templates select="." mode="label.markup" />
-      </xsl:variable>
-      <xsl:if test="normalize-space($label.markup)">
-        <xsl:value-of
-          select="concat($label.markup,$autotoc.label.separator)" />
-      </xsl:if>
-    </xsl:if>
-    <xsl:apply-templates select="." mode="title.markup" />
-  </xsl:variable>
-
-  <xsl:variable name="href">
-    <xsl:call-template name="href.target.with.base.dir">
-      <xsl:with-param name="context" select="/" />
-      <!-- Generate links relative to the location of root file/toc.xml file -->
-    </xsl:call-template>
-  </xsl:variable>
-
-  <xsl:variable name="id">
-    <xsl:value-of select="generate-id(.)"/>
-  </xsl:variable>
-  <xsl:variable name="order">
-    <xsl:value-of select="$depth +
-                                count(preceding::part|
-                                preceding::reference|
-                                preceding::book[parent::set]|
-                                preceding::preface|
-                                preceding::chapter|
-                                preceding::bibliography|
-                                preceding::appendix|
-                                preceding::article|
-                                preceding::topic|
-                                preceding::glossary|
-                                preceding::section[not(parent::partintro)]|
-                                preceding::sect1[not(parent::partintro)]|
-                                preceding::sect2[not(ancestor::partintro)]|
-                                preceding::sect3[not(ancestor::partintro)]|
-                                preceding::sect4[not(ancestor::partintro)]|
-                                preceding::sect5[not(ancestor::partintro)]|
-                                preceding::refentry|
-                                preceding::colophon|
-                                preceding::bibliodiv[title]|
-                                preceding::index)"/>
-  </xsl:variable>
-
-  <xsl:element name="navPoint" namespace="{$ncx.namespace}">
-    <xsl:attribute name="id">
-      <xsl:value-of select="$id"/>
-    </xsl:attribute>
-
-    <xsl:attribute name="playOrder">
-      <xsl:choose>
-        <xsl:when test="/*[self::set]">
-          <xsl:value-of select="$order"/>
-        </xsl:when>
-        <xsl:when test="$root.is.a.chunk != '0'">
-          <xsl:value-of select="$order + 1"/>
-        </xsl:when>
-        <xsl:otherwise>
-          <xsl:value-of select="$order - 0"/>
-        </xsl:otherwise>
-      </xsl:choose>
-    </xsl:attribute>
-    <xsl:element name="navLabel" namespace="{$ncx.namespace}">
-      <xsl:element name="text" namespace="{$ncx.namespace}"><xsl:value-of select="normalize-space($title)"/> </xsl:element>
-    </xsl:element>
-    <xsl:element name="content" namespace="{$ncx.namespace}">
-      <xsl:attribute name="src">
-        <xsl:value-of select="$href"/>
-      </xsl:attribute>
-    </xsl:element>
-    <xsl:if test="$depth != 0">
-      <!-- Don't recurse on root element, but treat it as a single point so
-      the progress bar shows all top level children -->
-      <xsl:apply-templates select="book[parent::set]|part|reference|preface|chapter|bibliography|appendix|article|topic|glossary|section|sect1|sect2|sect3|sect4|sect5|refentry|colophon|bibliodiv[title]|setindex|index" mode="ncx"/>
-    </xsl:if>
-  </xsl:element>
-
-</xsl:template>
-
-<xsl:template match="text()" mode="ncx" />
-
-<xsl:template name="package.spine">
-
-  <xsl:variable name="toc.params">
-    <xsl:call-template name="find.path.params">
-      <xsl:with-param name="node" select="."/>
-      <xsl:with-param name="table" select="normalize-space($generate.toc)"/>
-    </xsl:call-template>
-  </xsl:variable>
-
-  <xsl:element namespace="http://www.idpf.org/2007/opf" name="spine">
-    <xsl:if test="$epub.include.ncx != 0">
-      <xsl:attribute name="toc">
-        <xsl:value-of select="$epub.ncx.manifest.id"/>
-      </xsl:attribute>
-    </xsl:if>
-
-    <xsl:call-template name="spine.cover"/>
-
-
-    <xsl:if test="contains($toc.params, 'toc')">
-      <xsl:element namespace="http://www.idpf.org/2007/opf" name="itemref">
-        <xsl:attribute name="idref"> <xsl:value-of select="$epub.html.toc.id"/> </xsl:attribute>
-        <xsl:attribute name="linear">yes</xsl:attribute>
-      </xsl:element>
-    </xsl:if>  
-
-    <!-- TODO: be nice to have a idref="titlepage" here -->
-    <xsl:choose>
-      <xsl:when test="$root.is.a.chunk != '0'">
-        <xsl:apply-templates select="/*" mode="package.spine"/>
-      </xsl:when>
-      <xsl:otherwise>
-        <xsl:apply-templates select="/*/*" mode="package.spine"/>
-      </xsl:otherwise>
-    </xsl:choose>
-                                 
-  </xsl:element>
-</xsl:template>
-
-<xsl:template name="spine.cover">
-  <xsl:variable name="info" select="./*[contains(local-name(.), 'info')][1]"/>
-  <xsl:variable name="cover.image" 
-                select="$info//mediaobject[@role='cover' or ancestor::cover]"/>
-
-  <xsl:if test="$cover.image">
-    <!-- generate the spine reference to that cover html file -->
-    <xsl:element namespace="http://www.idpf.org/2007/opf" name="itemref">
-      <xsl:attribute name="idref">
-        <xsl:value-of select="$epub.cover.filename.id"/>
-      </xsl:attribute>
-      <xsl:attribute name="linear">
-      <xsl:choose>
-        <xsl:when test="$epub.cover.linear">
-          <xsl:text>yes</xsl:text>
-        </xsl:when>
-        <xsl:otherwise>no</xsl:otherwise>
-      </xsl:choose>
-      </xsl:attribute>
-    </xsl:element>
-  </xsl:if>
-</xsl:template>
-
-<xsl:template match="*" mode="package.spine">
-  <xsl:variable name="is.chunk">
-    <xsl:call-template name="chunk">
-      <xsl:with-param name="node" select="."/>
-    </xsl:call-template>
-  </xsl:variable>
-
-  <xsl:if test="$is.chunk != 0">
-    <xsl:element namespace="http://www.idpf.org/2007/opf" name="itemref">
-      <xsl:attribute name="idref">
-        <xsl:value-of select="concat($epub.package.id.prefix, generate-id(.))"/>
-      </xsl:attribute>
-    </xsl:element>
-    <xsl:apply-templates select="*|.//refentry" mode="package.spine"/>
-  </xsl:if>
-</xsl:template>
-
-<xsl:template match="*" mode="container">
-  <xsl:call-template name="container"/>
-</xsl:template>
-
-<xsl:template name="container">
-  <!-- The path in rootfile does not include all of base.dir, only the last part -->
-  <xsl:variable name="full-path-dir">
-    <xsl:call-template name="filename-basename">
-      <xsl:with-param name="filename" select="$chunk.base.dir"/>
-    </xsl:call-template>
-  </xsl:variable>
-  <xsl:call-template name="write.chunk">
-    <xsl:with-param name="filename">
-      <xsl:value-of select="$epub.container.pathname" />
-    </xsl:with-param>
-    <xsl:with-param name="method" select="'xml'" />
-    <xsl:with-param name="encoding" select="'utf-8'" />
-    <xsl:with-param name="indent" select="'no'" />
-    <xsl:with-param name="quiet" select="$chunk.quietly" />
-    <xsl:with-param name="doctype-public" select="''"/> <!-- intentionally blank -->
-    <xsl:with-param name="doctype-system" select="''"/> <!-- intentionally blank -->
-
-    <xsl:with-param name="content">
-      <xsl:element namespace="urn:oasis:names:tc:opendocument:xmlns:container" name="container">
-        <xsl:attribute name="version">1.0</xsl:attribute>
-        <xsl:element namespace="urn:oasis:names:tc:opendocument:xmlns:container" name="rootfiles">
-          <xsl:element namespace="urn:oasis:names:tc:opendocument:xmlns:container" name="rootfile">
-            <xsl:attribute name="full-path">
-              <xsl:value-of 
-                     select="concat($full-path-dir, $epub.package.filename)"/>
-            </xsl:attribute>
-            <xsl:attribute name="media-type">
-              <xsl:text>application/oebps-package+xml</xsl:text>
-            </xsl:attribute>
-          </xsl:element>
-        </xsl:element>
-      </xsl:element>
-    </xsl:with-param>
-  </xsl:call-template>
-</xsl:template>
-
-<xsl:template name="mimetype">
-  <xsl:call-template name="write.text.chunk">
-    <xsl:with-param name="filename" select="$epub.mimetype.pathname"/>
-    <xsl:with-param name="content" select="$epub.mimetype.value"/>
-  </xsl:call-template>
-</xsl:template>
-
-<xsl:template match="mediaobject[@role='cover' or ancestor::cover]">
-  <xsl:call-template name="write.chunk">
-    <xsl:with-param name="filename">
-      <xsl:value-of select="$epub.cover.pathname" />
-    </xsl:with-param>
-    <xsl:with-param name="method" select="'xml'" />
-    <xsl:with-param name="encoding" select="'utf-8'" />
-    <xsl:with-param name="indent" select="'no'" />
-    <xsl:with-param name="quiet" select="$chunk.quietly" />
-    <xsl:with-param name="content">
-      <xsl:element namespace="http://www.w3.org/1999/xhtml" name="html">
-        <xsl:element namespace="http://www.w3.org/1999/xhtml" name="head">
-          <xsl:element namespace="http://www.w3.org/1999/xhtml" name="title">Cover</xsl:element>
-          <xsl:element namespace="http://www.w3.org/1999/xhtml" name="style">
-            <xsl:attribute name="type">text/css</xsl:attribute>
-            <!-- Help the cover image scale nicely in the CSS then apply a max-width to look better in Adobe Digital Editions -->
-            <xsl:text> img { max-width: 100%; }</xsl:text>
-          </xsl:element>
-        </xsl:element>
-        <xsl:element namespace="http://www.w3.org/1999/xhtml" name="body">
-          <xsl:element namespace="http://www.w3.org/1999/xhtml" name="div">
-            <xsl:attribute name="id">
-              <xsl:value-of select="$epub.cover.image.id"/>
-            </xsl:attribute>
-            <xsl:choose>
-              <xsl:when test="imageobject[@role='front-large']">
-                <xsl:apply-templates select="imageobject[@role='front-large']"/>
-              </xsl:when>
-              <xsl:otherwise>
-                <xsl:apply-templates select="imageobject[1]"/>
-              </xsl:otherwise>
-            </xsl:choose>
-          </xsl:element>
-          <!-- If this is defined as an explicit cover page, then process
-          any remaining text -->
-          <xsl:if test="ancestor::cover">
-            <xsl:apply-templates select="ancestor::cover/para"/>
-          </xsl:if>
-        </xsl:element>
-      </xsl:element>
-    </xsl:with-param>  
-  </xsl:call-template>  
-</xsl:template>
-
-<!-- EPUB3: use <nav> and <ol> in TOC lists  -->
-<xsl:template name="make.toc">
-  <xsl:param name="toc-context" select="."/>
-  <xsl:param name="toc.title.p" select="true()"/>
-  <xsl:param name="nodes" select="/NOT-AN-ELEMENT"/>
-
-  <xsl:variable name="nodes.plus" select="$nodes | qandaset"/>
-
-  <xsl:variable name="toc.title">
-    <xsl:if test="$toc.title.p">
-      <xsl:choose>
-        <xsl:when test="$make.clean.html != 0">
-          <div class="toc-title">
-            <xsl:call-template name="gentext">
-              <xsl:with-param name="key">TableofContents</xsl:with-param>
-            </xsl:call-template>
-          </div>
-        </xsl:when>
-        <xsl:otherwise>
-          <p>
-            <b>
-              <xsl:call-template name="gentext">
-                <xsl:with-param name="key">TableofContents</xsl:with-param>
-              </xsl:call-template>
-            </b>
-          </p>
-        </xsl:otherwise>
-      </xsl:choose>
-    </xsl:if>
-  </xsl:variable>
-
-  <xsl:choose>
-    <xsl:when test="$manual.toc != ''">
-      <xsl:variable name="id">
-        <xsl:call-template name="object.id"/>
-      </xsl:variable>
-      <xsl:variable name="toc" select="document($manual.toc, .)"/>
-      <xsl:variable name="tocentry" select="$toc//tocentry[@linkend=$id]"/>
-      <xsl:if test="$tocentry and $tocentry/*">
-        <div class="toc">
-          <xsl:copy-of select="$toc.title"/>
-          <nav epub:type="toc">
-            <xsl:element name="{$toc.list.type}">
-              <xsl:call-template name="manual-toc">
-                <xsl:with-param name="tocentry" select="$tocentry/*[1]"/>
-              </xsl:call-template>
-            </xsl:element>
-          </nav>
-        </div>
-      </xsl:if>
-    </xsl:when>
-    <xsl:otherwise>
-      <xsl:choose>
-        <xsl:when test="$qanda.in.toc != 0">
-          <div class="toc">
-            <xsl:copy-of select="$toc.title"/>
-            <nav epub:type="toc">
-              <xsl:element name="{$toc.list.type}">
-                <xsl:if test="$nodes.plus">
-                  <xsl:apply-templates select="$nodes.plus" mode="toc">
-                    <xsl:with-param name="toc-context" select="$toc-context"/>
-                  </xsl:apply-templates>
-                </xsl:if>
-              </xsl:element>
-            </nav>
-          </div>
-        </xsl:when>
-        <xsl:otherwise>
-          <div class="toc">
-            <xsl:copy-of select="$toc.title"/>
-            <nav epub:type="toc">
-              <xsl:element name="{$toc.list.type}">
-                <xsl:if test="$nodes">
-                  <xsl:apply-templates select="$nodes" mode="toc">
-                    <xsl:with-param name="toc-context" select="$toc-context"/>
-                  </xsl:apply-templates>
-                </xsl:if>
-              </xsl:element>
-            </nav>
-          </div>
-        </xsl:otherwise>
-      </xsl:choose>
-
-    </xsl:otherwise>
-  </xsl:choose>
-</xsl:template>
-
-<xsl:template name="list.of.titles">
-  <xsl:param name="toc-context" select="."/>
-  <xsl:param name="titles" select="'table'"/>
-  <xsl:param name="nodes" select=".//table"/>
-
-  <xsl:variable name="epub.type">
-    <xsl:choose>
-      <xsl:when test="$titles='table'">lot</xsl:when>
-      <xsl:when test="$titles='figure'">loi</xsl:when>
-      <xsl:when test="$titles='equation'">loi</xsl:when>
-      <xsl:when test="$titles='example'">loi</xsl:when>
-      <xsl:when test="$titles='procedure'">loi</xsl:when>
-      <xsl:otherwise>loi</xsl:otherwise>
-    </xsl:choose>
-  </xsl:variable>
-
-  <xsl:if test="$nodes">
-    <div class="list-of-{$titles}s">
-      <nav epub:type="{$epub.type}">
-        <h4 class="toc-title">
-          <xsl:call-template name="gentext">
-            <xsl:with-param name="key">
-              <xsl:choose>
-                <xsl:when test="$titles='table'">ListofTables</xsl:when>
-                <xsl:when test="$titles='figure'">ListofFigures</xsl:when>
-                <xsl:when test="$titles='equation'">ListofEquations</xsl:when>
-                <xsl:when test="$titles='example'">ListofExamples</xsl:when>
-                <xsl:when test="$titles='procedure'">ListofProcedures</xsl:when>
-                <xsl:otherwise>ListofUnknown</xsl:otherwise>
-              </xsl:choose>
-            </xsl:with-param>
-          </xsl:call-template>
-        </h4>
-
-        <xsl:element name="{$toc.list.type}">
-          <xsl:apply-templates select="$nodes" mode="toc">
-            <xsl:with-param name="toc-context" select="$toc-context"/>
-          </xsl:apply-templates>
-        </xsl:element>
-      </nav>
-    </div>
-  </xsl:if>
-</xsl:template>
-
-<!-- EPUB3: add hidden="" for sections below toc.section.depth -->
-<xsl:template name="subtoc">
-  <xsl:param name="toc-context" select="."/>
-  <xsl:param name="nodes" select="NOT-AN-ELEMENT"/>
-
-  <xsl:variable name="nodes.plus" select="$nodes | qandaset"/>
-
-  <xsl:variable name="depth">
-    <xsl:choose>
-      <xsl:when test="local-name(.) = 'section'">
-        <xsl:value-of select="count(ancestor::section) + 1"/>
-      </xsl:when>
-      <xsl:when test="local-name(.) = 'sect1'">1</xsl:when>
-      <xsl:when test="local-name(.) = 'sect2'">2</xsl:when>
-      <xsl:when test="local-name(.) = 'sect3'">3</xsl:when>
-      <xsl:when test="local-name(.) = 'sect4'">4</xsl:when>
-      <xsl:when test="local-name(.) = 'sect5'">5</xsl:when>
-      <xsl:when test="local-name(.) = 'refsect1'">1</xsl:when>
-      <xsl:when test="local-name(.) = 'refsect2'">2</xsl:when>
-      <xsl:when test="local-name(.) = 'refsect3'">3</xsl:when>
-      <xsl:when test="local-name(.) = 'simplesect'">
-        <!-- sigh... -->
-        <xsl:choose>
-          <xsl:when test="local-name(..) = 'section'">
-            <xsl:value-of select="count(ancestor::section)"/>
-          </xsl:when>
-          <xsl:when test="local-name(..) = 'sect1'">2</xsl:when>
-          <xsl:when test="local-name(..) = 'sect2'">3</xsl:when>
-          <xsl:when test="local-name(..) = 'sect3'">4</xsl:when>
-          <xsl:when test="local-name(..) = 'sect4'">5</xsl:when>
-          <xsl:when test="local-name(..) = 'sect5'">6</xsl:when>
-          <xsl:when test="local-name(..) = 'refsect1'">2</xsl:when>
-          <xsl:when test="local-name(..) = 'refsect2'">3</xsl:when>
-          <xsl:when test="local-name(..) = 'refsect3'">4</xsl:when>
-          <xsl:otherwise>1</xsl:otherwise>
-        </xsl:choose>
-      </xsl:when>
-      <xsl:otherwise>0</xsl:otherwise>
-    </xsl:choose>
-  </xsl:variable>
-
-  <xsl:variable name="depth.from.context" select="count(ancestor::*)-count($toc-context/ancestor::*)"/>
-
-  <xsl:variable name="subtoc">
-    <xsl:element name="{$toc.list.type}">
-      <xsl:choose>
-        <xsl:when test="$toc.listitem.type = 'li'
-                  and $toc.section.depth > $depth and 
-                  ( ($qanda.in.toc = 0 and count($nodes)&gt;0) or
-                    ($qanda.in.toc != 0 and count($nodes.plus)&gt;0) )
-                  and $toc.max.depth > $depth.from.context">
-          <!-- No @hidden attribute -->
-        </xsl:when>
-        <xsl:otherwise>
-          <!-- Add empty @hidden attribute if too deep -->
-          <xsl:attribute name="hidden"></xsl:attribute>
-        </xsl:otherwise>
-      </xsl:choose>
-
-      <xsl:choose>
-        <xsl:when test="$qanda.in.toc != 0">
-          <xsl:apply-templates mode="toc" select="$nodes.plus">
-            <xsl:with-param name="toc-context" select="$toc-context"/>
-          </xsl:apply-templates>
-        </xsl:when>
-        <xsl:otherwise>
-          <xsl:apply-templates mode="toc" select="$nodes">
-            <xsl:with-param name="toc-context" select="$toc-context"/>
-          </xsl:apply-templates>
-        </xsl:otherwise>
-      </xsl:choose>
-    </xsl:element>
-  </xsl:variable>
-
-  <xsl:variable name="subtoc.list">
-    <xsl:choose>
-      <xsl:when test="$toc.dd.type = ''">
-        <xsl:copy-of select="$subtoc"/>
-      </xsl:when>
-      <xsl:otherwise>
-        <xsl:element name="{$toc.dd.type}">
-          <xsl:copy-of select="$subtoc"/>
-        </xsl:element>
-      </xsl:otherwise>
-    </xsl:choose>
-  </xsl:variable>
-
-  <xsl:element name="{$toc.listitem.type}">
-    <xsl:call-template name="toc.line">
-      <xsl:with-param name="toc-context" select="$toc-context"/>
-    </xsl:call-template>
-    <xsl:if test="$toc.listitem.type = 'li'
-                  and 
-                  ( ($qanda.in.toc = 0 and count($nodes)&gt;0) or
-                    ($qanda.in.toc != 0 and count($nodes.plus)&gt;0) ) ">
-      <xsl:copy-of select="$subtoc.list"/>
-    </xsl:if>
-  </xsl:element>
-</xsl:template>
-
-<!-- Inserted when a title is blank to avoid epubcheck error -->
-<xsl:param name="toc.entry.default.text">&#xA0;</xsl:param>
-
-<!-- EPUB3: either <a> or <span>, but not both  -->
-<xsl:template name="toc.line">
-  <xsl:param name="toc-context" select="."/>
-  <xsl:param name="depth" select="1"/>
-  <xsl:param name="depth.from.context" select="8"/>
-
-  <xsl:variable name="title">
-    <xsl:apply-templates select="." mode="title.markup"/>
-  </xsl:variable>
-
-  <a>
-    <xsl:attribute name="href">
-      <xsl:call-template name="href.target">
-        <xsl:with-param name="context" select="$toc-context"/>
-        <xsl:with-param name="toc-context" select="$toc-context"/>
-      </xsl:call-template>
-    </xsl:attribute>
-    
-    <!-- * if $autotoc.label.in.hyperlink is non-zero, then output the label -->
-    <!-- * as part of the hyperlinked title -->
-    <xsl:if test="not($autotoc.label.in.hyperlink = 0)">
-      <xsl:variable name="label">
-        <xsl:apply-templates select="." mode="label.markup"/>
-      </xsl:variable>
-      <xsl:copy-of select="$label"/>
-      <xsl:if test="$label != ''">
-        <xsl:value-of select="$autotoc.label.separator"/>
-      </xsl:if>
-    </xsl:if>
-
-    <xsl:choose>
-      <xsl:when test="string-length(normalize-space($title)) != 0">
-        <xsl:copy-of select="$title"/>
-      </xsl:when>
-      <xsl:otherwise>
-        <xsl:value-of select="$toc.entry.default.text"/>
-      </xsl:otherwise>
-    </xsl:choose>
-  </a>
-</xsl:template>
-
-<!-- Make sure all text is inside the <a> element for epub3 -->
-<xsl:template match="figure|table|example|equation|procedure" mode="toc">
-  <xsl:param name="toc-context" select="."/>
-
-  <xsl:element name="{$toc.listitem.type}">
-    <a>
-      <xsl:attribute name="href">
-        <xsl:call-template name="href.target">
-          <xsl:with-param name="toc-context" select="$toc-context"/>
-        </xsl:call-template>
-      </xsl:attribute>
-      <xsl:variable name="label">
-        <xsl:apply-templates select="." mode="label.markup"/>
-      </xsl:variable>
-      <xsl:copy-of select="$label"/>
-      <xsl:if test="$label != ''">
-        <xsl:value-of select="$autotoc.label.separator"/>
-      </xsl:if>
-      <xsl:apply-templates select="." mode="titleabbrev.markup"/>
-    </a>
-  </xsl:element>
-</xsl:template>
-
-<!-- Remove spans from refentry TOC lines for epub3check -->
-<xsl:template match="refentry" mode="toc">
-  <xsl:param name="toc-context" select="."/>
-
-  <xsl:variable name="refmeta" select=".//refmeta"/>
-  <xsl:variable name="refentrytitle" select="$refmeta//refentrytitle"/>
-  <xsl:variable name="refnamediv" select=".//refnamediv"/>
-  <xsl:variable name="refname" select="$refnamediv//refname"/>
-  <xsl:variable name="refdesc" select="$refnamediv//refdescriptor"/>
-  <xsl:variable name="title">
-    <xsl:choose>
-      <xsl:when test="$refentrytitle">
-        <xsl:apply-templates select="$refentrytitle[1]" mode="titleabbrev.markup"/>
-      </xsl:when>
-      <xsl:when test="$refdesc">
-        <xsl:apply-templates select="$refdesc" mode="titleabbrev.markup"/>
-      </xsl:when>
-      <xsl:when test="$refname">
-        <xsl:apply-templates select="$refname[1]" mode="titleabbrev.markup"/>
-      </xsl:when>
-    </xsl:choose>
-  </xsl:variable>
-
-  <xsl:element name="{$toc.listitem.type}" namespace="http://www.w3.org/1999/xhtml">
-    <a>
-      <xsl:attribute name="href">
-        <xsl:call-template name="href.target">
-          <xsl:with-param name="toc-context" select="$toc-context"/>
-        </xsl:call-template>
-      </xsl:attribute>
-      <xsl:copy-of select="$title"/>
-      <xsl:if test="$annotate.toc != 0">
-        <!-- * DocBook 5 says inlinemediaobject (among other things) -->
-        <!-- * is allowed in refpurpose; so we need to run -->
-        <!-- * apply-templates on refpurpose here, instead of value-of  -->
-        <!-- Set allow-anchors=0 to avoid indexterms and other links -->
-        <xsl:text> - </xsl:text>
-        <xsl:apply-templates select="refnamediv/refpurpose" mode="no.anchor.mode"/>
-      </xsl:if>
-    </a>
-  </xsl:element>
-</xsl:template>
-
-<!-- Copy these here so relative document() open gets the correct css source -->
-<xsl:template name="generate.default.css.file">
-  <xsl:if test="$make.clean.html != 0 and 
-                $generate.css.header = 0 and
-                $docbook.css.source != ''">
-    <!-- Select default file relative to stylesheet -->
-    <xsl:variable name="css.node" select="document($docbook.css.source)/*[1]"/>
-
-    <xsl:call-template name="generate.css.file">
-      <xsl:with-param name="src" select="$docbook.css.source"/>
-      <xsl:with-param name="css.node" select="$css.node"/>
-    </xsl:call-template>
-  </xsl:if>
-</xsl:template>
-
-<xsl:template name="generate.custom.css.file">
-  <xsl:if test="$custom.css.source != '' and
-                $generate.css.header = 0">
-    <!-- Select custom file relative to document -->
-    <xsl:variable name="css.node" select="document($custom.css.source,.)/*[1]"/>
-
-    <xsl:call-template name="generate.css.file">
-      <xsl:with-param name="src" select="$custom.css.source"/>
-      <xsl:with-param name="css.node" select="$css.node"/>
-    </xsl:call-template>
-  </xsl:if>
-</xsl:template>
-
-</xsl:stylesheet>

+ 0 - 54
stylesheets/lfs-xsl/docbook-xsl-1.78.1/epub3/profile-chunk.xsl

@@ -1,54 +0,0 @@
-<?xml version="1.0" encoding="ASCII"?>
-<!--This file was created automatically by html2xhtml-->
-<!--from the HTML stylesheets.-->
-<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" xmlns:exsl="http://exslt.org/common" xmlns="http://www.w3.org/1999/xhtml" version="1.0" exclude-result-prefixes="exsl">
-
-<!-- ********************************************************************
-     $Id: profile-chunk.xsl,v 1.1 2011-09-16 21:43:45 bobs Exp $
-     ********************************************************************
-
-     This file is part of the XSL DocBook Stylesheet distribution.
-     See ../README or http://docbook.sf.net/release/xsl/current/ for
-     copyright and other information.
-
-     ******************************************************************** -->
-
-<!-- ==================================================================== -->
-
-<!-- First import the non-chunking templates that format elements
-     within each chunk file. In a customization, you should
-     create a separate non-chunking customization layer such
-     as mydocbook.xsl that imports the original docbook.xsl and
-     customizes any presentation templates. Then your chunking
-     customization should import mydocbook.xsl instead of
-     docbook.xsl.  -->
-<xsl:import href="docbook.xsl"/>
-
-<!-- chunk-common.xsl contains all the named templates for chunking.
-     In a customization file, you import chunk-common.xsl, then
-     add any customized chunking templates of the same name. 
-     They will have import precedence over the original 
-     chunking templates in chunk-common.xsl. -->
-<xsl:import href="../xhtml/chunk-common.xsl"/>
-
-<!-- The manifest.xsl module is no longer imported because its
-     templates were moved into chunk-common and chunk-code -->
-
-<!-- chunk-code.xsl contains all the chunking templates that use
-     a match attribute.  In a customization it should be referenced
-     using <xsl:include> instead of <xsl:import>, and then add
-     any customized chunking templates with match attributes. But be sure
-     to add a priority="1" to such customized templates to resolve
-     its conflict with the original, since they have the
-     same import precedence.
-     
-     Using xsl:include prevents adding another layer
-     of import precedence, which would cause any
-     customizations that use xsl:apply-imports to wrongly
-     apply the chunking version instead of the original
-     non-chunking version to format an element.  -->
-<xsl:include href="../xhtml/profile-chunk-code.xsl"/>
-
-<xsl:include href="epub3-chunk-mods.xsl"/>
-
-</xsl:stylesheet>

+ 0 - 408
stylesheets/lfs-xsl/docbook-xsl-1.78.1/epub3/profile-docbook.xsl

@@ -1,408 +0,0 @@
-<?xml version="1.0" encoding="ASCII"?>
-<!--This file was created automatically by html2xhtml-->
-<!--from the HTML stylesheets.-->
-<!--This file was created automatically by xsl2profile-->
-<!--from the DocBook XSL stylesheets.-->
-<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" xmlns:ng="http://docbook.org/docbook-ng" xmlns:db="http://docbook.org/ns/docbook" xmlns:exsl="http://exslt.org/common" xmlns:exslt="http://exslt.org/common" xmlns="http://www.w3.org/1999/xhtml" exslt:dummy="dummy" ng:dummy="dummy" db:dummy="dummy" extension-element-prefixes="exslt" exclude-result-prefixes="db ng exsl exslt exslt" version="1.0">
-
-<xsl:output method="xml" encoding="UTF-8" indent="no"/>
-
-<!-- ********************************************************************
-     $Id: profile-docbook.xsl,v 1.1 2011-09-16 21:43:45 bobs Exp $
-     ********************************************************************
-
-     This file is part of the XSL DocBook Stylesheet distribution.
-     See ../README or http://docbook.sf.net/release/xsl/current/ for
-     copyright and other information.
-
-     ******************************************************************** -->
-
-<!-- ==================================================================== -->
-
-<xsl:include href="../VERSION.xsl"/>
-<xsl:include href="../xhtml/param.xsl"/>
-<xsl:include href="../lib/lib.xsl"/>
-<xsl:include href="../common/l10n.xsl"/>
-<xsl:include href="../common/common.xsl"/>
-<xsl:include href="../common/utility.xsl"/>
-<xsl:include href="../common/labels.xsl"/>
-<xsl:include href="../common/titles.xsl"/>
-<xsl:include href="../common/subtitles.xsl"/>
-<xsl:include href="../common/gentext.xsl"/>
-<xsl:include href="../common/targets.xsl"/>
-<xsl:include href="../common/olink.xsl"/>
-<xsl:include href="../common/pi.xsl"/>
-<xsl:include href="../xhtml/autotoc.xsl"/>
-<xsl:include href="../xhtml/autoidx.xsl"/>
-<xsl:include href="../xhtml/lists.xsl"/>
-<xsl:include href="../xhtml/callout.xsl"/>
-<xsl:include href="../xhtml/verbatim.xsl"/>
-<xsl:include href="../xhtml/graphics.xsl"/>
-<xsl:include href="../xhtml/xref.xsl"/>
-<xsl:include href="../xhtml/formal.xsl"/>
-<xsl:include href="../xhtml/table.xsl"/>
-<xsl:include href="../xhtml/htmltbl.xsl"/>
-<xsl:include href="../xhtml/sections.xsl"/>
-<xsl:include href="../xhtml/inline.xsl"/>
-<xsl:include href="../xhtml/footnote.xsl"/>
-<xsl:include href="../xhtml/html.xsl"/>
-<xsl:include href="../xhtml/info.xsl"/>
-<xsl:include href="../xhtml/keywords.xsl"/>
-<xsl:include href="../xhtml/division.xsl"/>
-<xsl:include href="../xhtml/toc.xsl"/>
-<xsl:include href="../xhtml/index.xsl"/>
-<xsl:include href="../xhtml/refentry.xsl"/>
-<xsl:include href="../xhtml/math.xsl"/>
-<xsl:include href="../xhtml/admon.xsl"/>
-<xsl:include href="../xhtml/component.xsl"/>
-<xsl:include href="../xhtml/biblio.xsl"/>
-<xsl:include href="../xhtml/biblio-iso690.xsl"/>
-<xsl:include href="../xhtml/glossary.xsl"/>
-<xsl:include href="../xhtml/block.xsl"/>
-<xsl:include href="../xhtml/task.xsl"/>
-<xsl:include href="../xhtml/qandaset.xsl"/>
-<xsl:include href="../xhtml/synop.xsl"/>
-<xsl:include href="../xhtml/titlepage.xsl"/>
-<xsl:include href="../xhtml/titlepage.templates.xsl"/>
-<xsl:include href="../xhtml/pi.xsl"/>
-<xsl:include href="../xhtml/ebnf.xsl"/>
-<xsl:include href="../xhtml/chunker.xsl"/>
-<xsl:include href="../xhtml/html-rtf.xsl"/>
-<xsl:include href="../xhtml/annotations.xsl"/>
-<xsl:include href="../common/stripns.xsl"/>
-
-<xsl:param name="stylesheet.result.type" select="'xhtml'"/>
-<xsl:param name="htmlhelp.output" select="0"/>
-
-<!-- ==================================================================== -->
-
-<xsl:key name="id" match="*" use="@id|@xml:id"/>
-<xsl:key name="gid" match="*" use="generate-id()"/>
-
-<!-- ==================================================================== -->
-
-<xsl:template match="*">
-  <xsl:message>
-    <xsl:text>Element </xsl:text>
-    <xsl:value-of select="local-name(.)"/>
-    <xsl:text> in namespace '</xsl:text>
-    <xsl:value-of select="namespace-uri(.)"/>
-    <xsl:text>' encountered</xsl:text>
-    <xsl:if test="parent::*">
-      <xsl:text> in </xsl:text>
-      <xsl:value-of select="name(parent::*)"/>
-    </xsl:if>
-    <xsl:text>, but no template matches.</xsl:text>
-  </xsl:message>
-
-  <span style="color: red">
-    <xsl:text>&lt;</xsl:text>
-    <xsl:value-of select="name(.)"/>
-    <xsl:text>&gt;</xsl:text>
-    <xsl:apply-templates/>
-    <xsl:text>&lt;/</xsl:text>
-    <xsl:value-of select="name(.)"/>
-    <xsl:text>&gt;</xsl:text>
-  </span>
-</xsl:template>
-
-<xsl:template match="text()">
-  <xsl:value-of select="."/>
-</xsl:template>
-
-<xsl:template name="body.attributes"><xslo:if xmlns:xslo="http://www.w3.org/1999/XSL/Transform" test="starts-with($writing.mode, 'rl')"><xslo:attribute name="dir">rtl</xslo:attribute></xslo:if>
-<!-- no apply-templates; make it empty except for dir for rtl-->
-</xsl:template>
-
-<xsl:template name="head.content">
-  <xsl:param name="node" select="."/>
-  <xsl:param name="title">
-    <xsl:apply-templates select="$node" mode="object.title.markup.textonly"/>
-  </xsl:param>
-
-  <title>
-    <xsl:copy-of select="$title"/>
-  </title>
-
-  <xsl:if test="$html.base != ''">
-    <base href="{$html.base}"/>
-  </xsl:if>
-
-  <!-- Insert links to CSS files or insert literal style elements -->
-  <xsl:call-template name="generate.css"/>
-
-  <xsl:if test="$html.stylesheet != ''">
-    <xsl:call-template name="output.html.stylesheets">
-      <xsl:with-param name="stylesheets" select="normalize-space($html.stylesheet)"/>
-    </xsl:call-template>
-  </xsl:if>
-
-  <xsl:if test="$link.mailto.url != ''">
-    <link rev="made" href="{$link.mailto.url}"/>
-  </xsl:if>
-
-  <meta name="generator" content="DocBook {$DistroTitle} V{$VERSION}"/>
-
-  <xsl:if test="$generate.meta.abstract != 0">
-    <xsl:variable name="info" select="(articleinfo                                       |bookinfo                                       |prefaceinfo                                       |chapterinfo                                       |appendixinfo                                       |sectioninfo                                       |sect1info                                       |sect2info                                       |sect3info                                       |sect4info                                       |sect5info                                       |referenceinfo                                       |refentryinfo                                       |partinfo                                       |info                                       |docinfo)[1]"/>
-    <xsl:if test="$info and $info/abstract">
-      <meta name="description">
-        <xsl:attribute name="content">
-          <xsl:for-each select="$info/abstract[1]/*">
-            <xsl:value-of select="normalize-space(.)"/>
-            <xsl:if test="position() &lt; last()">
-              <xsl:text> </xsl:text>
-            </xsl:if>
-          </xsl:for-each>
-        </xsl:attribute>
-      </meta>
-    </xsl:if>
-  </xsl:if>
-
-  <xsl:if test="($draft.mode = 'yes' or                 ($draft.mode = 'maybe' and                 ancestor-or-self::*[@status][1]/@status = 'draft'))                 and $draft.watermark.image != ''">
-    <style type="text/css"><xsl:text>
-body { background-image: url('</xsl:text>
-<xsl:value-of select="$draft.watermark.image"/><xsl:text>');
-       background-repeat: no-repeat;
-       background-position: top left;
-       /* The following properties make the watermark "fixed" on the page. */
-       /* I think that's just a bit too distracting for the reader... */
-       /* background-attachment: fixed; */
-       /* background-position: center center; */
-     }</xsl:text>
-    </style>
-  </xsl:if>
-  <xsl:apply-templates select="." mode="head.keywords.content"/>
-</xsl:template>
-
-<xsl:template name="output.html.stylesheets">
-  <xsl:param name="stylesheets" select="''"/>
-
-  <xsl:choose>
-    <xsl:when test="contains($stylesheets, ' ')">
-      <xsl:variable name="css.filename" select="substring-before($stylesheets, ' ')"/>
-
-      <xsl:call-template name="make.css.link">
-        <xsl:with-param name="css.filename" select="$css.filename"/>
-      </xsl:call-template>
-
-      <xsl:call-template name="output.html.stylesheets">
-        <xsl:with-param name="stylesheets" select="substring-after($stylesheets, ' ')"/>
-      </xsl:call-template>
-    </xsl:when>
-    <xsl:when test="$stylesheets != ''">
-      <xsl:call-template name="make.css.link">
-        <xsl:with-param name="css.filename" select="$stylesheets"/>
-      </xsl:call-template>
-    </xsl:when>
-  </xsl:choose>
-</xsl:template>
-
-<!-- ============================================================ -->
-
-<xsl:template match="*" mode="head.keywords.content">
-  <xsl:apply-templates select="chapterinfo/keywordset" mode="html.header"/>
-  <xsl:apply-templates select="appendixinfo/keywordset" mode="html.header"/>
-  <xsl:apply-templates select="prefaceinfo/keywordset" mode="html.header"/>
-  <xsl:apply-templates select="bookinfo/keywordset" mode="html.header"/>
-  <xsl:apply-templates select="setinfo/keywordset" mode="html.header"/>
-  <xsl:apply-templates select="articleinfo/keywordset" mode="html.header"/>
-  <xsl:apply-templates select="artheader/keywordset" mode="html.header"/>
-  <xsl:apply-templates select="sect1info/keywordset" mode="html.header"/>
-  <xsl:apply-templates select="sect2info/keywordset" mode="html.header"/>
-  <xsl:apply-templates select="sect3info/keywordset" mode="html.header"/>
-  <xsl:apply-templates select="sect4info/keywordset" mode="html.header"/>
-  <xsl:apply-templates select="sect5info/keywordset" mode="html.header"/>
-  <xsl:apply-templates select="sectioninfo/keywordset" mode="html.header"/>
-  <xsl:apply-templates select="refsect1info/keywordset" mode="html.header"/>
-  <xsl:apply-templates select="refsect2info/keywordset" mode="html.header"/>
-  <xsl:apply-templates select="refsect3info/keywordset" mode="html.header"/>
-  <xsl:apply-templates select="bibliographyinfo/keywordset" mode="html.header"/>
-  <xsl:apply-templates select="glossaryinfo/keywordset" mode="html.header"/>
-  <xsl:apply-templates select="indexinfo/keywordset" mode="html.header"/>
-  <xsl:apply-templates select="refentryinfo/keywordset" mode="html.header"/>
-  <xsl:apply-templates select="partinfo/keywordset" mode="html.header"/>
-  <xsl:apply-templates select="referenceinfo/keywordset" mode="html.header"/>
-  <xsl:apply-templates select="docinfo/keywordset" mode="html.header"/>
-  <xsl:apply-templates select="info/keywordset" mode="html.header"/>
-
-  <xsl:if test="$inherit.keywords != 0                 and parent::*">
-    <xsl:apply-templates select="parent::*" mode="head.keywords.content"/>
-  </xsl:if>
-</xsl:template>
-
-<!-- ============================================================ -->
-
-<xsl:template name="system.head.content">
-  <xsl:param name="node" select="."/>
-
-  <!-- FIXME: When chunking, only the annotations actually used
-              in this chunk should be referenced. I don't think it
-              does any harm to reference them all, but it adds
-              unnecessary bloat to each chunk. -->
-  <xsl:if test="$annotation.support != 0 and //annotation">
-    <xsl:call-template name="add.annotation.links"/>
-    <script type="text/javascript">
-      <xsl:text>
-// Create PopupWindow objects</xsl:text>
-      <xsl:for-each select="//annotation">
-        <xsl:text>
-var popup_</xsl:text>
-        <xsl:value-of select="generate-id(.)"/>
-        <xsl:text> = new PopupWindow("popup-</xsl:text>
-        <xsl:value-of select="generate-id(.)"/>
-        <xsl:text>");
-</xsl:text>
-        <xsl:text>popup_</xsl:text>
-        <xsl:value-of select="generate-id(.)"/>
-        <xsl:text>.offsetY = 15;
-</xsl:text>
-        <xsl:text>popup_</xsl:text>
-        <xsl:value-of select="generate-id(.)"/>
-        <xsl:text>.autoHide();
-</xsl:text>
-      </xsl:for-each>
-    </script>
-
-    <style type="text/css">
-      <xsl:value-of select="$annotation.css"/>
-    </style>
-  </xsl:if>
-
-  <!-- system.head.content is like user.head.content, except that
-       it is called before head.content. This is important because it
-       means, for example, that <style> elements output by system.head.content
-       have a lower CSS precedence than the users stylesheet. -->
-</xsl:template>
-
-<!-- ============================================================ -->
-
-<xsl:template name="user.preroot">
-  <!-- Pre-root output, can be used to output comments and PIs. -->
-  <!-- This must not output any element content! -->
-</xsl:template>
-
-<xsl:template name="user.head.content">
-  <xsl:param name="node" select="."/>
-</xsl:template>
-
-<xsl:template name="user.header.navigation">
-  <xsl:param name="node" select="."/>
-</xsl:template>
-
-<xsl:template name="user.header.content">
-  <xsl:param name="node" select="."/>
-</xsl:template>
-
-<xsl:template name="user.footer.content">
-  <xsl:param name="node" select="."/>
-</xsl:template>
-
-<xsl:template name="user.footer.navigation">
-  <xsl:param name="node" select="."/>
-</xsl:template>
-
-<xslo:include xmlns:xslo="http://www.w3.org/1999/XSL/Transform" href="../profiling/profile-mode.xsl"/><xslo:variable xmlns:xslo="http://www.w3.org/1999/XSL/Transform" name="profiled-content"><xslo:choose><xslo:when test="*/self::ng:* or */self::db:*"><xslo:message>Note: namesp. cut : stripped namespace before processing</xslo:message><xslo:variable name="stripped-content"><xslo:apply-templates select="/" mode="stripNS"/></xslo:variable><xslo:message>Note: namesp. cut : processing stripped document</xslo:message><xslo:apply-templates select="exslt:node-set($stripped-content)" mode="profile"/></xslo:when><xslo:otherwise><xslo:apply-templates select="/" mode="profile"/></xslo:otherwise></xslo:choose></xslo:variable><xslo:variable xmlns:xslo="http://www.w3.org/1999/XSL/Transform" name="profiled-nodes" select="exslt:node-set($profiled-content)"/><xsl:template match="/">
-  <!-- * Get a title for current doc so that we let the user -->
-  <!-- * know what document we are processing at this point. -->
-  <xsl:variable name="doc.title">
-    <xsl:call-template name="get.doc.title"/>
-  </xsl:variable>
-  <xsl:choose>
-    <!-- Hack! If someone hands us a DocBook V5.x or DocBook NG document,
-         toss the namespace and continue.  Use the docbook5 namespaced
-         stylesheets for DocBook5 if you don't want to use this feature.-->
-    <!-- include extra test for Xalan quirk -->
-    <xsl:when test="false()"/>
-    <!-- Can't process unless namespace removed -->
-    <xsl:when test="false()"/>
-    <xsl:otherwise>
-      <xsl:choose>
-        <xsl:when test="$rootid != ''">
-          <xsl:choose>
-            <xsl:when test="count($profiled-nodes//*[@id=$rootid]) = 0">
-              <xsl:message terminate="yes">
-                <xsl:text>ID '</xsl:text>
-                <xsl:value-of select="$rootid"/>
-                <xsl:text>' not found in document.</xsl:text>
-              </xsl:message>
-            </xsl:when>
-            <xsl:otherwise>
-              <xsl:if test="$collect.xref.targets = 'yes' or                             $collect.xref.targets = 'only'">
-                <xsl:apply-templates select="key('id', $rootid)" mode="collect.targets"/>
-              </xsl:if>
-              <xsl:if test="$collect.xref.targets != 'only'">
-                <xsl:apply-templates select="$profiled-nodes//*[@id=$rootid]" mode="process.root"/>
-                <xsl:if test="$tex.math.in.alt != ''">
-                  <xsl:apply-templates select="$profiled-nodes//*[@id=$rootid]" mode="collect.tex.math"/>
-                </xsl:if>
-              </xsl:if>
-            </xsl:otherwise>
-          </xsl:choose>
-        </xsl:when>
-        <xsl:otherwise>
-          <xsl:if test="$collect.xref.targets = 'yes' or                         $collect.xref.targets = 'only'">
-            <xsl:apply-templates select="$profiled-nodes" mode="collect.targets"/>
-          </xsl:if>
-          <xsl:if test="$collect.xref.targets != 'only'">
-            <xsl:apply-templates select="$profiled-nodes" mode="process.root"/>
-            <xsl:if test="$tex.math.in.alt != ''">
-              <xsl:apply-templates select="$profiled-nodes" mode="collect.tex.math"/>
-            </xsl:if>
-          </xsl:if>
-        </xsl:otherwise>
-      </xsl:choose>
-    </xsl:otherwise>
-  </xsl:choose>
-</xsl:template>
-
-<xsl:template match="*" mode="process.root">
-  <xsl:variable name="doc" select="self::*"/>
-
-  <xsl:call-template name="user.preroot"/>
-  <xsl:call-template name="root.messages"/>
-
-  <html>
-    <head>
-      <xsl:call-template name="system.head.content">
-        <xsl:with-param name="node" select="$doc"/>
-      </xsl:call-template>
-      <xsl:call-template name="head.content">
-        <xsl:with-param name="node" select="$doc"/>
-      </xsl:call-template>
-      <xsl:call-template name="user.head.content">
-        <xsl:with-param name="node" select="$doc"/>
-      </xsl:call-template>
-    </head>
-    <body>
-      <xsl:call-template name="body.attributes"/>
-      <xsl:call-template name="user.header.content">
-        <xsl:with-param name="node" select="$doc"/>
-      </xsl:call-template>
-      <xsl:apply-templates select="."/>
-      <xsl:call-template name="user.footer.content">
-        <xsl:with-param name="node" select="$doc"/>
-      </xsl:call-template>
-    </body>
-  </html>
-  <xsl:value-of select="$html.append"/>
-  
-  <!-- Generate any css files only once, not once per chunk -->
-  <xsl:call-template name="generate.css.files"/>
-</xsl:template>
-
-<xsl:template name="root.messages">
-  <!-- redefine this any way you'd like to output messages -->
-  <!-- DO NOT OUTPUT ANYTHING FROM THIS TEMPLATE -->
-</xsl:template>
-
-<!-- ==================================================================== -->
-
-<xsl:template name="chunk">
-  <xsl:param name="node" select="."/>
-
-  <!-- The default is that we are not chunking... -->
-  <xsl:text>0</xsl:text>
-</xsl:template>
-
-</xsl:stylesheet>

+ 0 - 712
stylesheets/lfs-xsl/docbook-xsl-1.78.1/epub3/titlepage.templates.xml

@@ -1,712 +0,0 @@
-<t:templates xmlns:t="http://nwalsh.com/docbook/xsl/template/1.0"
-             xmlns:param="http://nwalsh.com/docbook/xsl/template/1.0/param"
-             xmlns="http://www.w3.org/1999/xhtml"
-             xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
-
-<!-- ==================================================================== -->
-
-<t:titlepage t:element="article" t:wrapper="div" class="titlepage">
-  <t:titlepage-content t:side="recto">
-    <title/>
-    <subtitle/>
-    <corpauthor/>
-    <authorgroup/>
-    <author/>
-    <othercredit/>
-    <releaseinfo/>
-    <copyright/>
-    <legalnotice/>
-    <pubdate/>
-    <revision/>
-    <revhistory/>
-    <abstract/>
-  </t:titlepage-content>
-
-  <t:titlepage-content t:side="verso">
-  </t:titlepage-content>
-
-  <t:titlepage-separator>
-    <hr/>
-  </t:titlepage-separator>
-
-  <t:titlepage-before t:side="recto">
-  </t:titlepage-before>
-
-  <t:titlepage-before t:side="verso">
-  </t:titlepage-before>
-</t:titlepage>
-
-<!-- ==================================================================== -->
-
-<t:titlepage t:element="set" t:wrapper="div" class="titlepage">
-  <t:titlepage-content t:side="recto">
-    <title/>
-    <subtitle/>
-    <corpauthor/>
-    <authorgroup/>
-    <author/>
-    <othercredit/>
-    <releaseinfo/>
-    <copyright/>
-    <legalnotice/>
-    <pubdate/>
-    <revision/>
-    <revhistory/>
-    <abstract/>
-  </t:titlepage-content>
-
-  <t:titlepage-content t:side="verso">
-  </t:titlepage-content>
-
-  <t:titlepage-separator>
-    <hr/>
-  </t:titlepage-separator>
-
-  <t:titlepage-before t:side="recto">
-  </t:titlepage-before>
-
-  <t:titlepage-before t:side="verso">
-  </t:titlepage-before>
-</t:titlepage>
-
-<!-- ==================================================================== -->
-
-<t:titlepage t:element="book" t:wrapper="div" class="titlepage">
-  <t:titlepage-content t:side="recto">
-    <title/>
-    <subtitle/>
-    <isbn/>
-    <issn/>
-    <biblioid/>
-    <corpauthor/>
-    <authorgroup/>
-    <author/>
-    <othercredit/>
-    <releaseinfo/>
-    <copyright/>
-    <legalnotice/>
-    <pubdate/>
-    <revision/>
-    <revhistory/>
-    <abstract/>
-  </t:titlepage-content>
-
-  <t:titlepage-content t:side="verso">
-  </t:titlepage-content>
-
-  <t:titlepage-separator>
-    <hr/>
-  </t:titlepage-separator>
-
-  <t:titlepage-before t:side="recto">
-  </t:titlepage-before>
-
-  <t:titlepage-before t:side="verso">
-  </t:titlepage-before>
-</t:titlepage>
-
-<!-- ==================================================================== -->
-
-<t:titlepage t:element="part" t:wrapper="div" class="titlepage">
-  <t:titlepage-content t:side="recto">
-    <title
-           t:force="1"
-           t:named-template="division.title"
-           param:node="ancestor-or-self::part[1]"/>
-    <subtitle/>
-    <corpauthor/>
-    <authorgroup/>
-    <author/>
-    <othercredit/>
-    <releaseinfo/>
-    <copyright/>
-    <legalnotice/>
-    <pubdate/>
-    <revision/>
-    <revhistory/>
-    <abstract/>
-  </t:titlepage-content>
-
-  <t:titlepage-content t:side="verso">
-  </t:titlepage-content>
-
-  <t:titlepage-separator>
-  </t:titlepage-separator>
-
-  <t:titlepage-before t:side="recto">
-  </t:titlepage-before>
-
-  <t:titlepage-before t:side="verso">
-  </t:titlepage-before>
-</t:titlepage>
-
-<t:titlepage t:element="partintro" t:wrapper="div">
-  <t:titlepage-content t:side="recto">
-    <title/>
-    <subtitle/>
-    <corpauthor/>
-    <authorgroup/>
-    <author/>
-    <othercredit/>
-    <releaseinfo/>
-    <copyright/>
-    <legalnotice/>
-    <pubdate/>
-    <revision/>
-    <revhistory/>
-    <abstract/>
-  </t:titlepage-content>
-
-  <t:titlepage-content t:side="verso">
-  </t:titlepage-content>
-
-  <t:titlepage-separator>
-  </t:titlepage-separator>
-
-  <t:titlepage-before t:side="recto">
-  </t:titlepage-before>
-
-  <t:titlepage-before t:side="verso">
-  </t:titlepage-before>
-</t:titlepage>
-
-<!-- ==================================================================== -->
-
-<t:titlepage t:element="reference" t:wrapper="div" class="titlepage">
-  <t:titlepage-content t:side="recto">
-    <title/>
-    <subtitle/>
-    <corpauthor/>
-    <authorgroup/>
-    <author/>
-    <othercredit/>
-    <releaseinfo/>
-    <copyright/>
-    <legalnotice/>
-    <pubdate/>
-    <revision/>
-    <revhistory/>
-    <abstract/>
-  </t:titlepage-content>
-
-  <t:titlepage-content t:side="verso">
-  </t:titlepage-content>
-
-  <t:titlepage-separator>
-    <hr/>
-  </t:titlepage-separator>
-
-  <t:titlepage-before t:side="recto">
-  </t:titlepage-before>
-
-  <t:titlepage-before t:side="verso">
-  </t:titlepage-before>
-</t:titlepage>
-
-<!-- ==================================================================== -->
-
-<t:titlepage t:element="refentry" t:wrapper="div" class="titlepage">
-  <t:titlepage-content t:side="recto">
-<!-- uncomment this if you want refentry titlepages
-    <title t:force="1"
-           t:named-template="refentry.title"
-           param:node="ancestor-or-self::refentry[1]"/>
--->
-  </t:titlepage-content>
-
-  <t:titlepage-content t:side="verso">
-  </t:titlepage-content>
-
-  <t:titlepage-separator/>
-
-  <t:titlepage-before t:side="recto">
-  </t:titlepage-before>
-
-  <t:titlepage-before t:side="verso">
-  </t:titlepage-before>
-</t:titlepage>
-
-<!-- ==================================================================== -->
-
-  <t:titlepage t:element="dedication" t:wrapper="div" class="titlepage">
-    <t:titlepage-content t:side="recto">
-    <title
-           t:force="1"
-           t:named-template="component.title"
-           param:node="ancestor-or-self::dedication[1]"/>
-    <subtitle/>
-    </t:titlepage-content>
-
-  <t:titlepage-content t:side="verso">
-  </t:titlepage-content>
-
-  <t:titlepage-separator>
-  </t:titlepage-separator>
-
-  <t:titlepage-before t:side="recto">
-  </t:titlepage-before>
-
-  <t:titlepage-before t:side="verso">
-  </t:titlepage-before>
-</t:titlepage>
-
-<!-- ==================================================================== -->
-
-<t:titlepage t:element="acknowledgements" t:wrapper="div" class="titlepage">
-    <t:titlepage-content t:side="recto">
-    <title
-           t:force="1"
-           t:named-template="component.title"
-           param:node="ancestor-or-self::acknowledgements[1]"/>
-    <subtitle/>
-    </t:titlepage-content>
-
-  <t:titlepage-content t:side="verso">
-  </t:titlepage-content>
-
-  <t:titlepage-separator>
-  </t:titlepage-separator>
-
-  <t:titlepage-before t:side="recto">
-  </t:titlepage-before>
-
-  <t:titlepage-before t:side="verso">
-  </t:titlepage-before>
-</t:titlepage>
-
-<!-- ==================================================================== -->
-
-<t:titlepage t:element="preface" t:wrapper="div" class="titlepage">
-  <t:titlepage-content t:side="recto">
-    <title/>
-    <subtitle/>
-    <corpauthor/>
-    <authorgroup/>
-    <author/>
-    <othercredit/>
-    <releaseinfo/>
-    <copyright/>
-    <legalnotice/>
-    <pubdate/>
-    <revision/>
-    <revhistory/>
-    <abstract/>
-  </t:titlepage-content>
-
-  <t:titlepage-content t:side="verso">
-  </t:titlepage-content>
-
-  <t:titlepage-separator>
-  </t:titlepage-separator>
-
-  <t:titlepage-before t:side="recto">
-  </t:titlepage-before>
-
-  <t:titlepage-before t:side="verso">
-  </t:titlepage-before>
-</t:titlepage>
-
-<!-- ==================================================================== -->
-
-<t:titlepage t:element="chapter" t:wrapper="div" class="titlepage">
-  <t:titlepage-content t:side="recto">
-    <title/>
-    <subtitle/>
-    <corpauthor/>
-    <authorgroup/>
-    <author/>
-    <othercredit/>
-    <releaseinfo/>
-    <copyright/>
-    <legalnotice/>
-    <pubdate/>
-    <revision/>
-    <revhistory/>
-    <abstract/>
-  </t:titlepage-content>
-
-  <t:titlepage-content t:side="verso">
-  </t:titlepage-content>
-
-  <t:titlepage-separator>
-  </t:titlepage-separator>
-
-  <t:titlepage-before t:side="recto">
-  </t:titlepage-before>
-
-  <t:titlepage-before t:side="verso">
-  </t:titlepage-before>
-</t:titlepage>
-
-<!-- ==================================================================== -->
-
-<t:titlepage t:element="appendix" t:wrapper="div" class="titlepage">
-  <t:titlepage-content t:side="recto">
-    <title/>
-    <subtitle/>
-    <corpauthor/>
-    <authorgroup/>
-    <author/>
-    <othercredit/>
-    <releaseinfo/>
-    <copyright/>
-    <legalnotice/>
-    <pubdate/>
-    <revision/>
-    <revhistory/>
-    <abstract/>
-  </t:titlepage-content>
-
-  <t:titlepage-content t:side="verso">
-  </t:titlepage-content>
-
-  <t:titlepage-separator>
-  </t:titlepage-separator>
-
-  <t:titlepage-before t:side="recto">
-  </t:titlepage-before>
-
-  <t:titlepage-before t:side="verso">
-  </t:titlepage-before>
-</t:titlepage>
-
-<!-- ==================================================================== -->
-
-<t:titlepage t:element="section" t:wrapper="div" class="titlepage">
-  <t:titlepage-content t:side="recto">
-    <title/>
-    <subtitle/>
-    <corpauthor/>
-    <authorgroup/>
-    <author/>
-    <othercredit/>
-    <releaseinfo/>
-    <copyright/>
-    <legalnotice/>
-    <pubdate/>
-    <revision/>
-    <revhistory/>
-    <abstract/>
-  </t:titlepage-content>
-
-  <t:titlepage-content t:side="verso">
-  </t:titlepage-content>
-
-  <t:titlepage-separator>
-    <xsl:if test="count(parent::*)='0'"><hr/></xsl:if>
-  </t:titlepage-separator>
-
-  <t:titlepage-before t:side="recto">
-  </t:titlepage-before>
-
-  <t:titlepage-before t:side="verso">
-  </t:titlepage-before>
-</t:titlepage>
-
-<t:titlepage t:element="sect1" t:wrapper="div" class="titlepage">
-  <t:titlepage-content t:side="recto">
-    <title/>
-    <subtitle/>
-    <corpauthor/>
-    <authorgroup/>
-    <author/>
-    <othercredit/>
-    <releaseinfo/>
-    <copyright/>
-    <legalnotice/>
-    <pubdate/>
-    <revision/>
-    <revhistory/>
-    <abstract/>
-  </t:titlepage-content>
-
-  <t:titlepage-content t:side="verso">
-  </t:titlepage-content>
-
-  <t:titlepage-separator>
-    <xsl:if test="count(parent::*)='0'"><hr/></xsl:if>
-  </t:titlepage-separator>
-
-  <t:titlepage-before t:side="recto">
-  </t:titlepage-before>
-
-  <t:titlepage-before t:side="verso">
-  </t:titlepage-before>
-</t:titlepage>
-
-<t:titlepage t:element="sect2" t:wrapper="div" class="titlepage">
-  <t:titlepage-content t:side="recto">
-    <title/>
-    <subtitle/>
-    <corpauthor/>
-    <authorgroup/>
-    <author/>
-    <othercredit/>
-    <releaseinfo/>
-    <copyright/>
-    <legalnotice/>
-    <pubdate/>
-    <revision/>
-    <revhistory/>
-    <abstract/>
-  </t:titlepage-content>
-
-  <t:titlepage-content t:side="verso">
-  </t:titlepage-content>
-
-  <t:titlepage-separator>
-    <xsl:if test="count(parent::*)='0'"><hr/></xsl:if>
-  </t:titlepage-separator>
-
-  <t:titlepage-before t:side="recto">
-  </t:titlepage-before>
-
-  <t:titlepage-before t:side="verso">
-  </t:titlepage-before>
-</t:titlepage>
-
-<t:titlepage t:element="sect3" t:wrapper="div" class="titlepage">
-  <t:titlepage-content t:side="recto">
-    <title/>
-    <subtitle/>
-    <corpauthor/>
-    <authorgroup/>
-    <author/>
-    <othercredit/>
-    <releaseinfo/>
-    <copyright/>
-    <legalnotice/>
-    <pubdate/>
-    <revision/>
-    <revhistory/>
-    <abstract/>
-  </t:titlepage-content>
-
-  <t:titlepage-content t:side="verso">
-  </t:titlepage-content>
-
-  <t:titlepage-separator>
-    <xsl:if test="count(parent::*)='0'"><hr/></xsl:if>
-  </t:titlepage-separator>
-
-  <t:titlepage-before t:side="recto">
-  </t:titlepage-before>
-
-  <t:titlepage-before t:side="verso">
-  </t:titlepage-before>
-</t:titlepage>
-
-<t:titlepage t:element="sect4" t:wrapper="div" class="titlepage">
-  <t:titlepage-content t:side="recto">
-    <title/>
-    <subtitle/>
-    <corpauthor/>
-    <authorgroup/>
-    <author/>
-    <othercredit/>
-    <releaseinfo/>
-    <copyright/>
-    <legalnotice/>
-    <pubdate/>
-    <revision/>
-    <revhistory/>
-    <abstract/>
-  </t:titlepage-content>
-
-  <t:titlepage-content t:side="verso">
-  </t:titlepage-content>
-
-  <t:titlepage-separator>
-    <xsl:if test="count(parent::*)='0'"><hr/></xsl:if>
-  </t:titlepage-separator>
-
-  <t:titlepage-before t:side="recto">
-  </t:titlepage-before>
-
-  <t:titlepage-before t:side="verso">
-  </t:titlepage-before>
-</t:titlepage>
-
-<t:titlepage t:element="sect5" t:wrapper="div" class="titlepage">
-  <t:titlepage-content t:side="recto">
-    <title/>
-    <subtitle/>
-    <corpauthor/>
-    <authorgroup/>
-    <author/>
-    <othercredit/>
-    <releaseinfo/>
-    <copyright/>
-    <legalnotice/>
-    <pubdate/>
-    <revision/>
-    <revhistory/>
-    <abstract/>
-  </t:titlepage-content>
-
-  <t:titlepage-content t:side="verso">
-  </t:titlepage-content>
-
-  <t:titlepage-separator>
-    <xsl:if test="count(parent::*)='0'"><hr/></xsl:if>
-  </t:titlepage-separator>
-
-  <t:titlepage-before t:side="recto">
-  </t:titlepage-before>
-
-  <t:titlepage-before t:side="verso">
-  </t:titlepage-before>
-</t:titlepage>
-
-<t:titlepage t:element="simplesect" t:wrapper="div" class="titlepage">
-  <t:titlepage-content t:side="recto">
-    <title/>
-    <subtitle/>
-    <corpauthor/>
-    <authorgroup/>
-    <author/>
-    <othercredit/>
-    <releaseinfo/>
-    <copyright/>
-    <legalnotice/>
-    <pubdate/>
-    <revision/>
-    <revhistory/>
-    <abstract/>
-  </t:titlepage-content>
-
-  <t:titlepage-content t:side="verso">
-  </t:titlepage-content>
-
-  <t:titlepage-separator>
-    <xsl:if test="count(parent::*)='0'"><hr/></xsl:if>
-  </t:titlepage-separator>
-
-  <t:titlepage-before t:side="recto">
-  </t:titlepage-before>
-
-  <t:titlepage-before t:side="verso">
-  </t:titlepage-before>
-</t:titlepage>
-
-<!-- ==================================================================== -->
-
-<t:titlepage t:element="bibliography" t:wrapper="div" class="titlepage">
-  <t:titlepage-content t:side="recto">
-    <title
-           t:force="1"
-           t:named-template="component.title"
-           param:node="ancestor-or-self::bibliography[1]"/>
-    <subtitle/>
-  </t:titlepage-content>
-
-  <t:titlepage-content t:side="verso">
-  </t:titlepage-content>
-
-  <t:titlepage-separator>
-  </t:titlepage-separator>
-
-  <t:titlepage-before t:side="recto">
-  </t:titlepage-before>
-
-  <t:titlepage-before t:side="verso">
-  </t:titlepage-before>
-</t:titlepage>
-
-<!-- ==================================================================== -->
-
-<t:titlepage t:element="glossary" t:wrapper="div" class="titlepage">
-  <t:titlepage-content t:side="recto">
-    <title
-           t:force="1"
-           t:named-template="component.title"
-           param:node="ancestor-or-self::glossary[1]"/>
-    <subtitle/>
-  </t:titlepage-content>
-
-  <t:titlepage-content t:side="verso">
-  </t:titlepage-content>
-
-  <t:titlepage-separator>
-  </t:titlepage-separator>
-
-  <t:titlepage-before t:side="recto">
-  </t:titlepage-before>
-
-  <t:titlepage-before t:side="verso">
-  </t:titlepage-before>
-</t:titlepage>
-
-<!-- ==================================================================== -->
-
-<t:titlepage t:element="index" t:wrapper="div" class="titlepage">
-  <t:titlepage-content t:side="recto">
-    <title
-           t:force="1"
-           t:named-template="component.title"
-           param:node="ancestor-or-self::index[1]"/>
-    <subtitle/>
-  </t:titlepage-content>
-
-  <t:titlepage-content t:side="verso">
-  </t:titlepage-content>
-
-  <t:titlepage-separator>
-  </t:titlepage-separator>
-
-  <t:titlepage-before t:side="recto">
-  </t:titlepage-before>
-
-  <t:titlepage-before t:side="verso">
-  </t:titlepage-before>
-</t:titlepage>
-
-<!-- ==================================================================== -->
-
-<t:titlepage t:element="setindex" t:wrapper="div" class="titlepage">
-  <t:titlepage-content t:side="recto">
-    <title
-           t:force="1"
-           t:named-template="component.title"
-           param:node="ancestor-or-self::setindex[1]"/>
-    <subtitle/>
-  </t:titlepage-content>
-
-  <t:titlepage-content t:side="verso">
-  </t:titlepage-content>
-
-  <t:titlepage-separator>
-  </t:titlepage-separator>
-
-  <t:titlepage-before t:side="recto">
-  </t:titlepage-before>
-
-  <t:titlepage-before t:side="verso">
-  </t:titlepage-before>
-</t:titlepage>
-
-<!-- ==================================================================== -->
-<t:titlepage t:element="sidebar" t:wrapper="div" class="titlepage">
-  <t:titlepage-content t:side="recto">
-    <title
-           t:named-template="formal.object.heading"
-           param:object="ancestor-or-self::sidebar[1]"/>
-    <subtitle/>
-  </t:titlepage-content>
-
-  <t:titlepage-content t:side="verso">
-  </t:titlepage-content>
-
-  <t:titlepage-separator>
-  </t:titlepage-separator>
-
-  <t:titlepage-before t:side="recto">
-  </t:titlepage-before>
-
-  <t:titlepage-before t:side="verso">
-  </t:titlepage-before>
-</t:titlepage>
-
-<!-- ==================================================================== -->
-
-</t:templates>

+ 0 - 3841
stylesheets/lfs-xsl/docbook-xsl-1.78.1/epub3/titlepage.templates.xsl

@@ -1,3841 +0,0 @@
-<?xml version="1.0"?>
-
-<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" xmlns:exsl="http://exslt.org/common" version="1.0" exclude-result-prefixes="exsl">
-
-<!-- This stylesheet was created by template/titlepage.xsl-->
-
-<xsl:template name="article.titlepage.recto">
-  <xsl:choose>
-    <xsl:when test="articleinfo/title">
-      <xsl:apply-templates mode="article.titlepage.recto.auto.mode" select="articleinfo/title"/>
-    </xsl:when>
-    <xsl:when test="artheader/title">
-      <xsl:apply-templates mode="article.titlepage.recto.auto.mode" select="artheader/title"/>
-    </xsl:when>
-    <xsl:when test="info/title">
-      <xsl:apply-templates mode="article.titlepage.recto.auto.mode" select="info/title"/>
-    </xsl:when>
-    <xsl:when test="title">
-      <xsl:apply-templates mode="article.titlepage.recto.auto.mode" select="title"/>
-    </xsl:when>
-  </xsl:choose>
-
-  <xsl:choose>
-    <xsl:when test="articleinfo/subtitle">
-      <xsl:apply-templates mode="article.titlepage.recto.auto.mode" select="articleinfo/subtitle"/>
-    </xsl:when>
-    <xsl:when test="artheader/subtitle">
-      <xsl:apply-templates mode="article.titlepage.recto.auto.mode" select="artheader/subtitle"/>
-    </xsl:when>
-    <xsl:when test="info/subtitle">
-      <xsl:apply-templates mode="article.titlepage.recto.auto.mode" select="info/subtitle"/>
-    </xsl:when>
-    <xsl:when test="subtitle">
-      <xsl:apply-templates mode="article.titlepage.recto.auto.mode" select="subtitle"/>
-    </xsl:when>
-  </xsl:choose>
-
-  <xsl:apply-templates mode="article.titlepage.recto.auto.mode" select="articleinfo/corpauthor"/>
-  <xsl:apply-templates mode="article.titlepage.recto.auto.mode" select="artheader/corpauthor"/>
-  <xsl:apply-templates mode="article.titlepage.recto.auto.mode" select="info/corpauthor"/>
-  <xsl:apply-templates mode="article.titlepage.recto.auto.mode" select="articleinfo/authorgroup"/>
-  <xsl:apply-templates mode="article.titlepage.recto.auto.mode" select="artheader/authorgroup"/>
-  <xsl:apply-templates mode="article.titlepage.recto.auto.mode" select="info/authorgroup"/>
-  <xsl:apply-templates mode="article.titlepage.recto.auto.mode" select="articleinfo/author"/>
-  <xsl:apply-templates mode="article.titlepage.recto.auto.mode" select="artheader/author"/>
-  <xsl:apply-templates mode="article.titlepage.recto.auto.mode" select="info/author"/>
-  <xsl:apply-templates mode="article.titlepage.recto.auto.mode" select="articleinfo/othercredit"/>
-  <xsl:apply-templates mode="article.titlepage.recto.auto.mode" select="artheader/othercredit"/>
-  <xsl:apply-templates mode="article.titlepage.recto.auto.mode" select="info/othercredit"/>
-  <xsl:apply-templates mode="article.titlepage.recto.auto.mode" select="articleinfo/releaseinfo"/>
-  <xsl:apply-templates mode="article.titlepage.recto.auto.mode" select="artheader/releaseinfo"/>
-  <xsl:apply-templates mode="article.titlepage.recto.auto.mode" select="info/releaseinfo"/>
-  <xsl:apply-templates mode="article.titlepage.recto.auto.mode" select="articleinfo/copyright"/>
-  <xsl:apply-templates mode="article.titlepage.recto.auto.mode" select="artheader/copyright"/>
-  <xsl:apply-templates mode="article.titlepage.recto.auto.mode" select="info/copyright"/>
-  <xsl:apply-templates mode="article.titlepage.recto.auto.mode" select="articleinfo/legalnotice"/>
-  <xsl:apply-templates mode="article.titlepage.recto.auto.mode" select="artheader/legalnotice"/>
-  <xsl:apply-templates mode="article.titlepage.recto.auto.mode" select="info/legalnotice"/>
-  <xsl:apply-templates mode="article.titlepage.recto.auto.mode" select="articleinfo/pubdate"/>
-  <xsl:apply-templates mode="article.titlepage.recto.auto.mode" select="artheader/pubdate"/>
-  <xsl:apply-templates mode="article.titlepage.recto.auto.mode" select="info/pubdate"/>
-  <xsl:apply-templates mode="article.titlepage.recto.auto.mode" select="articleinfo/revision"/>
-  <xsl:apply-templates mode="article.titlepage.recto.auto.mode" select="artheader/revision"/>
-  <xsl:apply-templates mode="article.titlepage.recto.auto.mode" select="info/revision"/>
-  <xsl:apply-templates mode="article.titlepage.recto.auto.mode" select="articleinfo/revhistory"/>
-  <xsl:apply-templates mode="article.titlepage.recto.auto.mode" select="artheader/revhistory"/>
-  <xsl:apply-templates mode="article.titlepage.recto.auto.mode" select="info/revhistory"/>
-  <xsl:apply-templates mode="article.titlepage.recto.auto.mode" select="articleinfo/abstract"/>
-  <xsl:apply-templates mode="article.titlepage.recto.auto.mode" select="artheader/abstract"/>
-  <xsl:apply-templates mode="article.titlepage.recto.auto.mode" select="info/abstract"/>
-</xsl:template>
-
-<xsl:template name="article.titlepage.verso">
-</xsl:template>
-
-<xsl:template name="article.titlepage.separator"><hr xmlns="http://www.w3.org/1999/xhtml"/>
-</xsl:template>
-
-<xsl:template name="article.titlepage.before.recto">
-</xsl:template>
-
-<xsl:template name="article.titlepage.before.verso">
-</xsl:template>
-
-<xsl:template name="article.titlepage">
-  <div xmlns="http://www.w3.org/1999/xhtml" class="titlepage">
-    <xsl:variable name="recto.content">
-      <xsl:call-template name="article.titlepage.before.recto"/>
-      <xsl:call-template name="article.titlepage.recto"/>
-    </xsl:variable>
-    <xsl:variable name="recto.elements.count">
-      <xsl:choose>
-        <xsl:when test="function-available('exsl:node-set')"><xsl:value-of select="count(exsl:node-set($recto.content)/*)"/></xsl:when>
-        <xsl:when test="contains(system-property('xsl:vendor'), 'Apache Software Foundation')">
-          <!--Xalan quirk--><xsl:value-of select="count(exsl:node-set($recto.content)/*)"/></xsl:when>
-        <xsl:otherwise>1</xsl:otherwise>
-      </xsl:choose>
-    </xsl:variable>
-    <xsl:if test="(normalize-space($recto.content) != '') or ($recto.elements.count &gt; 0)">
-      <div><xsl:copy-of select="$recto.content"/></div>
-    </xsl:if>
-    <xsl:variable name="verso.content">
-      <xsl:call-template name="article.titlepage.before.verso"/>
-      <xsl:call-template name="article.titlepage.verso"/>
-    </xsl:variable>
-    <xsl:variable name="verso.elements.count">
-      <xsl:choose>
-        <xsl:when test="function-available('exsl:node-set')"><xsl:value-of select="count(exsl:node-set($verso.content)/*)"/></xsl:when>
-        <xsl:when test="contains(system-property('xsl:vendor'), 'Apache Software Foundation')">
-          <!--Xalan quirk--><xsl:value-of select="count(exsl:node-set($verso.content)/*)"/></xsl:when>
-        <xsl:otherwise>1</xsl:otherwise>
-      </xsl:choose>
-    </xsl:variable>
-    <xsl:if test="(normalize-space($verso.content) != '') or ($verso.elements.count &gt; 0)">
-      <div><xsl:copy-of select="$verso.content"/></div>
-    </xsl:if>
-    <xsl:call-template name="article.titlepage.separator"/>
-  </div>
-</xsl:template>
-
-<xsl:template match="*" mode="article.titlepage.recto.mode">
-  <!-- if an element isn't found in this mode, -->
-  <!-- try the generic titlepage.mode -->
-  <xsl:apply-templates select="." mode="titlepage.mode"/>
-</xsl:template>
-
-<xsl:template match="*" mode="article.titlepage.verso.mode">
-  <!-- if an element isn't found in this mode, -->
-  <!-- try the generic titlepage.mode -->
-  <xsl:apply-templates select="." mode="titlepage.mode"/>
-</xsl:template>
-
-<xsl:template match="title" mode="article.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="article.titlepage.recto.style">
-<xsl:apply-templates select="." mode="article.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="subtitle" mode="article.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="article.titlepage.recto.style">
-<xsl:apply-templates select="." mode="article.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="corpauthor" mode="article.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="article.titlepage.recto.style">
-<xsl:apply-templates select="." mode="article.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="authorgroup" mode="article.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="article.titlepage.recto.style">
-<xsl:apply-templates select="." mode="article.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="author" mode="article.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="article.titlepage.recto.style">
-<xsl:apply-templates select="." mode="article.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="othercredit" mode="article.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="article.titlepage.recto.style">
-<xsl:apply-templates select="." mode="article.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="releaseinfo" mode="article.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="article.titlepage.recto.style">
-<xsl:apply-templates select="." mode="article.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="copyright" mode="article.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="article.titlepage.recto.style">
-<xsl:apply-templates select="." mode="article.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="legalnotice" mode="article.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="article.titlepage.recto.style">
-<xsl:apply-templates select="." mode="article.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="pubdate" mode="article.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="article.titlepage.recto.style">
-<xsl:apply-templates select="." mode="article.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="revision" mode="article.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="article.titlepage.recto.style">
-<xsl:apply-templates select="." mode="article.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="revhistory" mode="article.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="article.titlepage.recto.style">
-<xsl:apply-templates select="." mode="article.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="abstract" mode="article.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="article.titlepage.recto.style">
-<xsl:apply-templates select="." mode="article.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template name="set.titlepage.recto">
-  <xsl:choose>
-    <xsl:when test="setinfo/title">
-      <xsl:apply-templates mode="set.titlepage.recto.auto.mode" select="setinfo/title"/>
-    </xsl:when>
-    <xsl:when test="info/title">
-      <xsl:apply-templates mode="set.titlepage.recto.auto.mode" select="info/title"/>
-    </xsl:when>
-    <xsl:when test="title">
-      <xsl:apply-templates mode="set.titlepage.recto.auto.mode" select="title"/>
-    </xsl:when>
-  </xsl:choose>
-
-  <xsl:choose>
-    <xsl:when test="setinfo/subtitle">
-      <xsl:apply-templates mode="set.titlepage.recto.auto.mode" select="setinfo/subtitle"/>
-    </xsl:when>
-    <xsl:when test="info/subtitle">
-      <xsl:apply-templates mode="set.titlepage.recto.auto.mode" select="info/subtitle"/>
-    </xsl:when>
-    <xsl:when test="subtitle">
-      <xsl:apply-templates mode="set.titlepage.recto.auto.mode" select="subtitle"/>
-    </xsl:when>
-  </xsl:choose>
-
-  <xsl:apply-templates mode="set.titlepage.recto.auto.mode" select="setinfo/corpauthor"/>
-  <xsl:apply-templates mode="set.titlepage.recto.auto.mode" select="info/corpauthor"/>
-  <xsl:apply-templates mode="set.titlepage.recto.auto.mode" select="setinfo/authorgroup"/>
-  <xsl:apply-templates mode="set.titlepage.recto.auto.mode" select="info/authorgroup"/>
-  <xsl:apply-templates mode="set.titlepage.recto.auto.mode" select="setinfo/author"/>
-  <xsl:apply-templates mode="set.titlepage.recto.auto.mode" select="info/author"/>
-  <xsl:apply-templates mode="set.titlepage.recto.auto.mode" select="setinfo/othercredit"/>
-  <xsl:apply-templates mode="set.titlepage.recto.auto.mode" select="info/othercredit"/>
-  <xsl:apply-templates mode="set.titlepage.recto.auto.mode" select="setinfo/releaseinfo"/>
-  <xsl:apply-templates mode="set.titlepage.recto.auto.mode" select="info/releaseinfo"/>
-  <xsl:apply-templates mode="set.titlepage.recto.auto.mode" select="setinfo/copyright"/>
-  <xsl:apply-templates mode="set.titlepage.recto.auto.mode" select="info/copyright"/>
-  <xsl:apply-templates mode="set.titlepage.recto.auto.mode" select="setinfo/legalnotice"/>
-  <xsl:apply-templates mode="set.titlepage.recto.auto.mode" select="info/legalnotice"/>
-  <xsl:apply-templates mode="set.titlepage.recto.auto.mode" select="setinfo/pubdate"/>
-  <xsl:apply-templates mode="set.titlepage.recto.auto.mode" select="info/pubdate"/>
-  <xsl:apply-templates mode="set.titlepage.recto.auto.mode" select="setinfo/revision"/>
-  <xsl:apply-templates mode="set.titlepage.recto.auto.mode" select="info/revision"/>
-  <xsl:apply-templates mode="set.titlepage.recto.auto.mode" select="setinfo/revhistory"/>
-  <xsl:apply-templates mode="set.titlepage.recto.auto.mode" select="info/revhistory"/>
-  <xsl:apply-templates mode="set.titlepage.recto.auto.mode" select="setinfo/abstract"/>
-  <xsl:apply-templates mode="set.titlepage.recto.auto.mode" select="info/abstract"/>
-</xsl:template>
-
-<xsl:template name="set.titlepage.verso">
-</xsl:template>
-
-<xsl:template name="set.titlepage.separator"><hr xmlns="http://www.w3.org/1999/xhtml"/>
-</xsl:template>
-
-<xsl:template name="set.titlepage.before.recto">
-</xsl:template>
-
-<xsl:template name="set.titlepage.before.verso">
-</xsl:template>
-
-<xsl:template name="set.titlepage">
-  <div xmlns="http://www.w3.org/1999/xhtml" class="titlepage">
-    <xsl:variable name="recto.content">
-      <xsl:call-template name="set.titlepage.before.recto"/>
-      <xsl:call-template name="set.titlepage.recto"/>
-    </xsl:variable>
-    <xsl:variable name="recto.elements.count">
-      <xsl:choose>
-        <xsl:when test="function-available('exsl:node-set')"><xsl:value-of select="count(exsl:node-set($recto.content)/*)"/></xsl:when>
-        <xsl:when test="contains(system-property('xsl:vendor'), 'Apache Software Foundation')">
-          <!--Xalan quirk--><xsl:value-of select="count(exsl:node-set($recto.content)/*)"/></xsl:when>
-        <xsl:otherwise>1</xsl:otherwise>
-      </xsl:choose>
-    </xsl:variable>
-    <xsl:if test="(normalize-space($recto.content) != '') or ($recto.elements.count &gt; 0)">
-      <div><xsl:copy-of select="$recto.content"/></div>
-    </xsl:if>
-    <xsl:variable name="verso.content">
-      <xsl:call-template name="set.titlepage.before.verso"/>
-      <xsl:call-template name="set.titlepage.verso"/>
-    </xsl:variable>
-    <xsl:variable name="verso.elements.count">
-      <xsl:choose>
-        <xsl:when test="function-available('exsl:node-set')"><xsl:value-of select="count(exsl:node-set($verso.content)/*)"/></xsl:when>
-        <xsl:when test="contains(system-property('xsl:vendor'), 'Apache Software Foundation')">
-          <!--Xalan quirk--><xsl:value-of select="count(exsl:node-set($verso.content)/*)"/></xsl:when>
-        <xsl:otherwise>1</xsl:otherwise>
-      </xsl:choose>
-    </xsl:variable>
-    <xsl:if test="(normalize-space($verso.content) != '') or ($verso.elements.count &gt; 0)">
-      <div><xsl:copy-of select="$verso.content"/></div>
-    </xsl:if>
-    <xsl:call-template name="set.titlepage.separator"/>
-  </div>
-</xsl:template>
-
-<xsl:template match="*" mode="set.titlepage.recto.mode">
-  <!-- if an element isn't found in this mode, -->
-  <!-- try the generic titlepage.mode -->
-  <xsl:apply-templates select="." mode="titlepage.mode"/>
-</xsl:template>
-
-<xsl:template match="*" mode="set.titlepage.verso.mode">
-  <!-- if an element isn't found in this mode, -->
-  <!-- try the generic titlepage.mode -->
-  <xsl:apply-templates select="." mode="titlepage.mode"/>
-</xsl:template>
-
-<xsl:template match="title" mode="set.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="set.titlepage.recto.style">
-<xsl:apply-templates select="." mode="set.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="subtitle" mode="set.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="set.titlepage.recto.style">
-<xsl:apply-templates select="." mode="set.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="corpauthor" mode="set.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="set.titlepage.recto.style">
-<xsl:apply-templates select="." mode="set.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="authorgroup" mode="set.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="set.titlepage.recto.style">
-<xsl:apply-templates select="." mode="set.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="author" mode="set.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="set.titlepage.recto.style">
-<xsl:apply-templates select="." mode="set.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="othercredit" mode="set.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="set.titlepage.recto.style">
-<xsl:apply-templates select="." mode="set.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="releaseinfo" mode="set.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="set.titlepage.recto.style">
-<xsl:apply-templates select="." mode="set.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="copyright" mode="set.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="set.titlepage.recto.style">
-<xsl:apply-templates select="." mode="set.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="legalnotice" mode="set.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="set.titlepage.recto.style">
-<xsl:apply-templates select="." mode="set.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="pubdate" mode="set.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="set.titlepage.recto.style">
-<xsl:apply-templates select="." mode="set.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="revision" mode="set.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="set.titlepage.recto.style">
-<xsl:apply-templates select="." mode="set.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="revhistory" mode="set.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="set.titlepage.recto.style">
-<xsl:apply-templates select="." mode="set.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="abstract" mode="set.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="set.titlepage.recto.style">
-<xsl:apply-templates select="." mode="set.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template name="book.titlepage.recto">
-  <xsl:choose>
-    <xsl:when test="bookinfo/title">
-      <xsl:apply-templates mode="book.titlepage.recto.auto.mode" select="bookinfo/title"/>
-    </xsl:when>
-    <xsl:when test="info/title">
-      <xsl:apply-templates mode="book.titlepage.recto.auto.mode" select="info/title"/>
-    </xsl:when>
-    <xsl:when test="title">
-      <xsl:apply-templates mode="book.titlepage.recto.auto.mode" select="title"/>
-    </xsl:when>
-  </xsl:choose>
-
-  <xsl:choose>
-    <xsl:when test="bookinfo/subtitle">
-      <xsl:apply-templates mode="book.titlepage.recto.auto.mode" select="bookinfo/subtitle"/>
-    </xsl:when>
-    <xsl:when test="info/subtitle">
-      <xsl:apply-templates mode="book.titlepage.recto.auto.mode" select="info/subtitle"/>
-    </xsl:when>
-    <xsl:when test="subtitle">
-      <xsl:apply-templates mode="book.titlepage.recto.auto.mode" select="subtitle"/>
-    </xsl:when>
-  </xsl:choose>
-
-  <xsl:apply-templates mode="book.titlepage.recto.auto.mode" select="bookinfo/isbn"/>
-  <xsl:apply-templates mode="book.titlepage.recto.auto.mode" select="info/isbn"/>
-  <xsl:apply-templates mode="book.titlepage.recto.auto.mode" select="bookinfo/issn"/>
-  <xsl:apply-templates mode="book.titlepage.recto.auto.mode" select="info/issn"/>
-  <xsl:apply-templates mode="book.titlepage.recto.auto.mode" select="bookinfo/biblioid"/>
-  <xsl:apply-templates mode="book.titlepage.recto.auto.mode" select="info/biblioid"/>
-  <xsl:apply-templates mode="book.titlepage.recto.auto.mode" select="bookinfo/corpauthor"/>
-  <xsl:apply-templates mode="book.titlepage.recto.auto.mode" select="info/corpauthor"/>
-  <xsl:apply-templates mode="book.titlepage.recto.auto.mode" select="bookinfo/authorgroup"/>
-  <xsl:apply-templates mode="book.titlepage.recto.auto.mode" select="info/authorgroup"/>
-  <xsl:apply-templates mode="book.titlepage.recto.auto.mode" select="bookinfo/author"/>
-  <xsl:apply-templates mode="book.titlepage.recto.auto.mode" select="info/author"/>
-  <xsl:apply-templates mode="book.titlepage.recto.auto.mode" select="bookinfo/othercredit"/>
-  <xsl:apply-templates mode="book.titlepage.recto.auto.mode" select="info/othercredit"/>
-  <xsl:apply-templates mode="book.titlepage.recto.auto.mode" select="bookinfo/releaseinfo"/>
-  <xsl:apply-templates mode="book.titlepage.recto.auto.mode" select="info/releaseinfo"/>
-  <xsl:apply-templates mode="book.titlepage.recto.auto.mode" select="bookinfo/copyright"/>
-  <xsl:apply-templates mode="book.titlepage.recto.auto.mode" select="info/copyright"/>
-  <xsl:apply-templates mode="book.titlepage.recto.auto.mode" select="bookinfo/legalnotice"/>
-  <xsl:apply-templates mode="book.titlepage.recto.auto.mode" select="info/legalnotice"/>
-  <xsl:apply-templates mode="book.titlepage.recto.auto.mode" select="bookinfo/pubdate"/>
-  <xsl:apply-templates mode="book.titlepage.recto.auto.mode" select="info/pubdate"/>
-  <xsl:apply-templates mode="book.titlepage.recto.auto.mode" select="bookinfo/revision"/>
-  <xsl:apply-templates mode="book.titlepage.recto.auto.mode" select="info/revision"/>
-  <xsl:apply-templates mode="book.titlepage.recto.auto.mode" select="bookinfo/revhistory"/>
-  <xsl:apply-templates mode="book.titlepage.recto.auto.mode" select="info/revhistory"/>
-  <xsl:apply-templates mode="book.titlepage.recto.auto.mode" select="bookinfo/abstract"/>
-  <xsl:apply-templates mode="book.titlepage.recto.auto.mode" select="info/abstract"/>
-</xsl:template>
-
-<xsl:template name="book.titlepage.verso">
-</xsl:template>
-
-<xsl:template name="book.titlepage.separator"><hr xmlns="http://www.w3.org/1999/xhtml"/>
-</xsl:template>
-
-<xsl:template name="book.titlepage.before.recto">
-</xsl:template>
-
-<xsl:template name="book.titlepage.before.verso">
-</xsl:template>
-
-<xsl:template name="book.titlepage">
-  <div xmlns="http://www.w3.org/1999/xhtml" class="titlepage">
-    <xsl:variable name="recto.content">
-      <xsl:call-template name="book.titlepage.before.recto"/>
-      <xsl:call-template name="book.titlepage.recto"/>
-    </xsl:variable>
-    <xsl:variable name="recto.elements.count">
-      <xsl:choose>
-        <xsl:when test="function-available('exsl:node-set')"><xsl:value-of select="count(exsl:node-set($recto.content)/*)"/></xsl:when>
-        <xsl:when test="contains(system-property('xsl:vendor'), 'Apache Software Foundation')">
-          <!--Xalan quirk--><xsl:value-of select="count(exsl:node-set($recto.content)/*)"/></xsl:when>
-        <xsl:otherwise>1</xsl:otherwise>
-      </xsl:choose>
-    </xsl:variable>
-    <xsl:if test="(normalize-space($recto.content) != '') or ($recto.elements.count &gt; 0)">
-      <div><xsl:copy-of select="$recto.content"/></div>
-    </xsl:if>
-    <xsl:variable name="verso.content">
-      <xsl:call-template name="book.titlepage.before.verso"/>
-      <xsl:call-template name="book.titlepage.verso"/>
-    </xsl:variable>
-    <xsl:variable name="verso.elements.count">
-      <xsl:choose>
-        <xsl:when test="function-available('exsl:node-set')"><xsl:value-of select="count(exsl:node-set($verso.content)/*)"/></xsl:when>
-        <xsl:when test="contains(system-property('xsl:vendor'), 'Apache Software Foundation')">
-          <!--Xalan quirk--><xsl:value-of select="count(exsl:node-set($verso.content)/*)"/></xsl:when>
-        <xsl:otherwise>1</xsl:otherwise>
-      </xsl:choose>
-    </xsl:variable>
-    <xsl:if test="(normalize-space($verso.content) != '') or ($verso.elements.count &gt; 0)">
-      <div><xsl:copy-of select="$verso.content"/></div>
-    </xsl:if>
-    <xsl:call-template name="book.titlepage.separator"/>
-  </div>
-</xsl:template>
-
-<xsl:template match="*" mode="book.titlepage.recto.mode">
-  <!-- if an element isn't found in this mode, -->
-  <!-- try the generic titlepage.mode -->
-  <xsl:apply-templates select="." mode="titlepage.mode"/>
-</xsl:template>
-
-<xsl:template match="*" mode="book.titlepage.verso.mode">
-  <!-- if an element isn't found in this mode, -->
-  <!-- try the generic titlepage.mode -->
-  <xsl:apply-templates select="." mode="titlepage.mode"/>
-</xsl:template>
-
-<xsl:template match="title" mode="book.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="book.titlepage.recto.style">
-<xsl:apply-templates select="." mode="book.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="subtitle" mode="book.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="book.titlepage.recto.style">
-<xsl:apply-templates select="." mode="book.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="isbn" mode="book.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="book.titlepage.recto.style">
-<xsl:apply-templates select="." mode="book.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="issn" mode="book.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="book.titlepage.recto.style">
-<xsl:apply-templates select="." mode="book.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="biblioid" mode="book.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="book.titlepage.recto.style">
-<xsl:apply-templates select="." mode="book.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="corpauthor" mode="book.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="book.titlepage.recto.style">
-<xsl:apply-templates select="." mode="book.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="authorgroup" mode="book.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="book.titlepage.recto.style">
-<xsl:apply-templates select="." mode="book.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="author" mode="book.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="book.titlepage.recto.style">
-<xsl:apply-templates select="." mode="book.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="othercredit" mode="book.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="book.titlepage.recto.style">
-<xsl:apply-templates select="." mode="book.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="releaseinfo" mode="book.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="book.titlepage.recto.style">
-<xsl:apply-templates select="." mode="book.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="copyright" mode="book.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="book.titlepage.recto.style">
-<xsl:apply-templates select="." mode="book.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="legalnotice" mode="book.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="book.titlepage.recto.style">
-<xsl:apply-templates select="." mode="book.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="pubdate" mode="book.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="book.titlepage.recto.style">
-<xsl:apply-templates select="." mode="book.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="revision" mode="book.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="book.titlepage.recto.style">
-<xsl:apply-templates select="." mode="book.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="revhistory" mode="book.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="book.titlepage.recto.style">
-<xsl:apply-templates select="." mode="book.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="abstract" mode="book.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="book.titlepage.recto.style">
-<xsl:apply-templates select="." mode="book.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template name="part.titlepage.recto">
-  <div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="part.titlepage.recto.style">
-<xsl:call-template name="division.title">
-<xsl:with-param name="node" select="ancestor-or-self::part[1]"/>
-</xsl:call-template></div>
-  <xsl:choose>
-    <xsl:when test="partinfo/subtitle">
-      <xsl:apply-templates mode="part.titlepage.recto.auto.mode" select="partinfo/subtitle"/>
-    </xsl:when>
-    <xsl:when test="docinfo/subtitle">
-      <xsl:apply-templates mode="part.titlepage.recto.auto.mode" select="docinfo/subtitle"/>
-    </xsl:when>
-    <xsl:when test="info/subtitle">
-      <xsl:apply-templates mode="part.titlepage.recto.auto.mode" select="info/subtitle"/>
-    </xsl:when>
-    <xsl:when test="subtitle">
-      <xsl:apply-templates mode="part.titlepage.recto.auto.mode" select="subtitle"/>
-    </xsl:when>
-  </xsl:choose>
-
-  <xsl:apply-templates mode="part.titlepage.recto.auto.mode" select="partinfo/corpauthor"/>
-  <xsl:apply-templates mode="part.titlepage.recto.auto.mode" select="docinfo/corpauthor"/>
-  <xsl:apply-templates mode="part.titlepage.recto.auto.mode" select="info/corpauthor"/>
-  <xsl:apply-templates mode="part.titlepage.recto.auto.mode" select="partinfo/authorgroup"/>
-  <xsl:apply-templates mode="part.titlepage.recto.auto.mode" select="docinfo/authorgroup"/>
-  <xsl:apply-templates mode="part.titlepage.recto.auto.mode" select="info/authorgroup"/>
-  <xsl:apply-templates mode="part.titlepage.recto.auto.mode" select="partinfo/author"/>
-  <xsl:apply-templates mode="part.titlepage.recto.auto.mode" select="docinfo/author"/>
-  <xsl:apply-templates mode="part.titlepage.recto.auto.mode" select="info/author"/>
-  <xsl:apply-templates mode="part.titlepage.recto.auto.mode" select="partinfo/othercredit"/>
-  <xsl:apply-templates mode="part.titlepage.recto.auto.mode" select="docinfo/othercredit"/>
-  <xsl:apply-templates mode="part.titlepage.recto.auto.mode" select="info/othercredit"/>
-  <xsl:apply-templates mode="part.titlepage.recto.auto.mode" select="partinfo/releaseinfo"/>
-  <xsl:apply-templates mode="part.titlepage.recto.auto.mode" select="docinfo/releaseinfo"/>
-  <xsl:apply-templates mode="part.titlepage.recto.auto.mode" select="info/releaseinfo"/>
-  <xsl:apply-templates mode="part.titlepage.recto.auto.mode" select="partinfo/copyright"/>
-  <xsl:apply-templates mode="part.titlepage.recto.auto.mode" select="docinfo/copyright"/>
-  <xsl:apply-templates mode="part.titlepage.recto.auto.mode" select="info/copyright"/>
-  <xsl:apply-templates mode="part.titlepage.recto.auto.mode" select="partinfo/legalnotice"/>
-  <xsl:apply-templates mode="part.titlepage.recto.auto.mode" select="docinfo/legalnotice"/>
-  <xsl:apply-templates mode="part.titlepage.recto.auto.mode" select="info/legalnotice"/>
-  <xsl:apply-templates mode="part.titlepage.recto.auto.mode" select="partinfo/pubdate"/>
-  <xsl:apply-templates mode="part.titlepage.recto.auto.mode" select="docinfo/pubdate"/>
-  <xsl:apply-templates mode="part.titlepage.recto.auto.mode" select="info/pubdate"/>
-  <xsl:apply-templates mode="part.titlepage.recto.auto.mode" select="partinfo/revision"/>
-  <xsl:apply-templates mode="part.titlepage.recto.auto.mode" select="docinfo/revision"/>
-  <xsl:apply-templates mode="part.titlepage.recto.auto.mode" select="info/revision"/>
-  <xsl:apply-templates mode="part.titlepage.recto.auto.mode" select="partinfo/revhistory"/>
-  <xsl:apply-templates mode="part.titlepage.recto.auto.mode" select="docinfo/revhistory"/>
-  <xsl:apply-templates mode="part.titlepage.recto.auto.mode" select="info/revhistory"/>
-  <xsl:apply-templates mode="part.titlepage.recto.auto.mode" select="partinfo/abstract"/>
-  <xsl:apply-templates mode="part.titlepage.recto.auto.mode" select="docinfo/abstract"/>
-  <xsl:apply-templates mode="part.titlepage.recto.auto.mode" select="info/abstract"/>
-</xsl:template>
-
-<xsl:template name="part.titlepage.verso">
-</xsl:template>
-
-<xsl:template name="part.titlepage.separator">
-</xsl:template>
-
-<xsl:template name="part.titlepage.before.recto">
-</xsl:template>
-
-<xsl:template name="part.titlepage.before.verso">
-</xsl:template>
-
-<xsl:template name="part.titlepage">
-  <div xmlns="http://www.w3.org/1999/xhtml" class="titlepage">
-    <xsl:variable name="recto.content">
-      <xsl:call-template name="part.titlepage.before.recto"/>
-      <xsl:call-template name="part.titlepage.recto"/>
-    </xsl:variable>
-    <xsl:variable name="recto.elements.count">
-      <xsl:choose>
-        <xsl:when test="function-available('exsl:node-set')"><xsl:value-of select="count(exsl:node-set($recto.content)/*)"/></xsl:when>
-        <xsl:when test="contains(system-property('xsl:vendor'), 'Apache Software Foundation')">
-          <!--Xalan quirk--><xsl:value-of select="count(exsl:node-set($recto.content)/*)"/></xsl:when>
-        <xsl:otherwise>1</xsl:otherwise>
-      </xsl:choose>
-    </xsl:variable>
-    <xsl:if test="(normalize-space($recto.content) != '') or ($recto.elements.count &gt; 0)">
-      <div><xsl:copy-of select="$recto.content"/></div>
-    </xsl:if>
-    <xsl:variable name="verso.content">
-      <xsl:call-template name="part.titlepage.before.verso"/>
-      <xsl:call-template name="part.titlepage.verso"/>
-    </xsl:variable>
-    <xsl:variable name="verso.elements.count">
-      <xsl:choose>
-        <xsl:when test="function-available('exsl:node-set')"><xsl:value-of select="count(exsl:node-set($verso.content)/*)"/></xsl:when>
-        <xsl:when test="contains(system-property('xsl:vendor'), 'Apache Software Foundation')">
-          <!--Xalan quirk--><xsl:value-of select="count(exsl:node-set($verso.content)/*)"/></xsl:when>
-        <xsl:otherwise>1</xsl:otherwise>
-      </xsl:choose>
-    </xsl:variable>
-    <xsl:if test="(normalize-space($verso.content) != '') or ($verso.elements.count &gt; 0)">
-      <div><xsl:copy-of select="$verso.content"/></div>
-    </xsl:if>
-    <xsl:call-template name="part.titlepage.separator"/>
-  </div>
-</xsl:template>
-
-<xsl:template match="*" mode="part.titlepage.recto.mode">
-  <!-- if an element isn't found in this mode, -->
-  <!-- try the generic titlepage.mode -->
-  <xsl:apply-templates select="." mode="titlepage.mode"/>
-</xsl:template>
-
-<xsl:template match="*" mode="part.titlepage.verso.mode">
-  <!-- if an element isn't found in this mode, -->
-  <!-- try the generic titlepage.mode -->
-  <xsl:apply-templates select="." mode="titlepage.mode"/>
-</xsl:template>
-
-<xsl:template match="subtitle" mode="part.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="part.titlepage.recto.style">
-<xsl:apply-templates select="." mode="part.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="corpauthor" mode="part.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="part.titlepage.recto.style">
-<xsl:apply-templates select="." mode="part.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="authorgroup" mode="part.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="part.titlepage.recto.style">
-<xsl:apply-templates select="." mode="part.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="author" mode="part.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="part.titlepage.recto.style">
-<xsl:apply-templates select="." mode="part.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="othercredit" mode="part.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="part.titlepage.recto.style">
-<xsl:apply-templates select="." mode="part.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="releaseinfo" mode="part.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="part.titlepage.recto.style">
-<xsl:apply-templates select="." mode="part.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="copyright" mode="part.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="part.titlepage.recto.style">
-<xsl:apply-templates select="." mode="part.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="legalnotice" mode="part.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="part.titlepage.recto.style">
-<xsl:apply-templates select="." mode="part.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="pubdate" mode="part.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="part.titlepage.recto.style">
-<xsl:apply-templates select="." mode="part.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="revision" mode="part.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="part.titlepage.recto.style">
-<xsl:apply-templates select="." mode="part.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="revhistory" mode="part.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="part.titlepage.recto.style">
-<xsl:apply-templates select="." mode="part.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="abstract" mode="part.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="part.titlepage.recto.style">
-<xsl:apply-templates select="." mode="part.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template name="partintro.titlepage.recto">
-  <xsl:choose>
-    <xsl:when test="partintroinfo/title">
-      <xsl:apply-templates mode="partintro.titlepage.recto.auto.mode" select="partintroinfo/title"/>
-    </xsl:when>
-    <xsl:when test="docinfo/title">
-      <xsl:apply-templates mode="partintro.titlepage.recto.auto.mode" select="docinfo/title"/>
-    </xsl:when>
-    <xsl:when test="info/title">
-      <xsl:apply-templates mode="partintro.titlepage.recto.auto.mode" select="info/title"/>
-    </xsl:when>
-    <xsl:when test="title">
-      <xsl:apply-templates mode="partintro.titlepage.recto.auto.mode" select="title"/>
-    </xsl:when>
-  </xsl:choose>
-
-  <xsl:choose>
-    <xsl:when test="partintroinfo/subtitle">
-      <xsl:apply-templates mode="partintro.titlepage.recto.auto.mode" select="partintroinfo/subtitle"/>
-    </xsl:when>
-    <xsl:when test="docinfo/subtitle">
-      <xsl:apply-templates mode="partintro.titlepage.recto.auto.mode" select="docinfo/subtitle"/>
-    </xsl:when>
-    <xsl:when test="info/subtitle">
-      <xsl:apply-templates mode="partintro.titlepage.recto.auto.mode" select="info/subtitle"/>
-    </xsl:when>
-    <xsl:when test="subtitle">
-      <xsl:apply-templates mode="partintro.titlepage.recto.auto.mode" select="subtitle"/>
-    </xsl:when>
-  </xsl:choose>
-
-  <xsl:apply-templates mode="partintro.titlepage.recto.auto.mode" select="partintroinfo/corpauthor"/>
-  <xsl:apply-templates mode="partintro.titlepage.recto.auto.mode" select="docinfo/corpauthor"/>
-  <xsl:apply-templates mode="partintro.titlepage.recto.auto.mode" select="info/corpauthor"/>
-  <xsl:apply-templates mode="partintro.titlepage.recto.auto.mode" select="partintroinfo/authorgroup"/>
-  <xsl:apply-templates mode="partintro.titlepage.recto.auto.mode" select="docinfo/authorgroup"/>
-  <xsl:apply-templates mode="partintro.titlepage.recto.auto.mode" select="info/authorgroup"/>
-  <xsl:apply-templates mode="partintro.titlepage.recto.auto.mode" select="partintroinfo/author"/>
-  <xsl:apply-templates mode="partintro.titlepage.recto.auto.mode" select="docinfo/author"/>
-  <xsl:apply-templates mode="partintro.titlepage.recto.auto.mode" select="info/author"/>
-  <xsl:apply-templates mode="partintro.titlepage.recto.auto.mode" select="partintroinfo/othercredit"/>
-  <xsl:apply-templates mode="partintro.titlepage.recto.auto.mode" select="docinfo/othercredit"/>
-  <xsl:apply-templates mode="partintro.titlepage.recto.auto.mode" select="info/othercredit"/>
-  <xsl:apply-templates mode="partintro.titlepage.recto.auto.mode" select="partintroinfo/releaseinfo"/>
-  <xsl:apply-templates mode="partintro.titlepage.recto.auto.mode" select="docinfo/releaseinfo"/>
-  <xsl:apply-templates mode="partintro.titlepage.recto.auto.mode" select="info/releaseinfo"/>
-  <xsl:apply-templates mode="partintro.titlepage.recto.auto.mode" select="partintroinfo/copyright"/>
-  <xsl:apply-templates mode="partintro.titlepage.recto.auto.mode" select="docinfo/copyright"/>
-  <xsl:apply-templates mode="partintro.titlepage.recto.auto.mode" select="info/copyright"/>
-  <xsl:apply-templates mode="partintro.titlepage.recto.auto.mode" select="partintroinfo/legalnotice"/>
-  <xsl:apply-templates mode="partintro.titlepage.recto.auto.mode" select="docinfo/legalnotice"/>
-  <xsl:apply-templates mode="partintro.titlepage.recto.auto.mode" select="info/legalnotice"/>
-  <xsl:apply-templates mode="partintro.titlepage.recto.auto.mode" select="partintroinfo/pubdate"/>
-  <xsl:apply-templates mode="partintro.titlepage.recto.auto.mode" select="docinfo/pubdate"/>
-  <xsl:apply-templates mode="partintro.titlepage.recto.auto.mode" select="info/pubdate"/>
-  <xsl:apply-templates mode="partintro.titlepage.recto.auto.mode" select="partintroinfo/revision"/>
-  <xsl:apply-templates mode="partintro.titlepage.recto.auto.mode" select="docinfo/revision"/>
-  <xsl:apply-templates mode="partintro.titlepage.recto.auto.mode" select="info/revision"/>
-  <xsl:apply-templates mode="partintro.titlepage.recto.auto.mode" select="partintroinfo/revhistory"/>
-  <xsl:apply-templates mode="partintro.titlepage.recto.auto.mode" select="docinfo/revhistory"/>
-  <xsl:apply-templates mode="partintro.titlepage.recto.auto.mode" select="info/revhistory"/>
-  <xsl:apply-templates mode="partintro.titlepage.recto.auto.mode" select="partintroinfo/abstract"/>
-  <xsl:apply-templates mode="partintro.titlepage.recto.auto.mode" select="docinfo/abstract"/>
-  <xsl:apply-templates mode="partintro.titlepage.recto.auto.mode" select="info/abstract"/>
-</xsl:template>
-
-<xsl:template name="partintro.titlepage.verso">
-</xsl:template>
-
-<xsl:template name="partintro.titlepage.separator">
-</xsl:template>
-
-<xsl:template name="partintro.titlepage.before.recto">
-</xsl:template>
-
-<xsl:template name="partintro.titlepage.before.verso">
-</xsl:template>
-
-<xsl:template name="partintro.titlepage">
-  <div xmlns="http://www.w3.org/1999/xhtml">
-    <xsl:variable name="recto.content">
-      <xsl:call-template name="partintro.titlepage.before.recto"/>
-      <xsl:call-template name="partintro.titlepage.recto"/>
-    </xsl:variable>
-    <xsl:variable name="recto.elements.count">
-      <xsl:choose>
-        <xsl:when test="function-available('exsl:node-set')"><xsl:value-of select="count(exsl:node-set($recto.content)/*)"/></xsl:when>
-        <xsl:when test="contains(system-property('xsl:vendor'), 'Apache Software Foundation')">
-          <!--Xalan quirk--><xsl:value-of select="count(exsl:node-set($recto.content)/*)"/></xsl:when>
-        <xsl:otherwise>1</xsl:otherwise>
-      </xsl:choose>
-    </xsl:variable>
-    <xsl:if test="(normalize-space($recto.content) != '') or ($recto.elements.count &gt; 0)">
-      <div><xsl:copy-of select="$recto.content"/></div>
-    </xsl:if>
-    <xsl:variable name="verso.content">
-      <xsl:call-template name="partintro.titlepage.before.verso"/>
-      <xsl:call-template name="partintro.titlepage.verso"/>
-    </xsl:variable>
-    <xsl:variable name="verso.elements.count">
-      <xsl:choose>
-        <xsl:when test="function-available('exsl:node-set')"><xsl:value-of select="count(exsl:node-set($verso.content)/*)"/></xsl:when>
-        <xsl:when test="contains(system-property('xsl:vendor'), 'Apache Software Foundation')">
-          <!--Xalan quirk--><xsl:value-of select="count(exsl:node-set($verso.content)/*)"/></xsl:when>
-        <xsl:otherwise>1</xsl:otherwise>
-      </xsl:choose>
-    </xsl:variable>
-    <xsl:if test="(normalize-space($verso.content) != '') or ($verso.elements.count &gt; 0)">
-      <div><xsl:copy-of select="$verso.content"/></div>
-    </xsl:if>
-    <xsl:call-template name="partintro.titlepage.separator"/>
-  </div>
-</xsl:template>
-
-<xsl:template match="*" mode="partintro.titlepage.recto.mode">
-  <!-- if an element isn't found in this mode, -->
-  <!-- try the generic titlepage.mode -->
-  <xsl:apply-templates select="." mode="titlepage.mode"/>
-</xsl:template>
-
-<xsl:template match="*" mode="partintro.titlepage.verso.mode">
-  <!-- if an element isn't found in this mode, -->
-  <!-- try the generic titlepage.mode -->
-  <xsl:apply-templates select="." mode="titlepage.mode"/>
-</xsl:template>
-
-<xsl:template match="title" mode="partintro.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="partintro.titlepage.recto.style">
-<xsl:apply-templates select="." mode="partintro.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="subtitle" mode="partintro.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="partintro.titlepage.recto.style">
-<xsl:apply-templates select="." mode="partintro.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="corpauthor" mode="partintro.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="partintro.titlepage.recto.style">
-<xsl:apply-templates select="." mode="partintro.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="authorgroup" mode="partintro.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="partintro.titlepage.recto.style">
-<xsl:apply-templates select="." mode="partintro.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="author" mode="partintro.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="partintro.titlepage.recto.style">
-<xsl:apply-templates select="." mode="partintro.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="othercredit" mode="partintro.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="partintro.titlepage.recto.style">
-<xsl:apply-templates select="." mode="partintro.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="releaseinfo" mode="partintro.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="partintro.titlepage.recto.style">
-<xsl:apply-templates select="." mode="partintro.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="copyright" mode="partintro.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="partintro.titlepage.recto.style">
-<xsl:apply-templates select="." mode="partintro.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="legalnotice" mode="partintro.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="partintro.titlepage.recto.style">
-<xsl:apply-templates select="." mode="partintro.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="pubdate" mode="partintro.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="partintro.titlepage.recto.style">
-<xsl:apply-templates select="." mode="partintro.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="revision" mode="partintro.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="partintro.titlepage.recto.style">
-<xsl:apply-templates select="." mode="partintro.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="revhistory" mode="partintro.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="partintro.titlepage.recto.style">
-<xsl:apply-templates select="." mode="partintro.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="abstract" mode="partintro.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="partintro.titlepage.recto.style">
-<xsl:apply-templates select="." mode="partintro.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template name="reference.titlepage.recto">
-  <xsl:choose>
-    <xsl:when test="referenceinfo/title">
-      <xsl:apply-templates mode="reference.titlepage.recto.auto.mode" select="referenceinfo/title"/>
-    </xsl:when>
-    <xsl:when test="docinfo/title">
-      <xsl:apply-templates mode="reference.titlepage.recto.auto.mode" select="docinfo/title"/>
-    </xsl:when>
-    <xsl:when test="info/title">
-      <xsl:apply-templates mode="reference.titlepage.recto.auto.mode" select="info/title"/>
-    </xsl:when>
-    <xsl:when test="title">
-      <xsl:apply-templates mode="reference.titlepage.recto.auto.mode" select="title"/>
-    </xsl:when>
-  </xsl:choose>
-
-  <xsl:choose>
-    <xsl:when test="referenceinfo/subtitle">
-      <xsl:apply-templates mode="reference.titlepage.recto.auto.mode" select="referenceinfo/subtitle"/>
-    </xsl:when>
-    <xsl:when test="docinfo/subtitle">
-      <xsl:apply-templates mode="reference.titlepage.recto.auto.mode" select="docinfo/subtitle"/>
-    </xsl:when>
-    <xsl:when test="info/subtitle">
-      <xsl:apply-templates mode="reference.titlepage.recto.auto.mode" select="info/subtitle"/>
-    </xsl:when>
-    <xsl:when test="subtitle">
-      <xsl:apply-templates mode="reference.titlepage.recto.auto.mode" select="subtitle"/>
-    </xsl:when>
-  </xsl:choose>
-
-  <xsl:apply-templates mode="reference.titlepage.recto.auto.mode" select="referenceinfo/corpauthor"/>
-  <xsl:apply-templates mode="reference.titlepage.recto.auto.mode" select="docinfo/corpauthor"/>
-  <xsl:apply-templates mode="reference.titlepage.recto.auto.mode" select="info/corpauthor"/>
-  <xsl:apply-templates mode="reference.titlepage.recto.auto.mode" select="referenceinfo/authorgroup"/>
-  <xsl:apply-templates mode="reference.titlepage.recto.auto.mode" select="docinfo/authorgroup"/>
-  <xsl:apply-templates mode="reference.titlepage.recto.auto.mode" select="info/authorgroup"/>
-  <xsl:apply-templates mode="reference.titlepage.recto.auto.mode" select="referenceinfo/author"/>
-  <xsl:apply-templates mode="reference.titlepage.recto.auto.mode" select="docinfo/author"/>
-  <xsl:apply-templates mode="reference.titlepage.recto.auto.mode" select="info/author"/>
-  <xsl:apply-templates mode="reference.titlepage.recto.auto.mode" select="referenceinfo/othercredit"/>
-  <xsl:apply-templates mode="reference.titlepage.recto.auto.mode" select="docinfo/othercredit"/>
-  <xsl:apply-templates mode="reference.titlepage.recto.auto.mode" select="info/othercredit"/>
-  <xsl:apply-templates mode="reference.titlepage.recto.auto.mode" select="referenceinfo/releaseinfo"/>
-  <xsl:apply-templates mode="reference.titlepage.recto.auto.mode" select="docinfo/releaseinfo"/>
-  <xsl:apply-templates mode="reference.titlepage.recto.auto.mode" select="info/releaseinfo"/>
-  <xsl:apply-templates mode="reference.titlepage.recto.auto.mode" select="referenceinfo/copyright"/>
-  <xsl:apply-templates mode="reference.titlepage.recto.auto.mode" select="docinfo/copyright"/>
-  <xsl:apply-templates mode="reference.titlepage.recto.auto.mode" select="info/copyright"/>
-  <xsl:apply-templates mode="reference.titlepage.recto.auto.mode" select="referenceinfo/legalnotice"/>
-  <xsl:apply-templates mode="reference.titlepage.recto.auto.mode" select="docinfo/legalnotice"/>
-  <xsl:apply-templates mode="reference.titlepage.recto.auto.mode" select="info/legalnotice"/>
-  <xsl:apply-templates mode="reference.titlepage.recto.auto.mode" select="referenceinfo/pubdate"/>
-  <xsl:apply-templates mode="reference.titlepage.recto.auto.mode" select="docinfo/pubdate"/>
-  <xsl:apply-templates mode="reference.titlepage.recto.auto.mode" select="info/pubdate"/>
-  <xsl:apply-templates mode="reference.titlepage.recto.auto.mode" select="referenceinfo/revision"/>
-  <xsl:apply-templates mode="reference.titlepage.recto.auto.mode" select="docinfo/revision"/>
-  <xsl:apply-templates mode="reference.titlepage.recto.auto.mode" select="info/revision"/>
-  <xsl:apply-templates mode="reference.titlepage.recto.auto.mode" select="referenceinfo/revhistory"/>
-  <xsl:apply-templates mode="reference.titlepage.recto.auto.mode" select="docinfo/revhistory"/>
-  <xsl:apply-templates mode="reference.titlepage.recto.auto.mode" select="info/revhistory"/>
-  <xsl:apply-templates mode="reference.titlepage.recto.auto.mode" select="referenceinfo/abstract"/>
-  <xsl:apply-templates mode="reference.titlepage.recto.auto.mode" select="docinfo/abstract"/>
-  <xsl:apply-templates mode="reference.titlepage.recto.auto.mode" select="info/abstract"/>
-</xsl:template>
-
-<xsl:template name="reference.titlepage.verso">
-</xsl:template>
-
-<xsl:template name="reference.titlepage.separator"><hr xmlns="http://www.w3.org/1999/xhtml"/>
-</xsl:template>
-
-<xsl:template name="reference.titlepage.before.recto">
-</xsl:template>
-
-<xsl:template name="reference.titlepage.before.verso">
-</xsl:template>
-
-<xsl:template name="reference.titlepage">
-  <div xmlns="http://www.w3.org/1999/xhtml" class="titlepage">
-    <xsl:variable name="recto.content">
-      <xsl:call-template name="reference.titlepage.before.recto"/>
-      <xsl:call-template name="reference.titlepage.recto"/>
-    </xsl:variable>
-    <xsl:variable name="recto.elements.count">
-      <xsl:choose>
-        <xsl:when test="function-available('exsl:node-set')"><xsl:value-of select="count(exsl:node-set($recto.content)/*)"/></xsl:when>
-        <xsl:when test="contains(system-property('xsl:vendor'), 'Apache Software Foundation')">
-          <!--Xalan quirk--><xsl:value-of select="count(exsl:node-set($recto.content)/*)"/></xsl:when>
-        <xsl:otherwise>1</xsl:otherwise>
-      </xsl:choose>
-    </xsl:variable>
-    <xsl:if test="(normalize-space($recto.content) != '') or ($recto.elements.count &gt; 0)">
-      <div><xsl:copy-of select="$recto.content"/></div>
-    </xsl:if>
-    <xsl:variable name="verso.content">
-      <xsl:call-template name="reference.titlepage.before.verso"/>
-      <xsl:call-template name="reference.titlepage.verso"/>
-    </xsl:variable>
-    <xsl:variable name="verso.elements.count">
-      <xsl:choose>
-        <xsl:when test="function-available('exsl:node-set')"><xsl:value-of select="count(exsl:node-set($verso.content)/*)"/></xsl:when>
-        <xsl:when test="contains(system-property('xsl:vendor'), 'Apache Software Foundation')">
-          <!--Xalan quirk--><xsl:value-of select="count(exsl:node-set($verso.content)/*)"/></xsl:when>
-        <xsl:otherwise>1</xsl:otherwise>
-      </xsl:choose>
-    </xsl:variable>
-    <xsl:if test="(normalize-space($verso.content) != '') or ($verso.elements.count &gt; 0)">
-      <div><xsl:copy-of select="$verso.content"/></div>
-    </xsl:if>
-    <xsl:call-template name="reference.titlepage.separator"/>
-  </div>
-</xsl:template>
-
-<xsl:template match="*" mode="reference.titlepage.recto.mode">
-  <!-- if an element isn't found in this mode, -->
-  <!-- try the generic titlepage.mode -->
-  <xsl:apply-templates select="." mode="titlepage.mode"/>
-</xsl:template>
-
-<xsl:template match="*" mode="reference.titlepage.verso.mode">
-  <!-- if an element isn't found in this mode, -->
-  <!-- try the generic titlepage.mode -->
-  <xsl:apply-templates select="." mode="titlepage.mode"/>
-</xsl:template>
-
-<xsl:template match="title" mode="reference.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="reference.titlepage.recto.style">
-<xsl:apply-templates select="." mode="reference.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="subtitle" mode="reference.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="reference.titlepage.recto.style">
-<xsl:apply-templates select="." mode="reference.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="corpauthor" mode="reference.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="reference.titlepage.recto.style">
-<xsl:apply-templates select="." mode="reference.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="authorgroup" mode="reference.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="reference.titlepage.recto.style">
-<xsl:apply-templates select="." mode="reference.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="author" mode="reference.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="reference.titlepage.recto.style">
-<xsl:apply-templates select="." mode="reference.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="othercredit" mode="reference.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="reference.titlepage.recto.style">
-<xsl:apply-templates select="." mode="reference.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="releaseinfo" mode="reference.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="reference.titlepage.recto.style">
-<xsl:apply-templates select="." mode="reference.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="copyright" mode="reference.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="reference.titlepage.recto.style">
-<xsl:apply-templates select="." mode="reference.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="legalnotice" mode="reference.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="reference.titlepage.recto.style">
-<xsl:apply-templates select="." mode="reference.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="pubdate" mode="reference.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="reference.titlepage.recto.style">
-<xsl:apply-templates select="." mode="reference.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="revision" mode="reference.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="reference.titlepage.recto.style">
-<xsl:apply-templates select="." mode="reference.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="revhistory" mode="reference.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="reference.titlepage.recto.style">
-<xsl:apply-templates select="." mode="reference.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="abstract" mode="reference.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="reference.titlepage.recto.style">
-<xsl:apply-templates select="." mode="reference.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template name="refentry.titlepage.recto">
-</xsl:template>
-
-<xsl:template name="refentry.titlepage.verso">
-</xsl:template>
-
-<xsl:template name="refentry.titlepage.separator">
-</xsl:template>
-
-<xsl:template name="refentry.titlepage.before.recto">
-</xsl:template>
-
-<xsl:template name="refentry.titlepage.before.verso">
-</xsl:template>
-
-<xsl:template name="refentry.titlepage">
-  <div xmlns="http://www.w3.org/1999/xhtml" class="titlepage">
-    <xsl:variable name="recto.content">
-      <xsl:call-template name="refentry.titlepage.before.recto"/>
-      <xsl:call-template name="refentry.titlepage.recto"/>
-    </xsl:variable>
-    <xsl:variable name="recto.elements.count">
-      <xsl:choose>
-        <xsl:when test="function-available('exsl:node-set')"><xsl:value-of select="count(exsl:node-set($recto.content)/*)"/></xsl:when>
-        <xsl:when test="contains(system-property('xsl:vendor'), 'Apache Software Foundation')">
-          <!--Xalan quirk--><xsl:value-of select="count(exsl:node-set($recto.content)/*)"/></xsl:when>
-        <xsl:otherwise>1</xsl:otherwise>
-      </xsl:choose>
-    </xsl:variable>
-    <xsl:if test="(normalize-space($recto.content) != '') or ($recto.elements.count &gt; 0)">
-      <div><xsl:copy-of select="$recto.content"/></div>
-    </xsl:if>
-    <xsl:variable name="verso.content">
-      <xsl:call-template name="refentry.titlepage.before.verso"/>
-      <xsl:call-template name="refentry.titlepage.verso"/>
-    </xsl:variable>
-    <xsl:variable name="verso.elements.count">
-      <xsl:choose>
-        <xsl:when test="function-available('exsl:node-set')"><xsl:value-of select="count(exsl:node-set($verso.content)/*)"/></xsl:when>
-        <xsl:when test="contains(system-property('xsl:vendor'), 'Apache Software Foundation')">
-          <!--Xalan quirk--><xsl:value-of select="count(exsl:node-set($verso.content)/*)"/></xsl:when>
-        <xsl:otherwise>1</xsl:otherwise>
-      </xsl:choose>
-    </xsl:variable>
-    <xsl:if test="(normalize-space($verso.content) != '') or ($verso.elements.count &gt; 0)">
-      <div><xsl:copy-of select="$verso.content"/></div>
-    </xsl:if>
-    <xsl:call-template name="refentry.titlepage.separator"/>
-  </div>
-</xsl:template>
-
-<xsl:template match="*" mode="refentry.titlepage.recto.mode">
-  <!-- if an element isn't found in this mode, -->
-  <!-- try the generic titlepage.mode -->
-  <xsl:apply-templates select="." mode="titlepage.mode"/>
-</xsl:template>
-
-<xsl:template match="*" mode="refentry.titlepage.verso.mode">
-  <!-- if an element isn't found in this mode, -->
-  <!-- try the generic titlepage.mode -->
-  <xsl:apply-templates select="." mode="titlepage.mode"/>
-</xsl:template>
-
-<xsl:template name="dedication.titlepage.recto">
-  <div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="dedication.titlepage.recto.style">
-<xsl:call-template name="component.title">
-<xsl:with-param name="node" select="ancestor-or-self::dedication[1]"/>
-</xsl:call-template></div>
-  <xsl:choose>
-    <xsl:when test="dedicationinfo/subtitle">
-      <xsl:apply-templates mode="dedication.titlepage.recto.auto.mode" select="dedicationinfo/subtitle"/>
-    </xsl:when>
-    <xsl:when test="docinfo/subtitle">
-      <xsl:apply-templates mode="dedication.titlepage.recto.auto.mode" select="docinfo/subtitle"/>
-    </xsl:when>
-    <xsl:when test="info/subtitle">
-      <xsl:apply-templates mode="dedication.titlepage.recto.auto.mode" select="info/subtitle"/>
-    </xsl:when>
-    <xsl:when test="subtitle">
-      <xsl:apply-templates mode="dedication.titlepage.recto.auto.mode" select="subtitle"/>
-    </xsl:when>
-  </xsl:choose>
-
-</xsl:template>
-
-<xsl:template name="dedication.titlepage.verso">
-</xsl:template>
-
-<xsl:template name="dedication.titlepage.separator">
-</xsl:template>
-
-<xsl:template name="dedication.titlepage.before.recto">
-</xsl:template>
-
-<xsl:template name="dedication.titlepage.before.verso">
-</xsl:template>
-
-<xsl:template name="dedication.titlepage">
-  <div xmlns="http://www.w3.org/1999/xhtml" class="titlepage">
-    <xsl:variable name="recto.content">
-      <xsl:call-template name="dedication.titlepage.before.recto"/>
-      <xsl:call-template name="dedication.titlepage.recto"/>
-    </xsl:variable>
-    <xsl:variable name="recto.elements.count">
-      <xsl:choose>
-        <xsl:when test="function-available('exsl:node-set')"><xsl:value-of select="count(exsl:node-set($recto.content)/*)"/></xsl:when>
-        <xsl:when test="contains(system-property('xsl:vendor'), 'Apache Software Foundation')">
-          <!--Xalan quirk--><xsl:value-of select="count(exsl:node-set($recto.content)/*)"/></xsl:when>
-        <xsl:otherwise>1</xsl:otherwise>
-      </xsl:choose>
-    </xsl:variable>
-    <xsl:if test="(normalize-space($recto.content) != '') or ($recto.elements.count &gt; 0)">
-      <div><xsl:copy-of select="$recto.content"/></div>
-    </xsl:if>
-    <xsl:variable name="verso.content">
-      <xsl:call-template name="dedication.titlepage.before.verso"/>
-      <xsl:call-template name="dedication.titlepage.verso"/>
-    </xsl:variable>
-    <xsl:variable name="verso.elements.count">
-      <xsl:choose>
-        <xsl:when test="function-available('exsl:node-set')"><xsl:value-of select="count(exsl:node-set($verso.content)/*)"/></xsl:when>
-        <xsl:when test="contains(system-property('xsl:vendor'), 'Apache Software Foundation')">
-          <!--Xalan quirk--><xsl:value-of select="count(exsl:node-set($verso.content)/*)"/></xsl:when>
-        <xsl:otherwise>1</xsl:otherwise>
-      </xsl:choose>
-    </xsl:variable>
-    <xsl:if test="(normalize-space($verso.content) != '') or ($verso.elements.count &gt; 0)">
-      <div><xsl:copy-of select="$verso.content"/></div>
-    </xsl:if>
-    <xsl:call-template name="dedication.titlepage.separator"/>
-  </div>
-</xsl:template>
-
-<xsl:template match="*" mode="dedication.titlepage.recto.mode">
-  <!-- if an element isn't found in this mode, -->
-  <!-- try the generic titlepage.mode -->
-  <xsl:apply-templates select="." mode="titlepage.mode"/>
-</xsl:template>
-
-<xsl:template match="*" mode="dedication.titlepage.verso.mode">
-  <!-- if an element isn't found in this mode, -->
-  <!-- try the generic titlepage.mode -->
-  <xsl:apply-templates select="." mode="titlepage.mode"/>
-</xsl:template>
-
-<xsl:template match="subtitle" mode="dedication.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="dedication.titlepage.recto.style">
-<xsl:apply-templates select="." mode="dedication.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template name="acknowledgements.titlepage.recto">
-  <div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="acknowledgements.titlepage.recto.style">
-<xsl:call-template name="component.title">
-<xsl:with-param name="node" select="ancestor-or-self::acknowledgements[1]"/>
-</xsl:call-template></div>
-  <xsl:choose>
-    <xsl:when test="acknowledgementsinfo/subtitle">
-      <xsl:apply-templates mode="acknowledgements.titlepage.recto.auto.mode" select="acknowledgementsinfo/subtitle"/>
-    </xsl:when>
-    <xsl:when test="docinfo/subtitle">
-      <xsl:apply-templates mode="acknowledgements.titlepage.recto.auto.mode" select="docinfo/subtitle"/>
-    </xsl:when>
-    <xsl:when test="info/subtitle">
-      <xsl:apply-templates mode="acknowledgements.titlepage.recto.auto.mode" select="info/subtitle"/>
-    </xsl:when>
-    <xsl:when test="subtitle">
-      <xsl:apply-templates mode="acknowledgements.titlepage.recto.auto.mode" select="subtitle"/>
-    </xsl:when>
-  </xsl:choose>
-
-</xsl:template>
-
-<xsl:template name="acknowledgements.titlepage.verso">
-</xsl:template>
-
-<xsl:template name="acknowledgements.titlepage.separator">
-</xsl:template>
-
-<xsl:template name="acknowledgements.titlepage.before.recto">
-</xsl:template>
-
-<xsl:template name="acknowledgements.titlepage.before.verso">
-</xsl:template>
-
-<xsl:template name="acknowledgements.titlepage">
-  <div xmlns="http://www.w3.org/1999/xhtml" class="titlepage">
-    <xsl:variable name="recto.content">
-      <xsl:call-template name="acknowledgements.titlepage.before.recto"/>
-      <xsl:call-template name="acknowledgements.titlepage.recto"/>
-    </xsl:variable>
-    <xsl:variable name="recto.elements.count">
-      <xsl:choose>
-        <xsl:when test="function-available('exsl:node-set')"><xsl:value-of select="count(exsl:node-set($recto.content)/*)"/></xsl:when>
-        <xsl:when test="contains(system-property('xsl:vendor'), 'Apache Software Foundation')">
-          <!--Xalan quirk--><xsl:value-of select="count(exsl:node-set($recto.content)/*)"/></xsl:when>
-        <xsl:otherwise>1</xsl:otherwise>
-      </xsl:choose>
-    </xsl:variable>
-    <xsl:if test="(normalize-space($recto.content) != '') or ($recto.elements.count &gt; 0)">
-      <div><xsl:copy-of select="$recto.content"/></div>
-    </xsl:if>
-    <xsl:variable name="verso.content">
-      <xsl:call-template name="acknowledgements.titlepage.before.verso"/>
-      <xsl:call-template name="acknowledgements.titlepage.verso"/>
-    </xsl:variable>
-    <xsl:variable name="verso.elements.count">
-      <xsl:choose>
-        <xsl:when test="function-available('exsl:node-set')"><xsl:value-of select="count(exsl:node-set($verso.content)/*)"/></xsl:when>
-        <xsl:when test="contains(system-property('xsl:vendor'), 'Apache Software Foundation')">
-          <!--Xalan quirk--><xsl:value-of select="count(exsl:node-set($verso.content)/*)"/></xsl:when>
-        <xsl:otherwise>1</xsl:otherwise>
-      </xsl:choose>
-    </xsl:variable>
-    <xsl:if test="(normalize-space($verso.content) != '') or ($verso.elements.count &gt; 0)">
-      <div><xsl:copy-of select="$verso.content"/></div>
-    </xsl:if>
-    <xsl:call-template name="acknowledgements.titlepage.separator"/>
-  </div>
-</xsl:template>
-
-<xsl:template match="*" mode="acknowledgements.titlepage.recto.mode">
-  <!-- if an element isn't found in this mode, -->
-  <!-- try the generic titlepage.mode -->
-  <xsl:apply-templates select="." mode="titlepage.mode"/>
-</xsl:template>
-
-<xsl:template match="*" mode="acknowledgements.titlepage.verso.mode">
-  <!-- if an element isn't found in this mode, -->
-  <!-- try the generic titlepage.mode -->
-  <xsl:apply-templates select="." mode="titlepage.mode"/>
-</xsl:template>
-
-<xsl:template match="subtitle" mode="acknowledgements.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="acknowledgements.titlepage.recto.style">
-<xsl:apply-templates select="." mode="acknowledgements.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template name="preface.titlepage.recto">
-  <xsl:choose>
-    <xsl:when test="prefaceinfo/title">
-      <xsl:apply-templates mode="preface.titlepage.recto.auto.mode" select="prefaceinfo/title"/>
-    </xsl:when>
-    <xsl:when test="docinfo/title">
-      <xsl:apply-templates mode="preface.titlepage.recto.auto.mode" select="docinfo/title"/>
-    </xsl:when>
-    <xsl:when test="info/title">
-      <xsl:apply-templates mode="preface.titlepage.recto.auto.mode" select="info/title"/>
-    </xsl:when>
-    <xsl:when test="title">
-      <xsl:apply-templates mode="preface.titlepage.recto.auto.mode" select="title"/>
-    </xsl:when>
-  </xsl:choose>
-
-  <xsl:choose>
-    <xsl:when test="prefaceinfo/subtitle">
-      <xsl:apply-templates mode="preface.titlepage.recto.auto.mode" select="prefaceinfo/subtitle"/>
-    </xsl:when>
-    <xsl:when test="docinfo/subtitle">
-      <xsl:apply-templates mode="preface.titlepage.recto.auto.mode" select="docinfo/subtitle"/>
-    </xsl:when>
-    <xsl:when test="info/subtitle">
-      <xsl:apply-templates mode="preface.titlepage.recto.auto.mode" select="info/subtitle"/>
-    </xsl:when>
-    <xsl:when test="subtitle">
-      <xsl:apply-templates mode="preface.titlepage.recto.auto.mode" select="subtitle"/>
-    </xsl:when>
-  </xsl:choose>
-
-  <xsl:apply-templates mode="preface.titlepage.recto.auto.mode" select="prefaceinfo/corpauthor"/>
-  <xsl:apply-templates mode="preface.titlepage.recto.auto.mode" select="docinfo/corpauthor"/>
-  <xsl:apply-templates mode="preface.titlepage.recto.auto.mode" select="info/corpauthor"/>
-  <xsl:apply-templates mode="preface.titlepage.recto.auto.mode" select="prefaceinfo/authorgroup"/>
-  <xsl:apply-templates mode="preface.titlepage.recto.auto.mode" select="docinfo/authorgroup"/>
-  <xsl:apply-templates mode="preface.titlepage.recto.auto.mode" select="info/authorgroup"/>
-  <xsl:apply-templates mode="preface.titlepage.recto.auto.mode" select="prefaceinfo/author"/>
-  <xsl:apply-templates mode="preface.titlepage.recto.auto.mode" select="docinfo/author"/>
-  <xsl:apply-templates mode="preface.titlepage.recto.auto.mode" select="info/author"/>
-  <xsl:apply-templates mode="preface.titlepage.recto.auto.mode" select="prefaceinfo/othercredit"/>
-  <xsl:apply-templates mode="preface.titlepage.recto.auto.mode" select="docinfo/othercredit"/>
-  <xsl:apply-templates mode="preface.titlepage.recto.auto.mode" select="info/othercredit"/>
-  <xsl:apply-templates mode="preface.titlepage.recto.auto.mode" select="prefaceinfo/releaseinfo"/>
-  <xsl:apply-templates mode="preface.titlepage.recto.auto.mode" select="docinfo/releaseinfo"/>
-  <xsl:apply-templates mode="preface.titlepage.recto.auto.mode" select="info/releaseinfo"/>
-  <xsl:apply-templates mode="preface.titlepage.recto.auto.mode" select="prefaceinfo/copyright"/>
-  <xsl:apply-templates mode="preface.titlepage.recto.auto.mode" select="docinfo/copyright"/>
-  <xsl:apply-templates mode="preface.titlepage.recto.auto.mode" select="info/copyright"/>
-  <xsl:apply-templates mode="preface.titlepage.recto.auto.mode" select="prefaceinfo/legalnotice"/>
-  <xsl:apply-templates mode="preface.titlepage.recto.auto.mode" select="docinfo/legalnotice"/>
-  <xsl:apply-templates mode="preface.titlepage.recto.auto.mode" select="info/legalnotice"/>
-  <xsl:apply-templates mode="preface.titlepage.recto.auto.mode" select="prefaceinfo/pubdate"/>
-  <xsl:apply-templates mode="preface.titlepage.recto.auto.mode" select="docinfo/pubdate"/>
-  <xsl:apply-templates mode="preface.titlepage.recto.auto.mode" select="info/pubdate"/>
-  <xsl:apply-templates mode="preface.titlepage.recto.auto.mode" select="prefaceinfo/revision"/>
-  <xsl:apply-templates mode="preface.titlepage.recto.auto.mode" select="docinfo/revision"/>
-  <xsl:apply-templates mode="preface.titlepage.recto.auto.mode" select="info/revision"/>
-  <xsl:apply-templates mode="preface.titlepage.recto.auto.mode" select="prefaceinfo/revhistory"/>
-  <xsl:apply-templates mode="preface.titlepage.recto.auto.mode" select="docinfo/revhistory"/>
-  <xsl:apply-templates mode="preface.titlepage.recto.auto.mode" select="info/revhistory"/>
-  <xsl:apply-templates mode="preface.titlepage.recto.auto.mode" select="prefaceinfo/abstract"/>
-  <xsl:apply-templates mode="preface.titlepage.recto.auto.mode" select="docinfo/abstract"/>
-  <xsl:apply-templates mode="preface.titlepage.recto.auto.mode" select="info/abstract"/>
-</xsl:template>
-
-<xsl:template name="preface.titlepage.verso">
-</xsl:template>
-
-<xsl:template name="preface.titlepage.separator">
-</xsl:template>
-
-<xsl:template name="preface.titlepage.before.recto">
-</xsl:template>
-
-<xsl:template name="preface.titlepage.before.verso">
-</xsl:template>
-
-<xsl:template name="preface.titlepage">
-  <div xmlns="http://www.w3.org/1999/xhtml" class="titlepage">
-    <xsl:variable name="recto.content">
-      <xsl:call-template name="preface.titlepage.before.recto"/>
-      <xsl:call-template name="preface.titlepage.recto"/>
-    </xsl:variable>
-    <xsl:variable name="recto.elements.count">
-      <xsl:choose>
-        <xsl:when test="function-available('exsl:node-set')"><xsl:value-of select="count(exsl:node-set($recto.content)/*)"/></xsl:when>
-        <xsl:when test="contains(system-property('xsl:vendor'), 'Apache Software Foundation')">
-          <!--Xalan quirk--><xsl:value-of select="count(exsl:node-set($recto.content)/*)"/></xsl:when>
-        <xsl:otherwise>1</xsl:otherwise>
-      </xsl:choose>
-    </xsl:variable>
-    <xsl:if test="(normalize-space($recto.content) != '') or ($recto.elements.count &gt; 0)">
-      <div><xsl:copy-of select="$recto.content"/></div>
-    </xsl:if>
-    <xsl:variable name="verso.content">
-      <xsl:call-template name="preface.titlepage.before.verso"/>
-      <xsl:call-template name="preface.titlepage.verso"/>
-    </xsl:variable>
-    <xsl:variable name="verso.elements.count">
-      <xsl:choose>
-        <xsl:when test="function-available('exsl:node-set')"><xsl:value-of select="count(exsl:node-set($verso.content)/*)"/></xsl:when>
-        <xsl:when test="contains(system-property('xsl:vendor'), 'Apache Software Foundation')">
-          <!--Xalan quirk--><xsl:value-of select="count(exsl:node-set($verso.content)/*)"/></xsl:when>
-        <xsl:otherwise>1</xsl:otherwise>
-      </xsl:choose>
-    </xsl:variable>
-    <xsl:if test="(normalize-space($verso.content) != '') or ($verso.elements.count &gt; 0)">
-      <div><xsl:copy-of select="$verso.content"/></div>
-    </xsl:if>
-    <xsl:call-template name="preface.titlepage.separator"/>
-  </div>
-</xsl:template>
-
-<xsl:template match="*" mode="preface.titlepage.recto.mode">
-  <!-- if an element isn't found in this mode, -->
-  <!-- try the generic titlepage.mode -->
-  <xsl:apply-templates select="." mode="titlepage.mode"/>
-</xsl:template>
-
-<xsl:template match="*" mode="preface.titlepage.verso.mode">
-  <!-- if an element isn't found in this mode, -->
-  <!-- try the generic titlepage.mode -->
-  <xsl:apply-templates select="." mode="titlepage.mode"/>
-</xsl:template>
-
-<xsl:template match="title" mode="preface.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="preface.titlepage.recto.style">
-<xsl:apply-templates select="." mode="preface.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="subtitle" mode="preface.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="preface.titlepage.recto.style">
-<xsl:apply-templates select="." mode="preface.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="corpauthor" mode="preface.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="preface.titlepage.recto.style">
-<xsl:apply-templates select="." mode="preface.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="authorgroup" mode="preface.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="preface.titlepage.recto.style">
-<xsl:apply-templates select="." mode="preface.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="author" mode="preface.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="preface.titlepage.recto.style">
-<xsl:apply-templates select="." mode="preface.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="othercredit" mode="preface.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="preface.titlepage.recto.style">
-<xsl:apply-templates select="." mode="preface.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="releaseinfo" mode="preface.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="preface.titlepage.recto.style">
-<xsl:apply-templates select="." mode="preface.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="copyright" mode="preface.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="preface.titlepage.recto.style">
-<xsl:apply-templates select="." mode="preface.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="legalnotice" mode="preface.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="preface.titlepage.recto.style">
-<xsl:apply-templates select="." mode="preface.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="pubdate" mode="preface.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="preface.titlepage.recto.style">
-<xsl:apply-templates select="." mode="preface.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="revision" mode="preface.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="preface.titlepage.recto.style">
-<xsl:apply-templates select="." mode="preface.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="revhistory" mode="preface.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="preface.titlepage.recto.style">
-<xsl:apply-templates select="." mode="preface.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="abstract" mode="preface.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="preface.titlepage.recto.style">
-<xsl:apply-templates select="." mode="preface.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template name="chapter.titlepage.recto">
-  <xsl:choose>
-    <xsl:when test="chapterinfo/title">
-      <xsl:apply-templates mode="chapter.titlepage.recto.auto.mode" select="chapterinfo/title"/>
-    </xsl:when>
-    <xsl:when test="docinfo/title">
-      <xsl:apply-templates mode="chapter.titlepage.recto.auto.mode" select="docinfo/title"/>
-    </xsl:when>
-    <xsl:when test="info/title">
-      <xsl:apply-templates mode="chapter.titlepage.recto.auto.mode" select="info/title"/>
-    </xsl:when>
-    <xsl:when test="title">
-      <xsl:apply-templates mode="chapter.titlepage.recto.auto.mode" select="title"/>
-    </xsl:when>
-  </xsl:choose>
-
-  <xsl:choose>
-    <xsl:when test="chapterinfo/subtitle">
-      <xsl:apply-templates mode="chapter.titlepage.recto.auto.mode" select="chapterinfo/subtitle"/>
-    </xsl:when>
-    <xsl:when test="docinfo/subtitle">
-      <xsl:apply-templates mode="chapter.titlepage.recto.auto.mode" select="docinfo/subtitle"/>
-    </xsl:when>
-    <xsl:when test="info/subtitle">
-      <xsl:apply-templates mode="chapter.titlepage.recto.auto.mode" select="info/subtitle"/>
-    </xsl:when>
-    <xsl:when test="subtitle">
-      <xsl:apply-templates mode="chapter.titlepage.recto.auto.mode" select="subtitle"/>
-    </xsl:when>
-  </xsl:choose>
-
-  <xsl:apply-templates mode="chapter.titlepage.recto.auto.mode" select="chapterinfo/corpauthor"/>
-  <xsl:apply-templates mode="chapter.titlepage.recto.auto.mode" select="docinfo/corpauthor"/>
-  <xsl:apply-templates mode="chapter.titlepage.recto.auto.mode" select="info/corpauthor"/>
-  <xsl:apply-templates mode="chapter.titlepage.recto.auto.mode" select="chapterinfo/authorgroup"/>
-  <xsl:apply-templates mode="chapter.titlepage.recto.auto.mode" select="docinfo/authorgroup"/>
-  <xsl:apply-templates mode="chapter.titlepage.recto.auto.mode" select="info/authorgroup"/>
-  <xsl:apply-templates mode="chapter.titlepage.recto.auto.mode" select="chapterinfo/author"/>
-  <xsl:apply-templates mode="chapter.titlepage.recto.auto.mode" select="docinfo/author"/>
-  <xsl:apply-templates mode="chapter.titlepage.recto.auto.mode" select="info/author"/>
-  <xsl:apply-templates mode="chapter.titlepage.recto.auto.mode" select="chapterinfo/othercredit"/>
-  <xsl:apply-templates mode="chapter.titlepage.recto.auto.mode" select="docinfo/othercredit"/>
-  <xsl:apply-templates mode="chapter.titlepage.recto.auto.mode" select="info/othercredit"/>
-  <xsl:apply-templates mode="chapter.titlepage.recto.auto.mode" select="chapterinfo/releaseinfo"/>
-  <xsl:apply-templates mode="chapter.titlepage.recto.auto.mode" select="docinfo/releaseinfo"/>
-  <xsl:apply-templates mode="chapter.titlepage.recto.auto.mode" select="info/releaseinfo"/>
-  <xsl:apply-templates mode="chapter.titlepage.recto.auto.mode" select="chapterinfo/copyright"/>
-  <xsl:apply-templates mode="chapter.titlepage.recto.auto.mode" select="docinfo/copyright"/>
-  <xsl:apply-templates mode="chapter.titlepage.recto.auto.mode" select="info/copyright"/>
-  <xsl:apply-templates mode="chapter.titlepage.recto.auto.mode" select="chapterinfo/legalnotice"/>
-  <xsl:apply-templates mode="chapter.titlepage.recto.auto.mode" select="docinfo/legalnotice"/>
-  <xsl:apply-templates mode="chapter.titlepage.recto.auto.mode" select="info/legalnotice"/>
-  <xsl:apply-templates mode="chapter.titlepage.recto.auto.mode" select="chapterinfo/pubdate"/>
-  <xsl:apply-templates mode="chapter.titlepage.recto.auto.mode" select="docinfo/pubdate"/>
-  <xsl:apply-templates mode="chapter.titlepage.recto.auto.mode" select="info/pubdate"/>
-  <xsl:apply-templates mode="chapter.titlepage.recto.auto.mode" select="chapterinfo/revision"/>
-  <xsl:apply-templates mode="chapter.titlepage.recto.auto.mode" select="docinfo/revision"/>
-  <xsl:apply-templates mode="chapter.titlepage.recto.auto.mode" select="info/revision"/>
-  <xsl:apply-templates mode="chapter.titlepage.recto.auto.mode" select="chapterinfo/revhistory"/>
-  <xsl:apply-templates mode="chapter.titlepage.recto.auto.mode" select="docinfo/revhistory"/>
-  <xsl:apply-templates mode="chapter.titlepage.recto.auto.mode" select="info/revhistory"/>
-  <xsl:apply-templates mode="chapter.titlepage.recto.auto.mode" select="chapterinfo/abstract"/>
-  <xsl:apply-templates mode="chapter.titlepage.recto.auto.mode" select="docinfo/abstract"/>
-  <xsl:apply-templates mode="chapter.titlepage.recto.auto.mode" select="info/abstract"/>
-</xsl:template>
-
-<xsl:template name="chapter.titlepage.verso">
-</xsl:template>
-
-<xsl:template name="chapter.titlepage.separator">
-</xsl:template>
-
-<xsl:template name="chapter.titlepage.before.recto">
-</xsl:template>
-
-<xsl:template name="chapter.titlepage.before.verso">
-</xsl:template>
-
-<xsl:template name="chapter.titlepage">
-  <div xmlns="http://www.w3.org/1999/xhtml" class="titlepage">
-    <xsl:variable name="recto.content">
-      <xsl:call-template name="chapter.titlepage.before.recto"/>
-      <xsl:call-template name="chapter.titlepage.recto"/>
-    </xsl:variable>
-    <xsl:variable name="recto.elements.count">
-      <xsl:choose>
-        <xsl:when test="function-available('exsl:node-set')"><xsl:value-of select="count(exsl:node-set($recto.content)/*)"/></xsl:when>
-        <xsl:when test="contains(system-property('xsl:vendor'), 'Apache Software Foundation')">
-          <!--Xalan quirk--><xsl:value-of select="count(exsl:node-set($recto.content)/*)"/></xsl:when>
-        <xsl:otherwise>1</xsl:otherwise>
-      </xsl:choose>
-    </xsl:variable>
-    <xsl:if test="(normalize-space($recto.content) != '') or ($recto.elements.count &gt; 0)">
-      <div><xsl:copy-of select="$recto.content"/></div>
-    </xsl:if>
-    <xsl:variable name="verso.content">
-      <xsl:call-template name="chapter.titlepage.before.verso"/>
-      <xsl:call-template name="chapter.titlepage.verso"/>
-    </xsl:variable>
-    <xsl:variable name="verso.elements.count">
-      <xsl:choose>
-        <xsl:when test="function-available('exsl:node-set')"><xsl:value-of select="count(exsl:node-set($verso.content)/*)"/></xsl:when>
-        <xsl:when test="contains(system-property('xsl:vendor'), 'Apache Software Foundation')">
-          <!--Xalan quirk--><xsl:value-of select="count(exsl:node-set($verso.content)/*)"/></xsl:when>
-        <xsl:otherwise>1</xsl:otherwise>
-      </xsl:choose>
-    </xsl:variable>
-    <xsl:if test="(normalize-space($verso.content) != '') or ($verso.elements.count &gt; 0)">
-      <div><xsl:copy-of select="$verso.content"/></div>
-    </xsl:if>
-    <xsl:call-template name="chapter.titlepage.separator"/>
-  </div>
-</xsl:template>
-
-<xsl:template match="*" mode="chapter.titlepage.recto.mode">
-  <!-- if an element isn't found in this mode, -->
-  <!-- try the generic titlepage.mode -->
-  <xsl:apply-templates select="." mode="titlepage.mode"/>
-</xsl:template>
-
-<xsl:template match="*" mode="chapter.titlepage.verso.mode">
-  <!-- if an element isn't found in this mode, -->
-  <!-- try the generic titlepage.mode -->
-  <xsl:apply-templates select="." mode="titlepage.mode"/>
-</xsl:template>
-
-<xsl:template match="title" mode="chapter.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="chapter.titlepage.recto.style">
-<xsl:apply-templates select="." mode="chapter.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="subtitle" mode="chapter.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="chapter.titlepage.recto.style">
-<xsl:apply-templates select="." mode="chapter.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="corpauthor" mode="chapter.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="chapter.titlepage.recto.style">
-<xsl:apply-templates select="." mode="chapter.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="authorgroup" mode="chapter.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="chapter.titlepage.recto.style">
-<xsl:apply-templates select="." mode="chapter.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="author" mode="chapter.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="chapter.titlepage.recto.style">
-<xsl:apply-templates select="." mode="chapter.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="othercredit" mode="chapter.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="chapter.titlepage.recto.style">
-<xsl:apply-templates select="." mode="chapter.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="releaseinfo" mode="chapter.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="chapter.titlepage.recto.style">
-<xsl:apply-templates select="." mode="chapter.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="copyright" mode="chapter.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="chapter.titlepage.recto.style">
-<xsl:apply-templates select="." mode="chapter.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="legalnotice" mode="chapter.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="chapter.titlepage.recto.style">
-<xsl:apply-templates select="." mode="chapter.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="pubdate" mode="chapter.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="chapter.titlepage.recto.style">
-<xsl:apply-templates select="." mode="chapter.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="revision" mode="chapter.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="chapter.titlepage.recto.style">
-<xsl:apply-templates select="." mode="chapter.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="revhistory" mode="chapter.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="chapter.titlepage.recto.style">
-<xsl:apply-templates select="." mode="chapter.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="abstract" mode="chapter.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="chapter.titlepage.recto.style">
-<xsl:apply-templates select="." mode="chapter.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template name="appendix.titlepage.recto">
-  <xsl:choose>
-    <xsl:when test="appendixinfo/title">
-      <xsl:apply-templates mode="appendix.titlepage.recto.auto.mode" select="appendixinfo/title"/>
-    </xsl:when>
-    <xsl:when test="docinfo/title">
-      <xsl:apply-templates mode="appendix.titlepage.recto.auto.mode" select="docinfo/title"/>
-    </xsl:when>
-    <xsl:when test="info/title">
-      <xsl:apply-templates mode="appendix.titlepage.recto.auto.mode" select="info/title"/>
-    </xsl:when>
-    <xsl:when test="title">
-      <xsl:apply-templates mode="appendix.titlepage.recto.auto.mode" select="title"/>
-    </xsl:when>
-  </xsl:choose>
-
-  <xsl:choose>
-    <xsl:when test="appendixinfo/subtitle">
-      <xsl:apply-templates mode="appendix.titlepage.recto.auto.mode" select="appendixinfo/subtitle"/>
-    </xsl:when>
-    <xsl:when test="docinfo/subtitle">
-      <xsl:apply-templates mode="appendix.titlepage.recto.auto.mode" select="docinfo/subtitle"/>
-    </xsl:when>
-    <xsl:when test="info/subtitle">
-      <xsl:apply-templates mode="appendix.titlepage.recto.auto.mode" select="info/subtitle"/>
-    </xsl:when>
-    <xsl:when test="subtitle">
-      <xsl:apply-templates mode="appendix.titlepage.recto.auto.mode" select="subtitle"/>
-    </xsl:when>
-  </xsl:choose>
-
-  <xsl:apply-templates mode="appendix.titlepage.recto.auto.mode" select="appendixinfo/corpauthor"/>
-  <xsl:apply-templates mode="appendix.titlepage.recto.auto.mode" select="docinfo/corpauthor"/>
-  <xsl:apply-templates mode="appendix.titlepage.recto.auto.mode" select="info/corpauthor"/>
-  <xsl:apply-templates mode="appendix.titlepage.recto.auto.mode" select="appendixinfo/authorgroup"/>
-  <xsl:apply-templates mode="appendix.titlepage.recto.auto.mode" select="docinfo/authorgroup"/>
-  <xsl:apply-templates mode="appendix.titlepage.recto.auto.mode" select="info/authorgroup"/>
-  <xsl:apply-templates mode="appendix.titlepage.recto.auto.mode" select="appendixinfo/author"/>
-  <xsl:apply-templates mode="appendix.titlepage.recto.auto.mode" select="docinfo/author"/>
-  <xsl:apply-templates mode="appendix.titlepage.recto.auto.mode" select="info/author"/>
-  <xsl:apply-templates mode="appendix.titlepage.recto.auto.mode" select="appendixinfo/othercredit"/>
-  <xsl:apply-templates mode="appendix.titlepage.recto.auto.mode" select="docinfo/othercredit"/>
-  <xsl:apply-templates mode="appendix.titlepage.recto.auto.mode" select="info/othercredit"/>
-  <xsl:apply-templates mode="appendix.titlepage.recto.auto.mode" select="appendixinfo/releaseinfo"/>
-  <xsl:apply-templates mode="appendix.titlepage.recto.auto.mode" select="docinfo/releaseinfo"/>
-  <xsl:apply-templates mode="appendix.titlepage.recto.auto.mode" select="info/releaseinfo"/>
-  <xsl:apply-templates mode="appendix.titlepage.recto.auto.mode" select="appendixinfo/copyright"/>
-  <xsl:apply-templates mode="appendix.titlepage.recto.auto.mode" select="docinfo/copyright"/>
-  <xsl:apply-templates mode="appendix.titlepage.recto.auto.mode" select="info/copyright"/>
-  <xsl:apply-templates mode="appendix.titlepage.recto.auto.mode" select="appendixinfo/legalnotice"/>
-  <xsl:apply-templates mode="appendix.titlepage.recto.auto.mode" select="docinfo/legalnotice"/>
-  <xsl:apply-templates mode="appendix.titlepage.recto.auto.mode" select="info/legalnotice"/>
-  <xsl:apply-templates mode="appendix.titlepage.recto.auto.mode" select="appendixinfo/pubdate"/>
-  <xsl:apply-templates mode="appendix.titlepage.recto.auto.mode" select="docinfo/pubdate"/>
-  <xsl:apply-templates mode="appendix.titlepage.recto.auto.mode" select="info/pubdate"/>
-  <xsl:apply-templates mode="appendix.titlepage.recto.auto.mode" select="appendixinfo/revision"/>
-  <xsl:apply-templates mode="appendix.titlepage.recto.auto.mode" select="docinfo/revision"/>
-  <xsl:apply-templates mode="appendix.titlepage.recto.auto.mode" select="info/revision"/>
-  <xsl:apply-templates mode="appendix.titlepage.recto.auto.mode" select="appendixinfo/revhistory"/>
-  <xsl:apply-templates mode="appendix.titlepage.recto.auto.mode" select="docinfo/revhistory"/>
-  <xsl:apply-templates mode="appendix.titlepage.recto.auto.mode" select="info/revhistory"/>
-  <xsl:apply-templates mode="appendix.titlepage.recto.auto.mode" select="appendixinfo/abstract"/>
-  <xsl:apply-templates mode="appendix.titlepage.recto.auto.mode" select="docinfo/abstract"/>
-  <xsl:apply-templates mode="appendix.titlepage.recto.auto.mode" select="info/abstract"/>
-</xsl:template>
-
-<xsl:template name="appendix.titlepage.verso">
-</xsl:template>
-
-<xsl:template name="appendix.titlepage.separator">
-</xsl:template>
-
-<xsl:template name="appendix.titlepage.before.recto">
-</xsl:template>
-
-<xsl:template name="appendix.titlepage.before.verso">
-</xsl:template>
-
-<xsl:template name="appendix.titlepage">
-  <div xmlns="http://www.w3.org/1999/xhtml" class="titlepage">
-    <xsl:variable name="recto.content">
-      <xsl:call-template name="appendix.titlepage.before.recto"/>
-      <xsl:call-template name="appendix.titlepage.recto"/>
-    </xsl:variable>
-    <xsl:variable name="recto.elements.count">
-      <xsl:choose>
-        <xsl:when test="function-available('exsl:node-set')"><xsl:value-of select="count(exsl:node-set($recto.content)/*)"/></xsl:when>
-        <xsl:when test="contains(system-property('xsl:vendor'), 'Apache Software Foundation')">
-          <!--Xalan quirk--><xsl:value-of select="count(exsl:node-set($recto.content)/*)"/></xsl:when>
-        <xsl:otherwise>1</xsl:otherwise>
-      </xsl:choose>
-    </xsl:variable>
-    <xsl:if test="(normalize-space($recto.content) != '') or ($recto.elements.count &gt; 0)">
-      <div><xsl:copy-of select="$recto.content"/></div>
-    </xsl:if>
-    <xsl:variable name="verso.content">
-      <xsl:call-template name="appendix.titlepage.before.verso"/>
-      <xsl:call-template name="appendix.titlepage.verso"/>
-    </xsl:variable>
-    <xsl:variable name="verso.elements.count">
-      <xsl:choose>
-        <xsl:when test="function-available('exsl:node-set')"><xsl:value-of select="count(exsl:node-set($verso.content)/*)"/></xsl:when>
-        <xsl:when test="contains(system-property('xsl:vendor'), 'Apache Software Foundation')">
-          <!--Xalan quirk--><xsl:value-of select="count(exsl:node-set($verso.content)/*)"/></xsl:when>
-        <xsl:otherwise>1</xsl:otherwise>
-      </xsl:choose>
-    </xsl:variable>
-    <xsl:if test="(normalize-space($verso.content) != '') or ($verso.elements.count &gt; 0)">
-      <div><xsl:copy-of select="$verso.content"/></div>
-    </xsl:if>
-    <xsl:call-template name="appendix.titlepage.separator"/>
-  </div>
-</xsl:template>
-
-<xsl:template match="*" mode="appendix.titlepage.recto.mode">
-  <!-- if an element isn't found in this mode, -->
-  <!-- try the generic titlepage.mode -->
-  <xsl:apply-templates select="." mode="titlepage.mode"/>
-</xsl:template>
-
-<xsl:template match="*" mode="appendix.titlepage.verso.mode">
-  <!-- if an element isn't found in this mode, -->
-  <!-- try the generic titlepage.mode -->
-  <xsl:apply-templates select="." mode="titlepage.mode"/>
-</xsl:template>
-
-<xsl:template match="title" mode="appendix.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="appendix.titlepage.recto.style">
-<xsl:apply-templates select="." mode="appendix.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="subtitle" mode="appendix.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="appendix.titlepage.recto.style">
-<xsl:apply-templates select="." mode="appendix.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="corpauthor" mode="appendix.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="appendix.titlepage.recto.style">
-<xsl:apply-templates select="." mode="appendix.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="authorgroup" mode="appendix.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="appendix.titlepage.recto.style">
-<xsl:apply-templates select="." mode="appendix.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="author" mode="appendix.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="appendix.titlepage.recto.style">
-<xsl:apply-templates select="." mode="appendix.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="othercredit" mode="appendix.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="appendix.titlepage.recto.style">
-<xsl:apply-templates select="." mode="appendix.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="releaseinfo" mode="appendix.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="appendix.titlepage.recto.style">
-<xsl:apply-templates select="." mode="appendix.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="copyright" mode="appendix.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="appendix.titlepage.recto.style">
-<xsl:apply-templates select="." mode="appendix.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="legalnotice" mode="appendix.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="appendix.titlepage.recto.style">
-<xsl:apply-templates select="." mode="appendix.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="pubdate" mode="appendix.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="appendix.titlepage.recto.style">
-<xsl:apply-templates select="." mode="appendix.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="revision" mode="appendix.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="appendix.titlepage.recto.style">
-<xsl:apply-templates select="." mode="appendix.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="revhistory" mode="appendix.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="appendix.titlepage.recto.style">
-<xsl:apply-templates select="." mode="appendix.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="abstract" mode="appendix.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="appendix.titlepage.recto.style">
-<xsl:apply-templates select="." mode="appendix.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template name="section.titlepage.recto">
-  <xsl:choose>
-    <xsl:when test="sectioninfo/title">
-      <xsl:apply-templates mode="section.titlepage.recto.auto.mode" select="sectioninfo/title"/>
-    </xsl:when>
-    <xsl:when test="info/title">
-      <xsl:apply-templates mode="section.titlepage.recto.auto.mode" select="info/title"/>
-    </xsl:when>
-    <xsl:when test="title">
-      <xsl:apply-templates mode="section.titlepage.recto.auto.mode" select="title"/>
-    </xsl:when>
-  </xsl:choose>
-
-  <xsl:choose>
-    <xsl:when test="sectioninfo/subtitle">
-      <xsl:apply-templates mode="section.titlepage.recto.auto.mode" select="sectioninfo/subtitle"/>
-    </xsl:when>
-    <xsl:when test="info/subtitle">
-      <xsl:apply-templates mode="section.titlepage.recto.auto.mode" select="info/subtitle"/>
-    </xsl:when>
-    <xsl:when test="subtitle">
-      <xsl:apply-templates mode="section.titlepage.recto.auto.mode" select="subtitle"/>
-    </xsl:when>
-  </xsl:choose>
-
-  <xsl:apply-templates mode="section.titlepage.recto.auto.mode" select="sectioninfo/corpauthor"/>
-  <xsl:apply-templates mode="section.titlepage.recto.auto.mode" select="info/corpauthor"/>
-  <xsl:apply-templates mode="section.titlepage.recto.auto.mode" select="sectioninfo/authorgroup"/>
-  <xsl:apply-templates mode="section.titlepage.recto.auto.mode" select="info/authorgroup"/>
-  <xsl:apply-templates mode="section.titlepage.recto.auto.mode" select="sectioninfo/author"/>
-  <xsl:apply-templates mode="section.titlepage.recto.auto.mode" select="info/author"/>
-  <xsl:apply-templates mode="section.titlepage.recto.auto.mode" select="sectioninfo/othercredit"/>
-  <xsl:apply-templates mode="section.titlepage.recto.auto.mode" select="info/othercredit"/>
-  <xsl:apply-templates mode="section.titlepage.recto.auto.mode" select="sectioninfo/releaseinfo"/>
-  <xsl:apply-templates mode="section.titlepage.recto.auto.mode" select="info/releaseinfo"/>
-  <xsl:apply-templates mode="section.titlepage.recto.auto.mode" select="sectioninfo/copyright"/>
-  <xsl:apply-templates mode="section.titlepage.recto.auto.mode" select="info/copyright"/>
-  <xsl:apply-templates mode="section.titlepage.recto.auto.mode" select="sectioninfo/legalnotice"/>
-  <xsl:apply-templates mode="section.titlepage.recto.auto.mode" select="info/legalnotice"/>
-  <xsl:apply-templates mode="section.titlepage.recto.auto.mode" select="sectioninfo/pubdate"/>
-  <xsl:apply-templates mode="section.titlepage.recto.auto.mode" select="info/pubdate"/>
-  <xsl:apply-templates mode="section.titlepage.recto.auto.mode" select="sectioninfo/revision"/>
-  <xsl:apply-templates mode="section.titlepage.recto.auto.mode" select="info/revision"/>
-  <xsl:apply-templates mode="section.titlepage.recto.auto.mode" select="sectioninfo/revhistory"/>
-  <xsl:apply-templates mode="section.titlepage.recto.auto.mode" select="info/revhistory"/>
-  <xsl:apply-templates mode="section.titlepage.recto.auto.mode" select="sectioninfo/abstract"/>
-  <xsl:apply-templates mode="section.titlepage.recto.auto.mode" select="info/abstract"/>
-</xsl:template>
-
-<xsl:template name="section.titlepage.verso">
-</xsl:template>
-
-<xsl:template name="section.titlepage.separator"><xsl:if test="count(parent::*)='0'"><hr xmlns="http://www.w3.org/1999/xhtml"/></xsl:if>
-</xsl:template>
-
-<xsl:template name="section.titlepage.before.recto">
-</xsl:template>
-
-<xsl:template name="section.titlepage.before.verso">
-</xsl:template>
-
-<xsl:template name="section.titlepage">
-  <div xmlns="http://www.w3.org/1999/xhtml" class="titlepage">
-    <xsl:variable name="recto.content">
-      <xsl:call-template name="section.titlepage.before.recto"/>
-      <xsl:call-template name="section.titlepage.recto"/>
-    </xsl:variable>
-    <xsl:variable name="recto.elements.count">
-      <xsl:choose>
-        <xsl:when test="function-available('exsl:node-set')"><xsl:value-of select="count(exsl:node-set($recto.content)/*)"/></xsl:when>
-        <xsl:when test="contains(system-property('xsl:vendor'), 'Apache Software Foundation')">
-          <!--Xalan quirk--><xsl:value-of select="count(exsl:node-set($recto.content)/*)"/></xsl:when>
-        <xsl:otherwise>1</xsl:otherwise>
-      </xsl:choose>
-    </xsl:variable>
-    <xsl:if test="(normalize-space($recto.content) != '') or ($recto.elements.count &gt; 0)">
-      <div><xsl:copy-of select="$recto.content"/></div>
-    </xsl:if>
-    <xsl:variable name="verso.content">
-      <xsl:call-template name="section.titlepage.before.verso"/>
-      <xsl:call-template name="section.titlepage.verso"/>
-    </xsl:variable>
-    <xsl:variable name="verso.elements.count">
-      <xsl:choose>
-        <xsl:when test="function-available('exsl:node-set')"><xsl:value-of select="count(exsl:node-set($verso.content)/*)"/></xsl:when>
-        <xsl:when test="contains(system-property('xsl:vendor'), 'Apache Software Foundation')">
-          <!--Xalan quirk--><xsl:value-of select="count(exsl:node-set($verso.content)/*)"/></xsl:when>
-        <xsl:otherwise>1</xsl:otherwise>
-      </xsl:choose>
-    </xsl:variable>
-    <xsl:if test="(normalize-space($verso.content) != '') or ($verso.elements.count &gt; 0)">
-      <div><xsl:copy-of select="$verso.content"/></div>
-    </xsl:if>
-    <xsl:call-template name="section.titlepage.separator"/>
-  </div>
-</xsl:template>
-
-<xsl:template match="*" mode="section.titlepage.recto.mode">
-  <!-- if an element isn't found in this mode, -->
-  <!-- try the generic titlepage.mode -->
-  <xsl:apply-templates select="." mode="titlepage.mode"/>
-</xsl:template>
-
-<xsl:template match="*" mode="section.titlepage.verso.mode">
-  <!-- if an element isn't found in this mode, -->
-  <!-- try the generic titlepage.mode -->
-  <xsl:apply-templates select="." mode="titlepage.mode"/>
-</xsl:template>
-
-<xsl:template match="title" mode="section.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="section.titlepage.recto.style">
-<xsl:apply-templates select="." mode="section.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="subtitle" mode="section.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="section.titlepage.recto.style">
-<xsl:apply-templates select="." mode="section.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="corpauthor" mode="section.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="section.titlepage.recto.style">
-<xsl:apply-templates select="." mode="section.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="authorgroup" mode="section.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="section.titlepage.recto.style">
-<xsl:apply-templates select="." mode="section.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="author" mode="section.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="section.titlepage.recto.style">
-<xsl:apply-templates select="." mode="section.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="othercredit" mode="section.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="section.titlepage.recto.style">
-<xsl:apply-templates select="." mode="section.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="releaseinfo" mode="section.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="section.titlepage.recto.style">
-<xsl:apply-templates select="." mode="section.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="copyright" mode="section.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="section.titlepage.recto.style">
-<xsl:apply-templates select="." mode="section.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="legalnotice" mode="section.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="section.titlepage.recto.style">
-<xsl:apply-templates select="." mode="section.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="pubdate" mode="section.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="section.titlepage.recto.style">
-<xsl:apply-templates select="." mode="section.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="revision" mode="section.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="section.titlepage.recto.style">
-<xsl:apply-templates select="." mode="section.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="revhistory" mode="section.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="section.titlepage.recto.style">
-<xsl:apply-templates select="." mode="section.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="abstract" mode="section.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="section.titlepage.recto.style">
-<xsl:apply-templates select="." mode="section.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template name="sect1.titlepage.recto">
-  <xsl:choose>
-    <xsl:when test="sect1info/title">
-      <xsl:apply-templates mode="sect1.titlepage.recto.auto.mode" select="sect1info/title"/>
-    </xsl:when>
-    <xsl:when test="info/title">
-      <xsl:apply-templates mode="sect1.titlepage.recto.auto.mode" select="info/title"/>
-    </xsl:when>
-    <xsl:when test="title">
-      <xsl:apply-templates mode="sect1.titlepage.recto.auto.mode" select="title"/>
-    </xsl:when>
-  </xsl:choose>
-
-  <xsl:choose>
-    <xsl:when test="sect1info/subtitle">
-      <xsl:apply-templates mode="sect1.titlepage.recto.auto.mode" select="sect1info/subtitle"/>
-    </xsl:when>
-    <xsl:when test="info/subtitle">
-      <xsl:apply-templates mode="sect1.titlepage.recto.auto.mode" select="info/subtitle"/>
-    </xsl:when>
-    <xsl:when test="subtitle">
-      <xsl:apply-templates mode="sect1.titlepage.recto.auto.mode" select="subtitle"/>
-    </xsl:when>
-  </xsl:choose>
-
-  <xsl:apply-templates mode="sect1.titlepage.recto.auto.mode" select="sect1info/corpauthor"/>
-  <xsl:apply-templates mode="sect1.titlepage.recto.auto.mode" select="info/corpauthor"/>
-  <xsl:apply-templates mode="sect1.titlepage.recto.auto.mode" select="sect1info/authorgroup"/>
-  <xsl:apply-templates mode="sect1.titlepage.recto.auto.mode" select="info/authorgroup"/>
-  <xsl:apply-templates mode="sect1.titlepage.recto.auto.mode" select="sect1info/author"/>
-  <xsl:apply-templates mode="sect1.titlepage.recto.auto.mode" select="info/author"/>
-  <xsl:apply-templates mode="sect1.titlepage.recto.auto.mode" select="sect1info/othercredit"/>
-  <xsl:apply-templates mode="sect1.titlepage.recto.auto.mode" select="info/othercredit"/>
-  <xsl:apply-templates mode="sect1.titlepage.recto.auto.mode" select="sect1info/releaseinfo"/>
-  <xsl:apply-templates mode="sect1.titlepage.recto.auto.mode" select="info/releaseinfo"/>
-  <xsl:apply-templates mode="sect1.titlepage.recto.auto.mode" select="sect1info/copyright"/>
-  <xsl:apply-templates mode="sect1.titlepage.recto.auto.mode" select="info/copyright"/>
-  <xsl:apply-templates mode="sect1.titlepage.recto.auto.mode" select="sect1info/legalnotice"/>
-  <xsl:apply-templates mode="sect1.titlepage.recto.auto.mode" select="info/legalnotice"/>
-  <xsl:apply-templates mode="sect1.titlepage.recto.auto.mode" select="sect1info/pubdate"/>
-  <xsl:apply-templates mode="sect1.titlepage.recto.auto.mode" select="info/pubdate"/>
-  <xsl:apply-templates mode="sect1.titlepage.recto.auto.mode" select="sect1info/revision"/>
-  <xsl:apply-templates mode="sect1.titlepage.recto.auto.mode" select="info/revision"/>
-  <xsl:apply-templates mode="sect1.titlepage.recto.auto.mode" select="sect1info/revhistory"/>
-  <xsl:apply-templates mode="sect1.titlepage.recto.auto.mode" select="info/revhistory"/>
-  <xsl:apply-templates mode="sect1.titlepage.recto.auto.mode" select="sect1info/abstract"/>
-  <xsl:apply-templates mode="sect1.titlepage.recto.auto.mode" select="info/abstract"/>
-</xsl:template>
-
-<xsl:template name="sect1.titlepage.verso">
-</xsl:template>
-
-<xsl:template name="sect1.titlepage.separator"><xsl:if test="count(parent::*)='0'"><hr xmlns="http://www.w3.org/1999/xhtml"/></xsl:if>
-</xsl:template>
-
-<xsl:template name="sect1.titlepage.before.recto">
-</xsl:template>
-
-<xsl:template name="sect1.titlepage.before.verso">
-</xsl:template>
-
-<xsl:template name="sect1.titlepage">
-  <div xmlns="http://www.w3.org/1999/xhtml" class="titlepage">
-    <xsl:variable name="recto.content">
-      <xsl:call-template name="sect1.titlepage.before.recto"/>
-      <xsl:call-template name="sect1.titlepage.recto"/>
-    </xsl:variable>
-    <xsl:variable name="recto.elements.count">
-      <xsl:choose>
-        <xsl:when test="function-available('exsl:node-set')"><xsl:value-of select="count(exsl:node-set($recto.content)/*)"/></xsl:when>
-        <xsl:when test="contains(system-property('xsl:vendor'), 'Apache Software Foundation')">
-          <!--Xalan quirk--><xsl:value-of select="count(exsl:node-set($recto.content)/*)"/></xsl:when>
-        <xsl:otherwise>1</xsl:otherwise>
-      </xsl:choose>
-    </xsl:variable>
-    <xsl:if test="(normalize-space($recto.content) != '') or ($recto.elements.count &gt; 0)">
-      <div><xsl:copy-of select="$recto.content"/></div>
-    </xsl:if>
-    <xsl:variable name="verso.content">
-      <xsl:call-template name="sect1.titlepage.before.verso"/>
-      <xsl:call-template name="sect1.titlepage.verso"/>
-    </xsl:variable>
-    <xsl:variable name="verso.elements.count">
-      <xsl:choose>
-        <xsl:when test="function-available('exsl:node-set')"><xsl:value-of select="count(exsl:node-set($verso.content)/*)"/></xsl:when>
-        <xsl:when test="contains(system-property('xsl:vendor'), 'Apache Software Foundation')">
-          <!--Xalan quirk--><xsl:value-of select="count(exsl:node-set($verso.content)/*)"/></xsl:when>
-        <xsl:otherwise>1</xsl:otherwise>
-      </xsl:choose>
-    </xsl:variable>
-    <xsl:if test="(normalize-space($verso.content) != '') or ($verso.elements.count &gt; 0)">
-      <div><xsl:copy-of select="$verso.content"/></div>
-    </xsl:if>
-    <xsl:call-template name="sect1.titlepage.separator"/>
-  </div>
-</xsl:template>
-
-<xsl:template match="*" mode="sect1.titlepage.recto.mode">
-  <!-- if an element isn't found in this mode, -->
-  <!-- try the generic titlepage.mode -->
-  <xsl:apply-templates select="." mode="titlepage.mode"/>
-</xsl:template>
-
-<xsl:template match="*" mode="sect1.titlepage.verso.mode">
-  <!-- if an element isn't found in this mode, -->
-  <!-- try the generic titlepage.mode -->
-  <xsl:apply-templates select="." mode="titlepage.mode"/>
-</xsl:template>
-
-<xsl:template match="title" mode="sect1.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="sect1.titlepage.recto.style">
-<xsl:apply-templates select="." mode="sect1.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="subtitle" mode="sect1.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="sect1.titlepage.recto.style">
-<xsl:apply-templates select="." mode="sect1.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="corpauthor" mode="sect1.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="sect1.titlepage.recto.style">
-<xsl:apply-templates select="." mode="sect1.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="authorgroup" mode="sect1.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="sect1.titlepage.recto.style">
-<xsl:apply-templates select="." mode="sect1.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="author" mode="sect1.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="sect1.titlepage.recto.style">
-<xsl:apply-templates select="." mode="sect1.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="othercredit" mode="sect1.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="sect1.titlepage.recto.style">
-<xsl:apply-templates select="." mode="sect1.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="releaseinfo" mode="sect1.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="sect1.titlepage.recto.style">
-<xsl:apply-templates select="." mode="sect1.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="copyright" mode="sect1.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="sect1.titlepage.recto.style">
-<xsl:apply-templates select="." mode="sect1.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="legalnotice" mode="sect1.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="sect1.titlepage.recto.style">
-<xsl:apply-templates select="." mode="sect1.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="pubdate" mode="sect1.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="sect1.titlepage.recto.style">
-<xsl:apply-templates select="." mode="sect1.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="revision" mode="sect1.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="sect1.titlepage.recto.style">
-<xsl:apply-templates select="." mode="sect1.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="revhistory" mode="sect1.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="sect1.titlepage.recto.style">
-<xsl:apply-templates select="." mode="sect1.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="abstract" mode="sect1.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="sect1.titlepage.recto.style">
-<xsl:apply-templates select="." mode="sect1.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template name="sect2.titlepage.recto">
-  <xsl:choose>
-    <xsl:when test="sect2info/title">
-      <xsl:apply-templates mode="sect2.titlepage.recto.auto.mode" select="sect2info/title"/>
-    </xsl:when>
-    <xsl:when test="info/title">
-      <xsl:apply-templates mode="sect2.titlepage.recto.auto.mode" select="info/title"/>
-    </xsl:when>
-    <xsl:when test="title">
-      <xsl:apply-templates mode="sect2.titlepage.recto.auto.mode" select="title"/>
-    </xsl:when>
-  </xsl:choose>
-
-  <xsl:choose>
-    <xsl:when test="sect2info/subtitle">
-      <xsl:apply-templates mode="sect2.titlepage.recto.auto.mode" select="sect2info/subtitle"/>
-    </xsl:when>
-    <xsl:when test="info/subtitle">
-      <xsl:apply-templates mode="sect2.titlepage.recto.auto.mode" select="info/subtitle"/>
-    </xsl:when>
-    <xsl:when test="subtitle">
-      <xsl:apply-templates mode="sect2.titlepage.recto.auto.mode" select="subtitle"/>
-    </xsl:when>
-  </xsl:choose>
-
-  <xsl:apply-templates mode="sect2.titlepage.recto.auto.mode" select="sect2info/corpauthor"/>
-  <xsl:apply-templates mode="sect2.titlepage.recto.auto.mode" select="info/corpauthor"/>
-  <xsl:apply-templates mode="sect2.titlepage.recto.auto.mode" select="sect2info/authorgroup"/>
-  <xsl:apply-templates mode="sect2.titlepage.recto.auto.mode" select="info/authorgroup"/>
-  <xsl:apply-templates mode="sect2.titlepage.recto.auto.mode" select="sect2info/author"/>
-  <xsl:apply-templates mode="sect2.titlepage.recto.auto.mode" select="info/author"/>
-  <xsl:apply-templates mode="sect2.titlepage.recto.auto.mode" select="sect2info/othercredit"/>
-  <xsl:apply-templates mode="sect2.titlepage.recto.auto.mode" select="info/othercredit"/>
-  <xsl:apply-templates mode="sect2.titlepage.recto.auto.mode" select="sect2info/releaseinfo"/>
-  <xsl:apply-templates mode="sect2.titlepage.recto.auto.mode" select="info/releaseinfo"/>
-  <xsl:apply-templates mode="sect2.titlepage.recto.auto.mode" select="sect2info/copyright"/>
-  <xsl:apply-templates mode="sect2.titlepage.recto.auto.mode" select="info/copyright"/>
-  <xsl:apply-templates mode="sect2.titlepage.recto.auto.mode" select="sect2info/legalnotice"/>
-  <xsl:apply-templates mode="sect2.titlepage.recto.auto.mode" select="info/legalnotice"/>
-  <xsl:apply-templates mode="sect2.titlepage.recto.auto.mode" select="sect2info/pubdate"/>
-  <xsl:apply-templates mode="sect2.titlepage.recto.auto.mode" select="info/pubdate"/>
-  <xsl:apply-templates mode="sect2.titlepage.recto.auto.mode" select="sect2info/revision"/>
-  <xsl:apply-templates mode="sect2.titlepage.recto.auto.mode" select="info/revision"/>
-  <xsl:apply-templates mode="sect2.titlepage.recto.auto.mode" select="sect2info/revhistory"/>
-  <xsl:apply-templates mode="sect2.titlepage.recto.auto.mode" select="info/revhistory"/>
-  <xsl:apply-templates mode="sect2.titlepage.recto.auto.mode" select="sect2info/abstract"/>
-  <xsl:apply-templates mode="sect2.titlepage.recto.auto.mode" select="info/abstract"/>
-</xsl:template>
-
-<xsl:template name="sect2.titlepage.verso">
-</xsl:template>
-
-<xsl:template name="sect2.titlepage.separator"><xsl:if test="count(parent::*)='0'"><hr xmlns="http://www.w3.org/1999/xhtml"/></xsl:if>
-</xsl:template>
-
-<xsl:template name="sect2.titlepage.before.recto">
-</xsl:template>
-
-<xsl:template name="sect2.titlepage.before.verso">
-</xsl:template>
-
-<xsl:template name="sect2.titlepage">
-  <div xmlns="http://www.w3.org/1999/xhtml" class="titlepage">
-    <xsl:variable name="recto.content">
-      <xsl:call-template name="sect2.titlepage.before.recto"/>
-      <xsl:call-template name="sect2.titlepage.recto"/>
-    </xsl:variable>
-    <xsl:variable name="recto.elements.count">
-      <xsl:choose>
-        <xsl:when test="function-available('exsl:node-set')"><xsl:value-of select="count(exsl:node-set($recto.content)/*)"/></xsl:when>
-        <xsl:when test="contains(system-property('xsl:vendor'), 'Apache Software Foundation')">
-          <!--Xalan quirk--><xsl:value-of select="count(exsl:node-set($recto.content)/*)"/></xsl:when>
-        <xsl:otherwise>1</xsl:otherwise>
-      </xsl:choose>
-    </xsl:variable>
-    <xsl:if test="(normalize-space($recto.content) != '') or ($recto.elements.count &gt; 0)">
-      <div><xsl:copy-of select="$recto.content"/></div>
-    </xsl:if>
-    <xsl:variable name="verso.content">
-      <xsl:call-template name="sect2.titlepage.before.verso"/>
-      <xsl:call-template name="sect2.titlepage.verso"/>
-    </xsl:variable>
-    <xsl:variable name="verso.elements.count">
-      <xsl:choose>
-        <xsl:when test="function-available('exsl:node-set')"><xsl:value-of select="count(exsl:node-set($verso.content)/*)"/></xsl:when>
-        <xsl:when test="contains(system-property('xsl:vendor'), 'Apache Software Foundation')">
-          <!--Xalan quirk--><xsl:value-of select="count(exsl:node-set($verso.content)/*)"/></xsl:when>
-        <xsl:otherwise>1</xsl:otherwise>
-      </xsl:choose>
-    </xsl:variable>
-    <xsl:if test="(normalize-space($verso.content) != '') or ($verso.elements.count &gt; 0)">
-      <div><xsl:copy-of select="$verso.content"/></div>
-    </xsl:if>
-    <xsl:call-template name="sect2.titlepage.separator"/>
-  </div>
-</xsl:template>
-
-<xsl:template match="*" mode="sect2.titlepage.recto.mode">
-  <!-- if an element isn't found in this mode, -->
-  <!-- try the generic titlepage.mode -->
-  <xsl:apply-templates select="." mode="titlepage.mode"/>
-</xsl:template>
-
-<xsl:template match="*" mode="sect2.titlepage.verso.mode">
-  <!-- if an element isn't found in this mode, -->
-  <!-- try the generic titlepage.mode -->
-  <xsl:apply-templates select="." mode="titlepage.mode"/>
-</xsl:template>
-
-<xsl:template match="title" mode="sect2.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="sect2.titlepage.recto.style">
-<xsl:apply-templates select="." mode="sect2.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="subtitle" mode="sect2.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="sect2.titlepage.recto.style">
-<xsl:apply-templates select="." mode="sect2.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="corpauthor" mode="sect2.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="sect2.titlepage.recto.style">
-<xsl:apply-templates select="." mode="sect2.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="authorgroup" mode="sect2.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="sect2.titlepage.recto.style">
-<xsl:apply-templates select="." mode="sect2.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="author" mode="sect2.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="sect2.titlepage.recto.style">
-<xsl:apply-templates select="." mode="sect2.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="othercredit" mode="sect2.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="sect2.titlepage.recto.style">
-<xsl:apply-templates select="." mode="sect2.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="releaseinfo" mode="sect2.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="sect2.titlepage.recto.style">
-<xsl:apply-templates select="." mode="sect2.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="copyright" mode="sect2.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="sect2.titlepage.recto.style">
-<xsl:apply-templates select="." mode="sect2.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="legalnotice" mode="sect2.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="sect2.titlepage.recto.style">
-<xsl:apply-templates select="." mode="sect2.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="pubdate" mode="sect2.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="sect2.titlepage.recto.style">
-<xsl:apply-templates select="." mode="sect2.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="revision" mode="sect2.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="sect2.titlepage.recto.style">
-<xsl:apply-templates select="." mode="sect2.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="revhistory" mode="sect2.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="sect2.titlepage.recto.style">
-<xsl:apply-templates select="." mode="sect2.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="abstract" mode="sect2.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="sect2.titlepage.recto.style">
-<xsl:apply-templates select="." mode="sect2.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template name="sect3.titlepage.recto">
-  <xsl:choose>
-    <xsl:when test="sect3info/title">
-      <xsl:apply-templates mode="sect3.titlepage.recto.auto.mode" select="sect3info/title"/>
-    </xsl:when>
-    <xsl:when test="info/title">
-      <xsl:apply-templates mode="sect3.titlepage.recto.auto.mode" select="info/title"/>
-    </xsl:when>
-    <xsl:when test="title">
-      <xsl:apply-templates mode="sect3.titlepage.recto.auto.mode" select="title"/>
-    </xsl:when>
-  </xsl:choose>
-
-  <xsl:choose>
-    <xsl:when test="sect3info/subtitle">
-      <xsl:apply-templates mode="sect3.titlepage.recto.auto.mode" select="sect3info/subtitle"/>
-    </xsl:when>
-    <xsl:when test="info/subtitle">
-      <xsl:apply-templates mode="sect3.titlepage.recto.auto.mode" select="info/subtitle"/>
-    </xsl:when>
-    <xsl:when test="subtitle">
-      <xsl:apply-templates mode="sect3.titlepage.recto.auto.mode" select="subtitle"/>
-    </xsl:when>
-  </xsl:choose>
-
-  <xsl:apply-templates mode="sect3.titlepage.recto.auto.mode" select="sect3info/corpauthor"/>
-  <xsl:apply-templates mode="sect3.titlepage.recto.auto.mode" select="info/corpauthor"/>
-  <xsl:apply-templates mode="sect3.titlepage.recto.auto.mode" select="sect3info/authorgroup"/>
-  <xsl:apply-templates mode="sect3.titlepage.recto.auto.mode" select="info/authorgroup"/>
-  <xsl:apply-templates mode="sect3.titlepage.recto.auto.mode" select="sect3info/author"/>
-  <xsl:apply-templates mode="sect3.titlepage.recto.auto.mode" select="info/author"/>
-  <xsl:apply-templates mode="sect3.titlepage.recto.auto.mode" select="sect3info/othercredit"/>
-  <xsl:apply-templates mode="sect3.titlepage.recto.auto.mode" select="info/othercredit"/>
-  <xsl:apply-templates mode="sect3.titlepage.recto.auto.mode" select="sect3info/releaseinfo"/>
-  <xsl:apply-templates mode="sect3.titlepage.recto.auto.mode" select="info/releaseinfo"/>
-  <xsl:apply-templates mode="sect3.titlepage.recto.auto.mode" select="sect3info/copyright"/>
-  <xsl:apply-templates mode="sect3.titlepage.recto.auto.mode" select="info/copyright"/>
-  <xsl:apply-templates mode="sect3.titlepage.recto.auto.mode" select="sect3info/legalnotice"/>
-  <xsl:apply-templates mode="sect3.titlepage.recto.auto.mode" select="info/legalnotice"/>
-  <xsl:apply-templates mode="sect3.titlepage.recto.auto.mode" select="sect3info/pubdate"/>
-  <xsl:apply-templates mode="sect3.titlepage.recto.auto.mode" select="info/pubdate"/>
-  <xsl:apply-templates mode="sect3.titlepage.recto.auto.mode" select="sect3info/revision"/>
-  <xsl:apply-templates mode="sect3.titlepage.recto.auto.mode" select="info/revision"/>
-  <xsl:apply-templates mode="sect3.titlepage.recto.auto.mode" select="sect3info/revhistory"/>
-  <xsl:apply-templates mode="sect3.titlepage.recto.auto.mode" select="info/revhistory"/>
-  <xsl:apply-templates mode="sect3.titlepage.recto.auto.mode" select="sect3info/abstract"/>
-  <xsl:apply-templates mode="sect3.titlepage.recto.auto.mode" select="info/abstract"/>
-</xsl:template>
-
-<xsl:template name="sect3.titlepage.verso">
-</xsl:template>
-
-<xsl:template name="sect3.titlepage.separator"><xsl:if test="count(parent::*)='0'"><hr xmlns="http://www.w3.org/1999/xhtml"/></xsl:if>
-</xsl:template>
-
-<xsl:template name="sect3.titlepage.before.recto">
-</xsl:template>
-
-<xsl:template name="sect3.titlepage.before.verso">
-</xsl:template>
-
-<xsl:template name="sect3.titlepage">
-  <div xmlns="http://www.w3.org/1999/xhtml" class="titlepage">
-    <xsl:variable name="recto.content">
-      <xsl:call-template name="sect3.titlepage.before.recto"/>
-      <xsl:call-template name="sect3.titlepage.recto"/>
-    </xsl:variable>
-    <xsl:variable name="recto.elements.count">
-      <xsl:choose>
-        <xsl:when test="function-available('exsl:node-set')"><xsl:value-of select="count(exsl:node-set($recto.content)/*)"/></xsl:when>
-        <xsl:when test="contains(system-property('xsl:vendor'), 'Apache Software Foundation')">
-          <!--Xalan quirk--><xsl:value-of select="count(exsl:node-set($recto.content)/*)"/></xsl:when>
-        <xsl:otherwise>1</xsl:otherwise>
-      </xsl:choose>
-    </xsl:variable>
-    <xsl:if test="(normalize-space($recto.content) != '') or ($recto.elements.count &gt; 0)">
-      <div><xsl:copy-of select="$recto.content"/></div>
-    </xsl:if>
-    <xsl:variable name="verso.content">
-      <xsl:call-template name="sect3.titlepage.before.verso"/>
-      <xsl:call-template name="sect3.titlepage.verso"/>
-    </xsl:variable>
-    <xsl:variable name="verso.elements.count">
-      <xsl:choose>
-        <xsl:when test="function-available('exsl:node-set')"><xsl:value-of select="count(exsl:node-set($verso.content)/*)"/></xsl:when>
-        <xsl:when test="contains(system-property('xsl:vendor'), 'Apache Software Foundation')">
-          <!--Xalan quirk--><xsl:value-of select="count(exsl:node-set($verso.content)/*)"/></xsl:when>
-        <xsl:otherwise>1</xsl:otherwise>
-      </xsl:choose>
-    </xsl:variable>
-    <xsl:if test="(normalize-space($verso.content) != '') or ($verso.elements.count &gt; 0)">
-      <div><xsl:copy-of select="$verso.content"/></div>
-    </xsl:if>
-    <xsl:call-template name="sect3.titlepage.separator"/>
-  </div>
-</xsl:template>
-
-<xsl:template match="*" mode="sect3.titlepage.recto.mode">
-  <!-- if an element isn't found in this mode, -->
-  <!-- try the generic titlepage.mode -->
-  <xsl:apply-templates select="." mode="titlepage.mode"/>
-</xsl:template>
-
-<xsl:template match="*" mode="sect3.titlepage.verso.mode">
-  <!-- if an element isn't found in this mode, -->
-  <!-- try the generic titlepage.mode -->
-  <xsl:apply-templates select="." mode="titlepage.mode"/>
-</xsl:template>
-
-<xsl:template match="title" mode="sect3.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="sect3.titlepage.recto.style">
-<xsl:apply-templates select="." mode="sect3.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="subtitle" mode="sect3.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="sect3.titlepage.recto.style">
-<xsl:apply-templates select="." mode="sect3.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="corpauthor" mode="sect3.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="sect3.titlepage.recto.style">
-<xsl:apply-templates select="." mode="sect3.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="authorgroup" mode="sect3.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="sect3.titlepage.recto.style">
-<xsl:apply-templates select="." mode="sect3.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="author" mode="sect3.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="sect3.titlepage.recto.style">
-<xsl:apply-templates select="." mode="sect3.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="othercredit" mode="sect3.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="sect3.titlepage.recto.style">
-<xsl:apply-templates select="." mode="sect3.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="releaseinfo" mode="sect3.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="sect3.titlepage.recto.style">
-<xsl:apply-templates select="." mode="sect3.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="copyright" mode="sect3.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="sect3.titlepage.recto.style">
-<xsl:apply-templates select="." mode="sect3.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="legalnotice" mode="sect3.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="sect3.titlepage.recto.style">
-<xsl:apply-templates select="." mode="sect3.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="pubdate" mode="sect3.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="sect3.titlepage.recto.style">
-<xsl:apply-templates select="." mode="sect3.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="revision" mode="sect3.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="sect3.titlepage.recto.style">
-<xsl:apply-templates select="." mode="sect3.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="revhistory" mode="sect3.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="sect3.titlepage.recto.style">
-<xsl:apply-templates select="." mode="sect3.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="abstract" mode="sect3.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="sect3.titlepage.recto.style">
-<xsl:apply-templates select="." mode="sect3.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template name="sect4.titlepage.recto">
-  <xsl:choose>
-    <xsl:when test="sect4info/title">
-      <xsl:apply-templates mode="sect4.titlepage.recto.auto.mode" select="sect4info/title"/>
-    </xsl:when>
-    <xsl:when test="info/title">
-      <xsl:apply-templates mode="sect4.titlepage.recto.auto.mode" select="info/title"/>
-    </xsl:when>
-    <xsl:when test="title">
-      <xsl:apply-templates mode="sect4.titlepage.recto.auto.mode" select="title"/>
-    </xsl:when>
-  </xsl:choose>
-
-  <xsl:choose>
-    <xsl:when test="sect4info/subtitle">
-      <xsl:apply-templates mode="sect4.titlepage.recto.auto.mode" select="sect4info/subtitle"/>
-    </xsl:when>
-    <xsl:when test="info/subtitle">
-      <xsl:apply-templates mode="sect4.titlepage.recto.auto.mode" select="info/subtitle"/>
-    </xsl:when>
-    <xsl:when test="subtitle">
-      <xsl:apply-templates mode="sect4.titlepage.recto.auto.mode" select="subtitle"/>
-    </xsl:when>
-  </xsl:choose>
-
-  <xsl:apply-templates mode="sect4.titlepage.recto.auto.mode" select="sect4info/corpauthor"/>
-  <xsl:apply-templates mode="sect4.titlepage.recto.auto.mode" select="info/corpauthor"/>
-  <xsl:apply-templates mode="sect4.titlepage.recto.auto.mode" select="sect4info/authorgroup"/>
-  <xsl:apply-templates mode="sect4.titlepage.recto.auto.mode" select="info/authorgroup"/>
-  <xsl:apply-templates mode="sect4.titlepage.recto.auto.mode" select="sect4info/author"/>
-  <xsl:apply-templates mode="sect4.titlepage.recto.auto.mode" select="info/author"/>
-  <xsl:apply-templates mode="sect4.titlepage.recto.auto.mode" select="sect4info/othercredit"/>
-  <xsl:apply-templates mode="sect4.titlepage.recto.auto.mode" select="info/othercredit"/>
-  <xsl:apply-templates mode="sect4.titlepage.recto.auto.mode" select="sect4info/releaseinfo"/>
-  <xsl:apply-templates mode="sect4.titlepage.recto.auto.mode" select="info/releaseinfo"/>
-  <xsl:apply-templates mode="sect4.titlepage.recto.auto.mode" select="sect4info/copyright"/>
-  <xsl:apply-templates mode="sect4.titlepage.recto.auto.mode" select="info/copyright"/>
-  <xsl:apply-templates mode="sect4.titlepage.recto.auto.mode" select="sect4info/legalnotice"/>
-  <xsl:apply-templates mode="sect4.titlepage.recto.auto.mode" select="info/legalnotice"/>
-  <xsl:apply-templates mode="sect4.titlepage.recto.auto.mode" select="sect4info/pubdate"/>
-  <xsl:apply-templates mode="sect4.titlepage.recto.auto.mode" select="info/pubdate"/>
-  <xsl:apply-templates mode="sect4.titlepage.recto.auto.mode" select="sect4info/revision"/>
-  <xsl:apply-templates mode="sect4.titlepage.recto.auto.mode" select="info/revision"/>
-  <xsl:apply-templates mode="sect4.titlepage.recto.auto.mode" select="sect4info/revhistory"/>
-  <xsl:apply-templates mode="sect4.titlepage.recto.auto.mode" select="info/revhistory"/>
-  <xsl:apply-templates mode="sect4.titlepage.recto.auto.mode" select="sect4info/abstract"/>
-  <xsl:apply-templates mode="sect4.titlepage.recto.auto.mode" select="info/abstract"/>
-</xsl:template>
-
-<xsl:template name="sect4.titlepage.verso">
-</xsl:template>
-
-<xsl:template name="sect4.titlepage.separator"><xsl:if test="count(parent::*)='0'"><hr xmlns="http://www.w3.org/1999/xhtml"/></xsl:if>
-</xsl:template>
-
-<xsl:template name="sect4.titlepage.before.recto">
-</xsl:template>
-
-<xsl:template name="sect4.titlepage.before.verso">
-</xsl:template>
-
-<xsl:template name="sect4.titlepage">
-  <div xmlns="http://www.w3.org/1999/xhtml" class="titlepage">
-    <xsl:variable name="recto.content">
-      <xsl:call-template name="sect4.titlepage.before.recto"/>
-      <xsl:call-template name="sect4.titlepage.recto"/>
-    </xsl:variable>
-    <xsl:variable name="recto.elements.count">
-      <xsl:choose>
-        <xsl:when test="function-available('exsl:node-set')"><xsl:value-of select="count(exsl:node-set($recto.content)/*)"/></xsl:when>
-        <xsl:when test="contains(system-property('xsl:vendor'), 'Apache Software Foundation')">
-          <!--Xalan quirk--><xsl:value-of select="count(exsl:node-set($recto.content)/*)"/></xsl:when>
-        <xsl:otherwise>1</xsl:otherwise>
-      </xsl:choose>
-    </xsl:variable>
-    <xsl:if test="(normalize-space($recto.content) != '') or ($recto.elements.count &gt; 0)">
-      <div><xsl:copy-of select="$recto.content"/></div>
-    </xsl:if>
-    <xsl:variable name="verso.content">
-      <xsl:call-template name="sect4.titlepage.before.verso"/>
-      <xsl:call-template name="sect4.titlepage.verso"/>
-    </xsl:variable>
-    <xsl:variable name="verso.elements.count">
-      <xsl:choose>
-        <xsl:when test="function-available('exsl:node-set')"><xsl:value-of select="count(exsl:node-set($verso.content)/*)"/></xsl:when>
-        <xsl:when test="contains(system-property('xsl:vendor'), 'Apache Software Foundation')">
-          <!--Xalan quirk--><xsl:value-of select="count(exsl:node-set($verso.content)/*)"/></xsl:when>
-        <xsl:otherwise>1</xsl:otherwise>
-      </xsl:choose>
-    </xsl:variable>
-    <xsl:if test="(normalize-space($verso.content) != '') or ($verso.elements.count &gt; 0)">
-      <div><xsl:copy-of select="$verso.content"/></div>
-    </xsl:if>
-    <xsl:call-template name="sect4.titlepage.separator"/>
-  </div>
-</xsl:template>
-
-<xsl:template match="*" mode="sect4.titlepage.recto.mode">
-  <!-- if an element isn't found in this mode, -->
-  <!-- try the generic titlepage.mode -->
-  <xsl:apply-templates select="." mode="titlepage.mode"/>
-</xsl:template>
-
-<xsl:template match="*" mode="sect4.titlepage.verso.mode">
-  <!-- if an element isn't found in this mode, -->
-  <!-- try the generic titlepage.mode -->
-  <xsl:apply-templates select="." mode="titlepage.mode"/>
-</xsl:template>
-
-<xsl:template match="title" mode="sect4.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="sect4.titlepage.recto.style">
-<xsl:apply-templates select="." mode="sect4.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="subtitle" mode="sect4.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="sect4.titlepage.recto.style">
-<xsl:apply-templates select="." mode="sect4.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="corpauthor" mode="sect4.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="sect4.titlepage.recto.style">
-<xsl:apply-templates select="." mode="sect4.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="authorgroup" mode="sect4.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="sect4.titlepage.recto.style">
-<xsl:apply-templates select="." mode="sect4.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="author" mode="sect4.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="sect4.titlepage.recto.style">
-<xsl:apply-templates select="." mode="sect4.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="othercredit" mode="sect4.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="sect4.titlepage.recto.style">
-<xsl:apply-templates select="." mode="sect4.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="releaseinfo" mode="sect4.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="sect4.titlepage.recto.style">
-<xsl:apply-templates select="." mode="sect4.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="copyright" mode="sect4.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="sect4.titlepage.recto.style">
-<xsl:apply-templates select="." mode="sect4.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="legalnotice" mode="sect4.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="sect4.titlepage.recto.style">
-<xsl:apply-templates select="." mode="sect4.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="pubdate" mode="sect4.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="sect4.titlepage.recto.style">
-<xsl:apply-templates select="." mode="sect4.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="revision" mode="sect4.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="sect4.titlepage.recto.style">
-<xsl:apply-templates select="." mode="sect4.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="revhistory" mode="sect4.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="sect4.titlepage.recto.style">
-<xsl:apply-templates select="." mode="sect4.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="abstract" mode="sect4.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="sect4.titlepage.recto.style">
-<xsl:apply-templates select="." mode="sect4.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template name="sect5.titlepage.recto">
-  <xsl:choose>
-    <xsl:when test="sect5info/title">
-      <xsl:apply-templates mode="sect5.titlepage.recto.auto.mode" select="sect5info/title"/>
-    </xsl:when>
-    <xsl:when test="info/title">
-      <xsl:apply-templates mode="sect5.titlepage.recto.auto.mode" select="info/title"/>
-    </xsl:when>
-    <xsl:when test="title">
-      <xsl:apply-templates mode="sect5.titlepage.recto.auto.mode" select="title"/>
-    </xsl:when>
-  </xsl:choose>
-
-  <xsl:choose>
-    <xsl:when test="sect5info/subtitle">
-      <xsl:apply-templates mode="sect5.titlepage.recto.auto.mode" select="sect5info/subtitle"/>
-    </xsl:when>
-    <xsl:when test="info/subtitle">
-      <xsl:apply-templates mode="sect5.titlepage.recto.auto.mode" select="info/subtitle"/>
-    </xsl:when>
-    <xsl:when test="subtitle">
-      <xsl:apply-templates mode="sect5.titlepage.recto.auto.mode" select="subtitle"/>
-    </xsl:when>
-  </xsl:choose>
-
-  <xsl:apply-templates mode="sect5.titlepage.recto.auto.mode" select="sect5info/corpauthor"/>
-  <xsl:apply-templates mode="sect5.titlepage.recto.auto.mode" select="info/corpauthor"/>
-  <xsl:apply-templates mode="sect5.titlepage.recto.auto.mode" select="sect5info/authorgroup"/>
-  <xsl:apply-templates mode="sect5.titlepage.recto.auto.mode" select="info/authorgroup"/>
-  <xsl:apply-templates mode="sect5.titlepage.recto.auto.mode" select="sect5info/author"/>
-  <xsl:apply-templates mode="sect5.titlepage.recto.auto.mode" select="info/author"/>
-  <xsl:apply-templates mode="sect5.titlepage.recto.auto.mode" select="sect5info/othercredit"/>
-  <xsl:apply-templates mode="sect5.titlepage.recto.auto.mode" select="info/othercredit"/>
-  <xsl:apply-templates mode="sect5.titlepage.recto.auto.mode" select="sect5info/releaseinfo"/>
-  <xsl:apply-templates mode="sect5.titlepage.recto.auto.mode" select="info/releaseinfo"/>
-  <xsl:apply-templates mode="sect5.titlepage.recto.auto.mode" select="sect5info/copyright"/>
-  <xsl:apply-templates mode="sect5.titlepage.recto.auto.mode" select="info/copyright"/>
-  <xsl:apply-templates mode="sect5.titlepage.recto.auto.mode" select="sect5info/legalnotice"/>
-  <xsl:apply-templates mode="sect5.titlepage.recto.auto.mode" select="info/legalnotice"/>
-  <xsl:apply-templates mode="sect5.titlepage.recto.auto.mode" select="sect5info/pubdate"/>
-  <xsl:apply-templates mode="sect5.titlepage.recto.auto.mode" select="info/pubdate"/>
-  <xsl:apply-templates mode="sect5.titlepage.recto.auto.mode" select="sect5info/revision"/>
-  <xsl:apply-templates mode="sect5.titlepage.recto.auto.mode" select="info/revision"/>
-  <xsl:apply-templates mode="sect5.titlepage.recto.auto.mode" select="sect5info/revhistory"/>
-  <xsl:apply-templates mode="sect5.titlepage.recto.auto.mode" select="info/revhistory"/>
-  <xsl:apply-templates mode="sect5.titlepage.recto.auto.mode" select="sect5info/abstract"/>
-  <xsl:apply-templates mode="sect5.titlepage.recto.auto.mode" select="info/abstract"/>
-</xsl:template>
-
-<xsl:template name="sect5.titlepage.verso">
-</xsl:template>
-
-<xsl:template name="sect5.titlepage.separator"><xsl:if test="count(parent::*)='0'"><hr xmlns="http://www.w3.org/1999/xhtml"/></xsl:if>
-</xsl:template>
-
-<xsl:template name="sect5.titlepage.before.recto">
-</xsl:template>
-
-<xsl:template name="sect5.titlepage.before.verso">
-</xsl:template>
-
-<xsl:template name="sect5.titlepage">
-  <div xmlns="http://www.w3.org/1999/xhtml" class="titlepage">
-    <xsl:variable name="recto.content">
-      <xsl:call-template name="sect5.titlepage.before.recto"/>
-      <xsl:call-template name="sect5.titlepage.recto"/>
-    </xsl:variable>
-    <xsl:variable name="recto.elements.count">
-      <xsl:choose>
-        <xsl:when test="function-available('exsl:node-set')"><xsl:value-of select="count(exsl:node-set($recto.content)/*)"/></xsl:when>
-        <xsl:when test="contains(system-property('xsl:vendor'), 'Apache Software Foundation')">
-          <!--Xalan quirk--><xsl:value-of select="count(exsl:node-set($recto.content)/*)"/></xsl:when>
-        <xsl:otherwise>1</xsl:otherwise>
-      </xsl:choose>
-    </xsl:variable>
-    <xsl:if test="(normalize-space($recto.content) != '') or ($recto.elements.count &gt; 0)">
-      <div><xsl:copy-of select="$recto.content"/></div>
-    </xsl:if>
-    <xsl:variable name="verso.content">
-      <xsl:call-template name="sect5.titlepage.before.verso"/>
-      <xsl:call-template name="sect5.titlepage.verso"/>
-    </xsl:variable>
-    <xsl:variable name="verso.elements.count">
-      <xsl:choose>
-        <xsl:when test="function-available('exsl:node-set')"><xsl:value-of select="count(exsl:node-set($verso.content)/*)"/></xsl:when>
-        <xsl:when test="contains(system-property('xsl:vendor'), 'Apache Software Foundation')">
-          <!--Xalan quirk--><xsl:value-of select="count(exsl:node-set($verso.content)/*)"/></xsl:when>
-        <xsl:otherwise>1</xsl:otherwise>
-      </xsl:choose>
-    </xsl:variable>
-    <xsl:if test="(normalize-space($verso.content) != '') or ($verso.elements.count &gt; 0)">
-      <div><xsl:copy-of select="$verso.content"/></div>
-    </xsl:if>
-    <xsl:call-template name="sect5.titlepage.separator"/>
-  </div>
-</xsl:template>
-
-<xsl:template match="*" mode="sect5.titlepage.recto.mode">
-  <!-- if an element isn't found in this mode, -->
-  <!-- try the generic titlepage.mode -->
-  <xsl:apply-templates select="." mode="titlepage.mode"/>
-</xsl:template>
-
-<xsl:template match="*" mode="sect5.titlepage.verso.mode">
-  <!-- if an element isn't found in this mode, -->
-  <!-- try the generic titlepage.mode -->
-  <xsl:apply-templates select="." mode="titlepage.mode"/>
-</xsl:template>
-
-<xsl:template match="title" mode="sect5.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="sect5.titlepage.recto.style">
-<xsl:apply-templates select="." mode="sect5.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="subtitle" mode="sect5.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="sect5.titlepage.recto.style">
-<xsl:apply-templates select="." mode="sect5.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="corpauthor" mode="sect5.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="sect5.titlepage.recto.style">
-<xsl:apply-templates select="." mode="sect5.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="authorgroup" mode="sect5.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="sect5.titlepage.recto.style">
-<xsl:apply-templates select="." mode="sect5.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="author" mode="sect5.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="sect5.titlepage.recto.style">
-<xsl:apply-templates select="." mode="sect5.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="othercredit" mode="sect5.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="sect5.titlepage.recto.style">
-<xsl:apply-templates select="." mode="sect5.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="releaseinfo" mode="sect5.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="sect5.titlepage.recto.style">
-<xsl:apply-templates select="." mode="sect5.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="copyright" mode="sect5.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="sect5.titlepage.recto.style">
-<xsl:apply-templates select="." mode="sect5.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="legalnotice" mode="sect5.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="sect5.titlepage.recto.style">
-<xsl:apply-templates select="." mode="sect5.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="pubdate" mode="sect5.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="sect5.titlepage.recto.style">
-<xsl:apply-templates select="." mode="sect5.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="revision" mode="sect5.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="sect5.titlepage.recto.style">
-<xsl:apply-templates select="." mode="sect5.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="revhistory" mode="sect5.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="sect5.titlepage.recto.style">
-<xsl:apply-templates select="." mode="sect5.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="abstract" mode="sect5.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="sect5.titlepage.recto.style">
-<xsl:apply-templates select="." mode="sect5.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template name="simplesect.titlepage.recto">
-  <xsl:choose>
-    <xsl:when test="simplesectinfo/title">
-      <xsl:apply-templates mode="simplesect.titlepage.recto.auto.mode" select="simplesectinfo/title"/>
-    </xsl:when>
-    <xsl:when test="docinfo/title">
-      <xsl:apply-templates mode="simplesect.titlepage.recto.auto.mode" select="docinfo/title"/>
-    </xsl:when>
-    <xsl:when test="info/title">
-      <xsl:apply-templates mode="simplesect.titlepage.recto.auto.mode" select="info/title"/>
-    </xsl:when>
-    <xsl:when test="title">
-      <xsl:apply-templates mode="simplesect.titlepage.recto.auto.mode" select="title"/>
-    </xsl:when>
-  </xsl:choose>
-
-  <xsl:choose>
-    <xsl:when test="simplesectinfo/subtitle">
-      <xsl:apply-templates mode="simplesect.titlepage.recto.auto.mode" select="simplesectinfo/subtitle"/>
-    </xsl:when>
-    <xsl:when test="docinfo/subtitle">
-      <xsl:apply-templates mode="simplesect.titlepage.recto.auto.mode" select="docinfo/subtitle"/>
-    </xsl:when>
-    <xsl:when test="info/subtitle">
-      <xsl:apply-templates mode="simplesect.titlepage.recto.auto.mode" select="info/subtitle"/>
-    </xsl:when>
-    <xsl:when test="subtitle">
-      <xsl:apply-templates mode="simplesect.titlepage.recto.auto.mode" select="subtitle"/>
-    </xsl:when>
-  </xsl:choose>
-
-  <xsl:apply-templates mode="simplesect.titlepage.recto.auto.mode" select="simplesectinfo/corpauthor"/>
-  <xsl:apply-templates mode="simplesect.titlepage.recto.auto.mode" select="docinfo/corpauthor"/>
-  <xsl:apply-templates mode="simplesect.titlepage.recto.auto.mode" select="info/corpauthor"/>
-  <xsl:apply-templates mode="simplesect.titlepage.recto.auto.mode" select="simplesectinfo/authorgroup"/>
-  <xsl:apply-templates mode="simplesect.titlepage.recto.auto.mode" select="docinfo/authorgroup"/>
-  <xsl:apply-templates mode="simplesect.titlepage.recto.auto.mode" select="info/authorgroup"/>
-  <xsl:apply-templates mode="simplesect.titlepage.recto.auto.mode" select="simplesectinfo/author"/>
-  <xsl:apply-templates mode="simplesect.titlepage.recto.auto.mode" select="docinfo/author"/>
-  <xsl:apply-templates mode="simplesect.titlepage.recto.auto.mode" select="info/author"/>
-  <xsl:apply-templates mode="simplesect.titlepage.recto.auto.mode" select="simplesectinfo/othercredit"/>
-  <xsl:apply-templates mode="simplesect.titlepage.recto.auto.mode" select="docinfo/othercredit"/>
-  <xsl:apply-templates mode="simplesect.titlepage.recto.auto.mode" select="info/othercredit"/>
-  <xsl:apply-templates mode="simplesect.titlepage.recto.auto.mode" select="simplesectinfo/releaseinfo"/>
-  <xsl:apply-templates mode="simplesect.titlepage.recto.auto.mode" select="docinfo/releaseinfo"/>
-  <xsl:apply-templates mode="simplesect.titlepage.recto.auto.mode" select="info/releaseinfo"/>
-  <xsl:apply-templates mode="simplesect.titlepage.recto.auto.mode" select="simplesectinfo/copyright"/>
-  <xsl:apply-templates mode="simplesect.titlepage.recto.auto.mode" select="docinfo/copyright"/>
-  <xsl:apply-templates mode="simplesect.titlepage.recto.auto.mode" select="info/copyright"/>
-  <xsl:apply-templates mode="simplesect.titlepage.recto.auto.mode" select="simplesectinfo/legalnotice"/>
-  <xsl:apply-templates mode="simplesect.titlepage.recto.auto.mode" select="docinfo/legalnotice"/>
-  <xsl:apply-templates mode="simplesect.titlepage.recto.auto.mode" select="info/legalnotice"/>
-  <xsl:apply-templates mode="simplesect.titlepage.recto.auto.mode" select="simplesectinfo/pubdate"/>
-  <xsl:apply-templates mode="simplesect.titlepage.recto.auto.mode" select="docinfo/pubdate"/>
-  <xsl:apply-templates mode="simplesect.titlepage.recto.auto.mode" select="info/pubdate"/>
-  <xsl:apply-templates mode="simplesect.titlepage.recto.auto.mode" select="simplesectinfo/revision"/>
-  <xsl:apply-templates mode="simplesect.titlepage.recto.auto.mode" select="docinfo/revision"/>
-  <xsl:apply-templates mode="simplesect.titlepage.recto.auto.mode" select="info/revision"/>
-  <xsl:apply-templates mode="simplesect.titlepage.recto.auto.mode" select="simplesectinfo/revhistory"/>
-  <xsl:apply-templates mode="simplesect.titlepage.recto.auto.mode" select="docinfo/revhistory"/>
-  <xsl:apply-templates mode="simplesect.titlepage.recto.auto.mode" select="info/revhistory"/>
-  <xsl:apply-templates mode="simplesect.titlepage.recto.auto.mode" select="simplesectinfo/abstract"/>
-  <xsl:apply-templates mode="simplesect.titlepage.recto.auto.mode" select="docinfo/abstract"/>
-  <xsl:apply-templates mode="simplesect.titlepage.recto.auto.mode" select="info/abstract"/>
-</xsl:template>
-
-<xsl:template name="simplesect.titlepage.verso">
-</xsl:template>
-
-<xsl:template name="simplesect.titlepage.separator"><xsl:if test="count(parent::*)='0'"><hr xmlns="http://www.w3.org/1999/xhtml"/></xsl:if>
-</xsl:template>
-
-<xsl:template name="simplesect.titlepage.before.recto">
-</xsl:template>
-
-<xsl:template name="simplesect.titlepage.before.verso">
-</xsl:template>
-
-<xsl:template name="simplesect.titlepage">
-  <div xmlns="http://www.w3.org/1999/xhtml" class="titlepage">
-    <xsl:variable name="recto.content">
-      <xsl:call-template name="simplesect.titlepage.before.recto"/>
-      <xsl:call-template name="simplesect.titlepage.recto"/>
-    </xsl:variable>
-    <xsl:variable name="recto.elements.count">
-      <xsl:choose>
-        <xsl:when test="function-available('exsl:node-set')"><xsl:value-of select="count(exsl:node-set($recto.content)/*)"/></xsl:when>
-        <xsl:when test="contains(system-property('xsl:vendor'), 'Apache Software Foundation')">
-          <!--Xalan quirk--><xsl:value-of select="count(exsl:node-set($recto.content)/*)"/></xsl:when>
-        <xsl:otherwise>1</xsl:otherwise>
-      </xsl:choose>
-    </xsl:variable>
-    <xsl:if test="(normalize-space($recto.content) != '') or ($recto.elements.count &gt; 0)">
-      <div><xsl:copy-of select="$recto.content"/></div>
-    </xsl:if>
-    <xsl:variable name="verso.content">
-      <xsl:call-template name="simplesect.titlepage.before.verso"/>
-      <xsl:call-template name="simplesect.titlepage.verso"/>
-    </xsl:variable>
-    <xsl:variable name="verso.elements.count">
-      <xsl:choose>
-        <xsl:when test="function-available('exsl:node-set')"><xsl:value-of select="count(exsl:node-set($verso.content)/*)"/></xsl:when>
-        <xsl:when test="contains(system-property('xsl:vendor'), 'Apache Software Foundation')">
-          <!--Xalan quirk--><xsl:value-of select="count(exsl:node-set($verso.content)/*)"/></xsl:when>
-        <xsl:otherwise>1</xsl:otherwise>
-      </xsl:choose>
-    </xsl:variable>
-    <xsl:if test="(normalize-space($verso.content) != '') or ($verso.elements.count &gt; 0)">
-      <div><xsl:copy-of select="$verso.content"/></div>
-    </xsl:if>
-    <xsl:call-template name="simplesect.titlepage.separator"/>
-  </div>
-</xsl:template>
-
-<xsl:template match="*" mode="simplesect.titlepage.recto.mode">
-  <!-- if an element isn't found in this mode, -->
-  <!-- try the generic titlepage.mode -->
-  <xsl:apply-templates select="." mode="titlepage.mode"/>
-</xsl:template>
-
-<xsl:template match="*" mode="simplesect.titlepage.verso.mode">
-  <!-- if an element isn't found in this mode, -->
-  <!-- try the generic titlepage.mode -->
-  <xsl:apply-templates select="." mode="titlepage.mode"/>
-</xsl:template>
-
-<xsl:template match="title" mode="simplesect.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="simplesect.titlepage.recto.style">
-<xsl:apply-templates select="." mode="simplesect.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="subtitle" mode="simplesect.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="simplesect.titlepage.recto.style">
-<xsl:apply-templates select="." mode="simplesect.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="corpauthor" mode="simplesect.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="simplesect.titlepage.recto.style">
-<xsl:apply-templates select="." mode="simplesect.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="authorgroup" mode="simplesect.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="simplesect.titlepage.recto.style">
-<xsl:apply-templates select="." mode="simplesect.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="author" mode="simplesect.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="simplesect.titlepage.recto.style">
-<xsl:apply-templates select="." mode="simplesect.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="othercredit" mode="simplesect.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="simplesect.titlepage.recto.style">
-<xsl:apply-templates select="." mode="simplesect.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="releaseinfo" mode="simplesect.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="simplesect.titlepage.recto.style">
-<xsl:apply-templates select="." mode="simplesect.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="copyright" mode="simplesect.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="simplesect.titlepage.recto.style">
-<xsl:apply-templates select="." mode="simplesect.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="legalnotice" mode="simplesect.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="simplesect.titlepage.recto.style">
-<xsl:apply-templates select="." mode="simplesect.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="pubdate" mode="simplesect.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="simplesect.titlepage.recto.style">
-<xsl:apply-templates select="." mode="simplesect.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="revision" mode="simplesect.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="simplesect.titlepage.recto.style">
-<xsl:apply-templates select="." mode="simplesect.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="revhistory" mode="simplesect.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="simplesect.titlepage.recto.style">
-<xsl:apply-templates select="." mode="simplesect.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template match="abstract" mode="simplesect.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="simplesect.titlepage.recto.style">
-<xsl:apply-templates select="." mode="simplesect.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template name="bibliography.titlepage.recto">
-  <div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="bibliography.titlepage.recto.style">
-<xsl:call-template name="component.title">
-<xsl:with-param name="node" select="ancestor-or-self::bibliography[1]"/>
-</xsl:call-template></div>
-  <xsl:choose>
-    <xsl:when test="bibliographyinfo/subtitle">
-      <xsl:apply-templates mode="bibliography.titlepage.recto.auto.mode" select="bibliographyinfo/subtitle"/>
-    </xsl:when>
-    <xsl:when test="docinfo/subtitle">
-      <xsl:apply-templates mode="bibliography.titlepage.recto.auto.mode" select="docinfo/subtitle"/>
-    </xsl:when>
-    <xsl:when test="info/subtitle">
-      <xsl:apply-templates mode="bibliography.titlepage.recto.auto.mode" select="info/subtitle"/>
-    </xsl:when>
-    <xsl:when test="subtitle">
-      <xsl:apply-templates mode="bibliography.titlepage.recto.auto.mode" select="subtitle"/>
-    </xsl:when>
-  </xsl:choose>
-
-</xsl:template>
-
-<xsl:template name="bibliography.titlepage.verso">
-</xsl:template>
-
-<xsl:template name="bibliography.titlepage.separator">
-</xsl:template>
-
-<xsl:template name="bibliography.titlepage.before.recto">
-</xsl:template>
-
-<xsl:template name="bibliography.titlepage.before.verso">
-</xsl:template>
-
-<xsl:template name="bibliography.titlepage">
-  <div xmlns="http://www.w3.org/1999/xhtml" class="titlepage">
-    <xsl:variable name="recto.content">
-      <xsl:call-template name="bibliography.titlepage.before.recto"/>
-      <xsl:call-template name="bibliography.titlepage.recto"/>
-    </xsl:variable>
-    <xsl:variable name="recto.elements.count">
-      <xsl:choose>
-        <xsl:when test="function-available('exsl:node-set')"><xsl:value-of select="count(exsl:node-set($recto.content)/*)"/></xsl:when>
-        <xsl:when test="contains(system-property('xsl:vendor'), 'Apache Software Foundation')">
-          <!--Xalan quirk--><xsl:value-of select="count(exsl:node-set($recto.content)/*)"/></xsl:when>
-        <xsl:otherwise>1</xsl:otherwise>
-      </xsl:choose>
-    </xsl:variable>
-    <xsl:if test="(normalize-space($recto.content) != '') or ($recto.elements.count &gt; 0)">
-      <div><xsl:copy-of select="$recto.content"/></div>
-    </xsl:if>
-    <xsl:variable name="verso.content">
-      <xsl:call-template name="bibliography.titlepage.before.verso"/>
-      <xsl:call-template name="bibliography.titlepage.verso"/>
-    </xsl:variable>
-    <xsl:variable name="verso.elements.count">
-      <xsl:choose>
-        <xsl:when test="function-available('exsl:node-set')"><xsl:value-of select="count(exsl:node-set($verso.content)/*)"/></xsl:when>
-        <xsl:when test="contains(system-property('xsl:vendor'), 'Apache Software Foundation')">
-          <!--Xalan quirk--><xsl:value-of select="count(exsl:node-set($verso.content)/*)"/></xsl:when>
-        <xsl:otherwise>1</xsl:otherwise>
-      </xsl:choose>
-    </xsl:variable>
-    <xsl:if test="(normalize-space($verso.content) != '') or ($verso.elements.count &gt; 0)">
-      <div><xsl:copy-of select="$verso.content"/></div>
-    </xsl:if>
-    <xsl:call-template name="bibliography.titlepage.separator"/>
-  </div>
-</xsl:template>
-
-<xsl:template match="*" mode="bibliography.titlepage.recto.mode">
-  <!-- if an element isn't found in this mode, -->
-  <!-- try the generic titlepage.mode -->
-  <xsl:apply-templates select="." mode="titlepage.mode"/>
-</xsl:template>
-
-<xsl:template match="*" mode="bibliography.titlepage.verso.mode">
-  <!-- if an element isn't found in this mode, -->
-  <!-- try the generic titlepage.mode -->
-  <xsl:apply-templates select="." mode="titlepage.mode"/>
-</xsl:template>
-
-<xsl:template match="subtitle" mode="bibliography.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="bibliography.titlepage.recto.style">
-<xsl:apply-templates select="." mode="bibliography.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template name="glossary.titlepage.recto">
-  <div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="glossary.titlepage.recto.style">
-<xsl:call-template name="component.title">
-<xsl:with-param name="node" select="ancestor-or-self::glossary[1]"/>
-</xsl:call-template></div>
-  <xsl:choose>
-    <xsl:when test="glossaryinfo/subtitle">
-      <xsl:apply-templates mode="glossary.titlepage.recto.auto.mode" select="glossaryinfo/subtitle"/>
-    </xsl:when>
-    <xsl:when test="docinfo/subtitle">
-      <xsl:apply-templates mode="glossary.titlepage.recto.auto.mode" select="docinfo/subtitle"/>
-    </xsl:when>
-    <xsl:when test="info/subtitle">
-      <xsl:apply-templates mode="glossary.titlepage.recto.auto.mode" select="info/subtitle"/>
-    </xsl:when>
-    <xsl:when test="subtitle">
-      <xsl:apply-templates mode="glossary.titlepage.recto.auto.mode" select="subtitle"/>
-    </xsl:when>
-  </xsl:choose>
-
-</xsl:template>
-
-<xsl:template name="glossary.titlepage.verso">
-</xsl:template>
-
-<xsl:template name="glossary.titlepage.separator">
-</xsl:template>
-
-<xsl:template name="glossary.titlepage.before.recto">
-</xsl:template>
-
-<xsl:template name="glossary.titlepage.before.verso">
-</xsl:template>
-
-<xsl:template name="glossary.titlepage">
-  <div xmlns="http://www.w3.org/1999/xhtml" class="titlepage">
-    <xsl:variable name="recto.content">
-      <xsl:call-template name="glossary.titlepage.before.recto"/>
-      <xsl:call-template name="glossary.titlepage.recto"/>
-    </xsl:variable>
-    <xsl:variable name="recto.elements.count">
-      <xsl:choose>
-        <xsl:when test="function-available('exsl:node-set')"><xsl:value-of select="count(exsl:node-set($recto.content)/*)"/></xsl:when>
-        <xsl:when test="contains(system-property('xsl:vendor'), 'Apache Software Foundation')">
-          <!--Xalan quirk--><xsl:value-of select="count(exsl:node-set($recto.content)/*)"/></xsl:when>
-        <xsl:otherwise>1</xsl:otherwise>
-      </xsl:choose>
-    </xsl:variable>
-    <xsl:if test="(normalize-space($recto.content) != '') or ($recto.elements.count &gt; 0)">
-      <div><xsl:copy-of select="$recto.content"/></div>
-    </xsl:if>
-    <xsl:variable name="verso.content">
-      <xsl:call-template name="glossary.titlepage.before.verso"/>
-      <xsl:call-template name="glossary.titlepage.verso"/>
-    </xsl:variable>
-    <xsl:variable name="verso.elements.count">
-      <xsl:choose>
-        <xsl:when test="function-available('exsl:node-set')"><xsl:value-of select="count(exsl:node-set($verso.content)/*)"/></xsl:when>
-        <xsl:when test="contains(system-property('xsl:vendor'), 'Apache Software Foundation')">
-          <!--Xalan quirk--><xsl:value-of select="count(exsl:node-set($verso.content)/*)"/></xsl:when>
-        <xsl:otherwise>1</xsl:otherwise>
-      </xsl:choose>
-    </xsl:variable>
-    <xsl:if test="(normalize-space($verso.content) != '') or ($verso.elements.count &gt; 0)">
-      <div><xsl:copy-of select="$verso.content"/></div>
-    </xsl:if>
-    <xsl:call-template name="glossary.titlepage.separator"/>
-  </div>
-</xsl:template>
-
-<xsl:template match="*" mode="glossary.titlepage.recto.mode">
-  <!-- if an element isn't found in this mode, -->
-  <!-- try the generic titlepage.mode -->
-  <xsl:apply-templates select="." mode="titlepage.mode"/>
-</xsl:template>
-
-<xsl:template match="*" mode="glossary.titlepage.verso.mode">
-  <!-- if an element isn't found in this mode, -->
-  <!-- try the generic titlepage.mode -->
-  <xsl:apply-templates select="." mode="titlepage.mode"/>
-</xsl:template>
-
-<xsl:template match="subtitle" mode="glossary.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="glossary.titlepage.recto.style">
-<xsl:apply-templates select="." mode="glossary.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template name="index.titlepage.recto">
-  <div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="index.titlepage.recto.style">
-<xsl:call-template name="component.title">
-<xsl:with-param name="node" select="ancestor-or-self::index[1]"/>
-</xsl:call-template></div>
-  <xsl:choose>
-    <xsl:when test="indexinfo/subtitle">
-      <xsl:apply-templates mode="index.titlepage.recto.auto.mode" select="indexinfo/subtitle"/>
-    </xsl:when>
-    <xsl:when test="docinfo/subtitle">
-      <xsl:apply-templates mode="index.titlepage.recto.auto.mode" select="docinfo/subtitle"/>
-    </xsl:when>
-    <xsl:when test="info/subtitle">
-      <xsl:apply-templates mode="index.titlepage.recto.auto.mode" select="info/subtitle"/>
-    </xsl:when>
-    <xsl:when test="subtitle">
-      <xsl:apply-templates mode="index.titlepage.recto.auto.mode" select="subtitle"/>
-    </xsl:when>
-  </xsl:choose>
-
-</xsl:template>
-
-<xsl:template name="index.titlepage.verso">
-</xsl:template>
-
-<xsl:template name="index.titlepage.separator">
-</xsl:template>
-
-<xsl:template name="index.titlepage.before.recto">
-</xsl:template>
-
-<xsl:template name="index.titlepage.before.verso">
-</xsl:template>
-
-<xsl:template name="index.titlepage">
-  <div xmlns="http://www.w3.org/1999/xhtml" class="titlepage">
-    <xsl:variable name="recto.content">
-      <xsl:call-template name="index.titlepage.before.recto"/>
-      <xsl:call-template name="index.titlepage.recto"/>
-    </xsl:variable>
-    <xsl:variable name="recto.elements.count">
-      <xsl:choose>
-        <xsl:when test="function-available('exsl:node-set')"><xsl:value-of select="count(exsl:node-set($recto.content)/*)"/></xsl:when>
-        <xsl:when test="contains(system-property('xsl:vendor'), 'Apache Software Foundation')">
-          <!--Xalan quirk--><xsl:value-of select="count(exsl:node-set($recto.content)/*)"/></xsl:when>
-        <xsl:otherwise>1</xsl:otherwise>
-      </xsl:choose>
-    </xsl:variable>
-    <xsl:if test="(normalize-space($recto.content) != '') or ($recto.elements.count &gt; 0)">
-      <div><xsl:copy-of select="$recto.content"/></div>
-    </xsl:if>
-    <xsl:variable name="verso.content">
-      <xsl:call-template name="index.titlepage.before.verso"/>
-      <xsl:call-template name="index.titlepage.verso"/>
-    </xsl:variable>
-    <xsl:variable name="verso.elements.count">
-      <xsl:choose>
-        <xsl:when test="function-available('exsl:node-set')"><xsl:value-of select="count(exsl:node-set($verso.content)/*)"/></xsl:when>
-        <xsl:when test="contains(system-property('xsl:vendor'), 'Apache Software Foundation')">
-          <!--Xalan quirk--><xsl:value-of select="count(exsl:node-set($verso.content)/*)"/></xsl:when>
-        <xsl:otherwise>1</xsl:otherwise>
-      </xsl:choose>
-    </xsl:variable>
-    <xsl:if test="(normalize-space($verso.content) != '') or ($verso.elements.count &gt; 0)">
-      <div><xsl:copy-of select="$verso.content"/></div>
-    </xsl:if>
-    <xsl:call-template name="index.titlepage.separator"/>
-  </div>
-</xsl:template>
-
-<xsl:template match="*" mode="index.titlepage.recto.mode">
-  <!-- if an element isn't found in this mode, -->
-  <!-- try the generic titlepage.mode -->
-  <xsl:apply-templates select="." mode="titlepage.mode"/>
-</xsl:template>
-
-<xsl:template match="*" mode="index.titlepage.verso.mode">
-  <!-- if an element isn't found in this mode, -->
-  <!-- try the generic titlepage.mode -->
-  <xsl:apply-templates select="." mode="titlepage.mode"/>
-</xsl:template>
-
-<xsl:template match="subtitle" mode="index.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="index.titlepage.recto.style">
-<xsl:apply-templates select="." mode="index.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template name="setindex.titlepage.recto">
-  <div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="setindex.titlepage.recto.style">
-<xsl:call-template name="component.title">
-<xsl:with-param name="node" select="ancestor-or-self::setindex[1]"/>
-</xsl:call-template></div>
-  <xsl:choose>
-    <xsl:when test="setindexinfo/subtitle">
-      <xsl:apply-templates mode="setindex.titlepage.recto.auto.mode" select="setindexinfo/subtitle"/>
-    </xsl:when>
-    <xsl:when test="docinfo/subtitle">
-      <xsl:apply-templates mode="setindex.titlepage.recto.auto.mode" select="docinfo/subtitle"/>
-    </xsl:when>
-    <xsl:when test="info/subtitle">
-      <xsl:apply-templates mode="setindex.titlepage.recto.auto.mode" select="info/subtitle"/>
-    </xsl:when>
-    <xsl:when test="subtitle">
-      <xsl:apply-templates mode="setindex.titlepage.recto.auto.mode" select="subtitle"/>
-    </xsl:when>
-  </xsl:choose>
-
-</xsl:template>
-
-<xsl:template name="setindex.titlepage.verso">
-</xsl:template>
-
-<xsl:template name="setindex.titlepage.separator">
-</xsl:template>
-
-<xsl:template name="setindex.titlepage.before.recto">
-</xsl:template>
-
-<xsl:template name="setindex.titlepage.before.verso">
-</xsl:template>
-
-<xsl:template name="setindex.titlepage">
-  <div xmlns="http://www.w3.org/1999/xhtml" class="titlepage">
-    <xsl:variable name="recto.content">
-      <xsl:call-template name="setindex.titlepage.before.recto"/>
-      <xsl:call-template name="setindex.titlepage.recto"/>
-    </xsl:variable>
-    <xsl:variable name="recto.elements.count">
-      <xsl:choose>
-        <xsl:when test="function-available('exsl:node-set')"><xsl:value-of select="count(exsl:node-set($recto.content)/*)"/></xsl:when>
-        <xsl:when test="contains(system-property('xsl:vendor'), 'Apache Software Foundation')">
-          <!--Xalan quirk--><xsl:value-of select="count(exsl:node-set($recto.content)/*)"/></xsl:when>
-        <xsl:otherwise>1</xsl:otherwise>
-      </xsl:choose>
-    </xsl:variable>
-    <xsl:if test="(normalize-space($recto.content) != '') or ($recto.elements.count &gt; 0)">
-      <div><xsl:copy-of select="$recto.content"/></div>
-    </xsl:if>
-    <xsl:variable name="verso.content">
-      <xsl:call-template name="setindex.titlepage.before.verso"/>
-      <xsl:call-template name="setindex.titlepage.verso"/>
-    </xsl:variable>
-    <xsl:variable name="verso.elements.count">
-      <xsl:choose>
-        <xsl:when test="function-available('exsl:node-set')"><xsl:value-of select="count(exsl:node-set($verso.content)/*)"/></xsl:when>
-        <xsl:when test="contains(system-property('xsl:vendor'), 'Apache Software Foundation')">
-          <!--Xalan quirk--><xsl:value-of select="count(exsl:node-set($verso.content)/*)"/></xsl:when>
-        <xsl:otherwise>1</xsl:otherwise>
-      </xsl:choose>
-    </xsl:variable>
-    <xsl:if test="(normalize-space($verso.content) != '') or ($verso.elements.count &gt; 0)">
-      <div><xsl:copy-of select="$verso.content"/></div>
-    </xsl:if>
-    <xsl:call-template name="setindex.titlepage.separator"/>
-  </div>
-</xsl:template>
-
-<xsl:template match="*" mode="setindex.titlepage.recto.mode">
-  <!-- if an element isn't found in this mode, -->
-  <!-- try the generic titlepage.mode -->
-  <xsl:apply-templates select="." mode="titlepage.mode"/>
-</xsl:template>
-
-<xsl:template match="*" mode="setindex.titlepage.verso.mode">
-  <!-- if an element isn't found in this mode, -->
-  <!-- try the generic titlepage.mode -->
-  <xsl:apply-templates select="." mode="titlepage.mode"/>
-</xsl:template>
-
-<xsl:template match="subtitle" mode="setindex.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="setindex.titlepage.recto.style">
-<xsl:apply-templates select="." mode="setindex.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-<xsl:template name="sidebar.titlepage.recto">
-  <xsl:choose>
-    <xsl:when test="sidebarinfo/title">
-      <xsl:apply-templates mode="sidebar.titlepage.recto.auto.mode" select="sidebarinfo/title"/>
-    </xsl:when>
-    <xsl:when test="docinfo/title">
-      <xsl:apply-templates mode="sidebar.titlepage.recto.auto.mode" select="docinfo/title"/>
-    </xsl:when>
-    <xsl:when test="info/title">
-      <xsl:apply-templates mode="sidebar.titlepage.recto.auto.mode" select="info/title"/>
-    </xsl:when>
-    <xsl:when test="title">
-      <xsl:apply-templates mode="sidebar.titlepage.recto.auto.mode" select="title"/>
-    </xsl:when>
-  </xsl:choose>
-
-  <xsl:choose>
-    <xsl:when test="sidebarinfo/subtitle">
-      <xsl:apply-templates mode="sidebar.titlepage.recto.auto.mode" select="sidebarinfo/subtitle"/>
-    </xsl:when>
-    <xsl:when test="docinfo/subtitle">
-      <xsl:apply-templates mode="sidebar.titlepage.recto.auto.mode" select="docinfo/subtitle"/>
-    </xsl:when>
-    <xsl:when test="info/subtitle">
-      <xsl:apply-templates mode="sidebar.titlepage.recto.auto.mode" select="info/subtitle"/>
-    </xsl:when>
-    <xsl:when test="subtitle">
-      <xsl:apply-templates mode="sidebar.titlepage.recto.auto.mode" select="subtitle"/>
-    </xsl:when>
-  </xsl:choose>
-
-</xsl:template>
-
-<xsl:template name="sidebar.titlepage.verso">
-</xsl:template>
-
-<xsl:template name="sidebar.titlepage.separator">
-</xsl:template>
-
-<xsl:template name="sidebar.titlepage.before.recto">
-</xsl:template>
-
-<xsl:template name="sidebar.titlepage.before.verso">
-</xsl:template>
-
-<xsl:template name="sidebar.titlepage">
-  <div xmlns="http://www.w3.org/1999/xhtml" class="titlepage">
-    <xsl:variable name="recto.content">
-      <xsl:call-template name="sidebar.titlepage.before.recto"/>
-      <xsl:call-template name="sidebar.titlepage.recto"/>
-    </xsl:variable>
-    <xsl:variable name="recto.elements.count">
-      <xsl:choose>
-        <xsl:when test="function-available('exsl:node-set')"><xsl:value-of select="count(exsl:node-set($recto.content)/*)"/></xsl:when>
-        <xsl:when test="contains(system-property('xsl:vendor'), 'Apache Software Foundation')">
-          <!--Xalan quirk--><xsl:value-of select="count(exsl:node-set($recto.content)/*)"/></xsl:when>
-        <xsl:otherwise>1</xsl:otherwise>
-      </xsl:choose>
-    </xsl:variable>
-    <xsl:if test="(normalize-space($recto.content) != '') or ($recto.elements.count &gt; 0)">
-      <div><xsl:copy-of select="$recto.content"/></div>
-    </xsl:if>
-    <xsl:variable name="verso.content">
-      <xsl:call-template name="sidebar.titlepage.before.verso"/>
-      <xsl:call-template name="sidebar.titlepage.verso"/>
-    </xsl:variable>
-    <xsl:variable name="verso.elements.count">
-      <xsl:choose>
-        <xsl:when test="function-available('exsl:node-set')"><xsl:value-of select="count(exsl:node-set($verso.content)/*)"/></xsl:when>
-        <xsl:when test="contains(system-property('xsl:vendor'), 'Apache Software Foundation')">
-          <!--Xalan quirk--><xsl:value-of select="count(exsl:node-set($verso.content)/*)"/></xsl:when>
-        <xsl:otherwise>1</xsl:otherwise>
-      </xsl:choose>
-    </xsl:variable>
-    <xsl:if test="(normalize-space($verso.content) != '') or ($verso.elements.count &gt; 0)">
-      <div><xsl:copy-of select="$verso.content"/></div>
-    </xsl:if>
-    <xsl:call-template name="sidebar.titlepage.separator"/>
-  </div>
-</xsl:template>
-
-<xsl:template match="*" mode="sidebar.titlepage.recto.mode">
-  <!-- if an element isn't found in this mode, -->
-  <!-- try the generic titlepage.mode -->
-  <xsl:apply-templates select="." mode="titlepage.mode"/>
-</xsl:template>
-
-<xsl:template match="*" mode="sidebar.titlepage.verso.mode">
-  <!-- if an element isn't found in this mode, -->
-  <!-- try the generic titlepage.mode -->
-  <xsl:apply-templates select="." mode="titlepage.mode"/>
-</xsl:template>
-
-<xsl:template match="title" mode="sidebar.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="sidebar.titlepage.recto.style">
-<xsl:call-template name="formal.object.heading">
-<xsl:with-param name="object" select="ancestor-or-self::sidebar[1]"/>
-</xsl:call-template>
-</div>
-</xsl:template>
-
-<xsl:template match="subtitle" mode="sidebar.titlepage.recto.auto.mode">
-<div xmlns="http://www.w3.org/1999/xhtml" xsl:use-attribute-sets="sidebar.titlepage.recto.style">
-<xsl:apply-templates select="." mode="sidebar.titlepage.recto.mode"/>
-</div>
-</xsl:template>
-
-</xsl:stylesheet>
-

+ 0 - 264
stylesheets/lfs-xsl/docbook-xsl-1.78.1/extensions/LICENSE.txt

@@ -1,264 +0,0 @@
-LICENSE
-
-   Copyright (c) 2008 N. Quaine - NexWave Solutions All Rights Reserved. 
-
-CONDITIONS
-
-Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met: 
-Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer. 
-Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution. 
-Neither the name of the copyright holders nor the names of the contributors may be used to endorse or promote products derived from this software without specific prior written permission. 
-
-DISCLAIMER
-    THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR
-    IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
-    FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
-    CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
-    CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
-    SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-    THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
-    OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
-    POSSIBILITY OF SUCH DAMAGE. 
-
-
-
-
-                                 Apache License
-                           Version 2.0, January 2004
-                        http://www.apache.org/licenses/
-
-   TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION
-
-   1. Definitions.
-
-      "License" shall mean the terms and conditions for use, reproduction,
-      and distribution as defined by Sections 1 through 9 of this document.
-
-      "Licensor" shall mean the copyright owner or entity authorized by
-      the copyright owner that is granting the License.
-
-      "Legal Entity" shall mean the union of the acting entity and all
-      other entities that control, are controlled by, or are under common
-      control with that entity. For the purposes of this definition,
-      "control" means (i) the power, direct or indirect, to cause the
-      direction or management of such entity, whether by contract or
-      otherwise, or (ii) ownership of fifty percent (50%) or more of the
-      outstanding shares, or (iii) beneficial ownership of such entity.
-
-      "You" (or "Your") shall mean an individual or Legal Entity
-      exercising permissions granted by this License.
-
-      "Source" form shall mean the preferred form for making modifications,
-      including but not limited to software source code, documentation
-      source, and configuration files.
-
-      "Object" form shall mean any form resulting from mechanical
-      transformation or translation of a Source form, including but
-      not limited to compiled object code, generated documentation,
-      and conversions to other media types.
-
-      "Work" shall mean the work of authorship, whether in Source or
-      Object form, made available under the License, as indicated by a
-      copyright notice that is included in or attached to the work
-      (an example is provided in the Appendix below).
-
-      "Derivative Works" shall mean any work, whether in Source or Object
-      form, that is based on (or derived from) the Work and for which the
-      editorial revisions, annotations, elaborations, or other modifications
-      represent, as a whole, an original work of authorship. For the purposes
-      of this License, Derivative Works shall not include works that remain
-      separable from, or merely link (or bind by name) to the interfaces of,
-      the Work and Derivative Works thereof.
-
-      "Contribution" shall mean any work of authorship, including
-      the original version of the Work and any modifications or additions
-      to that Work or Derivative Works thereof, that is intentionally
-      submitted to Licensor for inclusion in the Work by the copyright owner
-      or by an individual or Legal Entity authorized to submit on behalf of
-      the copyright owner. For the purposes of this definition, "submitted"
-      means any form of electronic, verbal, or written communication sent
-      to the Licensor or its representatives, including but not limited to
-      communication on electronic mailing lists, source code control systems,
-      and issue tracking systems that are managed by, or on behalf of, the
-      Licensor for the purpose of discussing and improving the Work, but
-      excluding communication that is conspicuously marked or otherwise
-      designated in writing by the copyright owner as "Not a Contribution."
-
-      "Contributor" shall mean Licensor and any individual or Legal Entity
-      on behalf of whom a Contribution has been received by Licensor and
-      subsequently incorporated within the Work.
-
-   2. Grant of Copyright License. Subject to the terms and conditions of
-      this License, each Contributor hereby grants to You a perpetual,
-      worldwide, non-exclusive, no-charge, royalty-free, irrevocable
-      copyright license to reproduce, prepare Derivative Works of,
-      publicly display, publicly perform, sublicense, and distribute the
-      Work and such Derivative Works in Source or Object form.
-
-   3. Grant of Patent License. Subject to the terms and conditions of
-      this License, each Contributor hereby grants to You a perpetual,
-      worldwide, non-exclusive, no-charge, royalty-free, irrevocable
-      (except as stated in this section) patent license to make, have made,
-      use, offer to sell, sell, import, and otherwise transfer the Work,
-      where such license applies only to those patent claims licensable
-      by such Contributor that are necessarily infringed by their
-      Contribution(s) alone or by combination of their Contribution(s)
-      with the Work to which such Contribution(s) was submitted. If You
-      institute patent litigation against any entity (including a
-      cross-claim or counterclaim in a lawsuit) alleging that the Work
-      or a Contribution incorporated within the Work constitutes direct
-      or contributory patent infringement, then any patent licenses
-      granted to You under this License for that Work shall terminate
-      as of the date such litigation is filed.
-
-   4. Redistribution. You may reproduce and distribute copies of the
-      Work or Derivative Works thereof in any medium, with or without
-      modifications, and in Source or Object form, provided that You
-      meet the following conditions:
-
-      (a) You must give any other recipients of the Work or
-          Derivative Works a copy of this License; and
-
-      (b) You must cause any modified files to carry prominent notices
-          stating that You changed the files; and
-
-      (c) You must retain, in the Source form of any Derivative Works
-          that You distribute, all copyright, patent, trademark, and
-          attribution notices from the Source form of the Work,
-          excluding those notices that do not pertain to any part of
-          the Derivative Works; and
-
-      (d) If the Work includes a "NOTICE" text file as part of its
-          distribution, then any Derivative Works that You distribute must
-          include a readable copy of the attribution notices contained
-          within such NOTICE file, excluding those notices that do not
-          pertain to any part of the Derivative Works, in at least one
-          of the following places: within a NOTICE text file distributed
-          as part of the Derivative Works; within the Source form or
-          documentation, if provided along with the Derivative Works; or,
-          within a display generated by the Derivative Works, if and
-          wherever such third-party notices normally appear. The contents
-          of the NOTICE file are for informational purposes only and
-          do not modify the License. You may add Your own attribution
-          notices within Derivative Works that You distribute, alongside
-          or as an addendum to the NOTICE text from the Work, provided
-          that such additional attribution notices cannot be construed
-          as modifying the License.
-
-      You may add Your own copyright statement to Your modifications and
-      may provide additional or different license terms and conditions
-      for use, reproduction, or distribution of Your modifications, or
-      for any such Derivative Works as a whole, provided Your use,
-      reproduction, and distribution of the Work otherwise complies with
-      the conditions stated in this License.
-
-   5. Submission of Contributions. Unless You explicitly state otherwise,
-      any Contribution intentionally submitted for inclusion in the Work
-      by You to the Licensor shall be under the terms and conditions of
-      this License, without any additional terms or conditions.
-      Notwithstanding the above, nothing herein shall supersede or modify
-      the terms of any separate license agreement you may have executed
-      with Licensor regarding such Contributions.
-
-   6. Trademarks. This License does not grant permission to use the trade
-      names, trademarks, service marks, or product names of the Licensor,
-      except as required for reasonable and customary use in describing the
-      origin of the Work and reproducing the content of the NOTICE file.
-
-   7. Disclaimer of Warranty. Unless required by applicable law or
-      agreed to in writing, Licensor provides the Work (and each
-      Contributor provides its Contributions) on an "AS IS" BASIS,
-      WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
-      implied, including, without limitation, any warranties or conditions
-      of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A
-      PARTICULAR PURPOSE. You are solely responsible for determining the
-      appropriateness of using or redistributing the Work and assume any
-      risks associated with Your exercise of permissions under this License.
-
-   8. Limitation of Liability. In no event and under no legal theory,
-      whether in tort (including negligence), contract, or otherwise,
-      unless required by applicable law (such as deliberate and grossly
-      negligent acts) or agreed to in writing, shall any Contributor be
-      liable to You for damages, including any direct, indirect, special,
-      incidental, or consequential damages of any character arising as a
-      result of this License or out of the use or inability to use the
-      Work (including but not limited to damages for loss of goodwill,
-      work stoppage, computer failure or malfunction, or any and all
-      other commercial damages or losses), even if such Contributor
-      has been advised of the possibility of such damages.
-
-   9. Accepting Warranty or Additional Liability. While redistributing
-      the Work or Derivative Works thereof, You may choose to offer,
-      and charge a fee for, acceptance of support, warranty, indemnity,
-      or other liability obligations and/or rights consistent with this
-      License. However, in accepting such obligations, You may act only
-      on Your own behalf and on Your sole responsibility, not on behalf
-      of any other Contributor, and only if You agree to indemnify,
-      defend, and hold each Contributor harmless for any liability
-      incurred by, or claims asserted against, such Contributor by reason
-      of your accepting any such warranty or additional liability.
-
-   END OF TERMS AND CONDITIONS
-
-   APPENDIX: How to apply the Apache License to your work.
-
-      To apply the Apache License to your work, attach the following
-      boilerplate notice, with the fields enclosed by brackets "[]"
-      replaced with your own identifying information. (Don't include
-      the brackets!)  The text should be enclosed in the appropriate
-      comment syntax for the file format. We also recommend that a
-      file or class name and description of purpose be included on the
-      same "printed page" as the copyright notice for easier
-      identification within third-party archives.
-
-   Copyright [yyyy] [name of copyright owner]
-
-   Licensed under the Apache License, Version 2.0 (the "License");
-   you may not use this file except in compliance with the License.
-   You may obtain a copy of the License at
-
-       http://www.apache.org/licenses/LICENSE-2.0
-
-   Unless required by applicable law or agreed to in writing, software
-   distributed under the License is distributed on an "AS IS" BASIS,
-   WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
-   See the License for the specific language governing permissions and
-   limitations under the License.
-
-
-
-Some code in src/java/org/apache/lucene/util/UnicodeUtil.java was
-derived from unicode conversion examples available at
-http://www.unicode.org/Public/PROGRAMS/CVTUTF.  Here is the copyright
-from those sources:
-
-/*
- * Copyright 2001-2004 Unicode, Inc.
- * 
- * Disclaimer
- * 
- * This source code is provided as is by Unicode, Inc. No claims are
- * made as to fitness for any particular purpose. No warranties of any
- * kind are expressed or implied. The recipient agrees to determine
- * applicability of information provided. If this file has been
- * purchased on magnetic or optical media from Unicode, Inc., the
- * sole remedy for any claim will be exchange of defective media
- * within 90 days of receipt.
- * 
- * Limitations on Rights to Redistribute This Code
- * 
- * Unicode, Inc. hereby grants the right to freely use the information
- * supplied in this file in the creation of products supporting the
- * Unicode Standard, and to make copies of this file in any form
- * for internal or external distribution as long as this notice
- * remains attached.
- */
-
-
-Some code in src/java/org/apache/lucene/util/ArrayUtil.java was
-derived from Python 2.4.2 sources available at
-http://www.python.org. Full license is here:
-
-  http://www.python.org/download/releases/2.4.2/license/
-
-

+ 0 - 12
stylesheets/lfs-xsl/docbook-xsl-1.78.1/extensions/NOTICE.txt

@@ -1,12 +0,0 @@
-The webhelpindexer is released under the Apache 2.0 license and
-includes software from other projects.
-
-The webhelpindexer was originally developed by N. Quaine and released
-under a MIT/BSD-style license. See LICENSE.txt.
-
-This product includes software developed by The Apache Software
-Foundation (http://www.apache.org/). See LICENSE.txt.
-
-This product also includes software released as part of the Snowball
-project maintained by Martin Porter and Richard Boulton released under
-a BSD-style license: http://snowball.tartarus.org/

+ 0 - 52
stylesheets/lfs-xsl/docbook-xsl-1.78.1/extensions/README.LIBXSLT

@@ -1,52 +0,0 @@
-----------------------------------------------------------------------
-              README file for the libxslt extensions
-----------------------------------------------------------------------
-$Id: README.LIBXSLT 7877 2008-03-08 04:07:52Z xmldoc $
-
-These are XSLT extensions written in Python for use with the DocBook XML 
-stylesheets and the libxslt library[1].
-
-Currently, the only available extension is a function for adjusting column
-widths in tables. For more information, see the section describing the 
-equivalent Java extension in "DocBook XSL: The Complete Guide"[2].
-
-----------------------------------------------------------------------
-Preparations
-----------------------------------------------------------------------
-In addition to libxml2 and libxslt, the following software needs to 
-be installed before you start using the extensions:
-
-1. Python[3].
-
-2. Python bindings for libxml2/libxslt. Most distributions of 
-   libxml2/libxslt for Unix/Linux include these bindings.
-   A native Windows port is provided by Stéphane Bidoul[4].
-
-----------------------------------------------------------------------
-Installation of the extensions
-----------------------------------------------------------------------
-No special installation step is needed.
-
-----------------------------------------------------------------------
-How to use the extensions
-----------------------------------------------------------------------
-Instead of using xsltproc, you run a Python program (xslt.py). The 
-command has this general form:
-
-python xslt.py xmlfile xslfile [outputfile] [param1=val1 [param2=val]...]
-
-Modify paths, filenames, and parameters as needed. Make sure to set 
-the "use.extensions" and "tablecolumns.extension" parameters to 1.
-
-----------------------------------------------------------------------
-Manifest
-----------------------------------------------------------------------
-README.LIBXSLT   This file
-xslt.py          Executable script file
-docbook.py       Module that implements extensions
-
-----------------------------------------------------------------------
-[1] http://xmlsoft.org/XSLT
-[2] http://www.sagehill.net/docbookxsl/ColumnWidths.html
-[3] http://www.python.org/download
-[4] http://users.skynet.be/sbi/libxml-python

+ 0 - 4
stylesheets/lfs-xsl/docbook-xsl-1.78.1/extensions/README.txt

@@ -1,4 +0,0 @@
-See webhelp/docs/index.html for more information about the webhelp
-indexer and the webhelp output format. See webhelp/docs/index.html for
-more information about the webhelp indexer and the webhelp output
-format.

+ 0 - 239
stylesheets/lfs-xsl/docbook-xsl-1.78.1/extensions/docbook.py

@@ -1,239 +0,0 @@
-# docbook.py: extension module
-# $Id: docbook.py 8353 2009-03-17 16:57:50Z mzjn $
-
-import sys
-import string
-import libxml2
-import libxslt
-import re
-import math
-
-# Some globals
-pixelsPerInch = 96.0
-unitHash = { 'in': pixelsPerInch,
-             'cm': pixelsPerInch / 2.54,
-             'mm': pixelsPerInch / 25.4,
-             'pc': (pixelsPerInch / 72.0) * 12,
-             'pt': pixelsPerInch / 72.0,
-             'px': 1 }
-
-# ======================================================================
-
-def adjustColumnWidths(ctx, nodeset):
-    #
-    # Small check to verify the context is correcly accessed
-    #
-    try:
-        pctxt = libxslt.xpathParserContext(_obj=ctx)
-        ctxt = pctxt.context()
-        tctxt = ctxt.transformContext()
-    except:
-        pass
-
-    # Get the nominal table width
-    varString = lookupVariable(tctxt, "nominal.table.width", None)
-    if varString == None:
-        nominalWidth = 6 * pixelsPerInch;
-    else:
-        nominalWidth = convertLength(varString);
-
-    # Get the requested table width
-    tableWidth = lookupVariable(tctxt, "table.width", "100%")
-
-    foStylesheet = (tctxt.variableLookup("stylesheet.result.type", None) == "fo")
-
-    relTotal = 0
-    relParts = []
-
-    absTotal = 0
-    absParts = []
-
-    colgroup = libxml2.xmlNode(_obj = nodeset[0])
-    # If this is an foStylesheet, we've been passed a list of fo:table-columns.
-    # Otherwise we've been passed a colgroup that contains a list of cols.
-    if foStylesheet:
-        colChildren = colgroup
-    else:
-        colChildren = colgroup.children
-
-    col = colChildren
-    while col != None:
-        if foStylesheet:
-            width = col.prop("column-width")
-        else:
-            width = col.prop("width")
-
-        if width == None:
-            width = "1*"
-
-        relPart = 0.0
-        absPart = 0.0
-        starPos = string.find(width, "*")
-        if starPos >= 0:
-            relPart, absPart = string.split(width, "*", 2)
-            relPart = float(relPart)
-            relTotal = relTotal + float(relPart)
-        else:
-            absPart = width
-
-        pixels = convertLength(absPart)
-        absTotal = absTotal + pixels
-
-        relParts.append(relPart)
-        absParts.append(pixels)
-
-        col = col.next
-
-    # Ok, now we have the relative widths and absolute widths in
-    # two parallel arrays.
-    #
-    # - If there are no relative widths, output the absolute widths
-    # - If there are no absolute widths, output the relative widths
-    # - If there are a mixture of relative and absolute widths,
-    #   - If the table width is absolute, turn these all into absolute
-    #     widths.
-    #   - If the table width is relative, turn these all into absolute
-    #     widths in the nominalWidth and then turn them back into
-    #     percentages.
-
-    widths = []
-
-    if relTotal == 0:
-        for absPart in absParts:
-            if foStylesheet:
-                inches = absPart / pixelsPerInch
-                widths.append("%4.2fin" % inches)
-            else:
-                widths.append("%d" % absPart)
-    elif absTotal == 0:
-        for relPart in relParts:
-            rel = relPart / relTotal * 100
-            widths.append(rel)
-        widths = correctRoundingError(widths)
-    else:
-        pixelWidth = nominalWidth
-        if string.find(tableWidth, "%") < 0:
-            pixelWidth = convertLength(tableWidth)
-
-        if pixelWidth <= absTotal:
-            print "Table is wider than table width"
-        else:
-            pixelWidth = pixelWidth - absTotal
-
-        absTotal = 0
-        for count in range(len(relParts)):
-            rel = relParts[count] / relTotal * pixelWidth
-            relParts[count] = rel + absParts[count]
-            absTotal = absTotal + rel + absParts[count]
-
-        if string.find(tableWidth, "%") < 0:
-            for count in range(len(relParts)):
-                if foStylesheet:
-                    pixels = relParts[count]
-                    inches = pixels / pixelsPerInch
-                    widths.append("%4.2fin" % inches)
-                else:
-                    widths.append(relParts[count])
-        else:
-            for count in range(len(relParts)):
-                rel = relParts[count] / absTotal * 100
-                widths.append(rel)
-            widths = correctRoundingError(widths)
-
-    # Danger, Will Robinson! In-place modification of the result tree!
-    # Side-effect free? We don' need no steenkin' side-effect free!
-    count = 0
-    col = colChildren
-    while col != None:
-        if foStylesheet:
-            col.setProp("column-width", widths[count])
-        else:
-            col.setProp("width", widths[count])
-
-        count = count+1
-        col = col.next
-
-    return nodeset
-
-def convertLength(length):
-    # Given "3.4in" return the width in pixels
-    global pixelsPerInch
-    global unitHash
-
-    m = re.search('([+-]?[\d\.]+)(\S+)', length)
-    if m != None and m.lastindex > 1:
-        unit = pixelsPerInch
-        if unitHash.has_key(m.group(2)):
-            unit = unitHash[m.group(2)]
-        else:
-            print "Unrecognized length: " + m.group(2)
-
-        pixels = unit * float(m.group(1))
-    else:
-        pixels = 0
-
-    return pixels
-
-def correctRoundingError(floatWidths):
-    # The widths are currently floating point numbers, we have to truncate
-    # them back to integers and then distribute the error so that they sum
-    # to exactly 100%.
-
-    totalWidth = 0
-    widths = []
-    for width in floatWidths:
-        width = math.floor(width)
-        widths.append(width)
-        totalWidth = totalWidth + math.floor(width)
-
-    totalError = 100 - totalWidth
-    columnError = totalError / len(widths)
-    error = 0
-    for count in range(len(widths)):
-        width = widths[count]
-        error = error + columnError
-        if error >= 1.0:
-            adj = math.floor(error)
-            error = error - adj
-            widths[count] = "%d%%" % (width + adj)
-        else:
-            widths[count] = "%d%%" % width
-
-    return widths
-
-def lookupVariable(tctxt, varName, default):
-    varString = tctxt.variableLookup(varName, None)
-    if varString == None:
-        return default
-
-    # If it's a list, get the first element
-    if type(varString) == type([]):
-        varString = varString[0]
-
-    # If it's not a string, it must be a node, get its content
-    if type(varString) != type(""):
-        varString = varString.content
-
-    return varString
-
-# ======================================================================
-# Random notes...
-
-#once you have a node which is a libxml2 python xmlNode wrapper all common
-#operations are possible:
-#   .children .last .parent .next .prev .doc for navigation
-#   .content .type for introspection
-#   .prop("attribute_name") to lookup attribute values
-
-#    # Now make a nodeset to return
-#    # Danger, Will Robinson! This creates a memory leak!
-#    newDoc = libxml2.newDoc("1.0")
-#    newColGroup = newDoc.newDocNode(None, "colgroup", None)
-#    newDoc.addChild(newColGroup)
-#    col = colgroup.children
-#    while col != None:
-#        newCol = newDoc.newDocNode(None, "col", None)
-#        newCol.copyPropList(col);
-#        newCol.setProp("width", "4")
-#        newColGroup.addChild(newCol)
-#        col = col.next

BIN
stylesheets/lfs-xsl/docbook-xsl-1.78.1/extensions/lucene-analyzers-3.0.0.jar


BIN
stylesheets/lfs-xsl/docbook-xsl-1.78.1/extensions/lucene-core-3.0.0.jar


BIN
stylesheets/lfs-xsl/docbook-xsl-1.78.1/extensions/saxon65.jar


BIN
stylesheets/lfs-xsl/docbook-xsl-1.78.1/extensions/tagsoup-1.2.1.jar


BIN
stylesheets/lfs-xsl/docbook-xsl-1.78.1/extensions/webhelpindexer.jar


BIN
stylesheets/lfs-xsl/docbook-xsl-1.78.1/extensions/xalan27.jar


+ 0 - 84
stylesheets/lfs-xsl/docbook-xsl-1.78.1/extensions/xslt.py

@@ -1,84 +0,0 @@
-#!/usr/bin/python -u
-# $Id: xslt.py 8353 2009-03-17 16:57:50Z mzjn $
-
-import sys
-import libxml2
-import libxslt
-from docbook import adjustColumnWidths
-
-# Check the arguments
-usage = "Usage: %s xmlfile.xml xslfile.xsl [outputfile] [param1=val [param2=val]...]" % sys.argv[0]
-
-xmlfile = None
-xslfile = None
-outfile = "-"
-params  = {}
-
-try:
-    xmlfile = sys.argv[1]
-    xslfile = sys.argv[2]
-except IndexError:
-    print usage
-    sys.exit(1)
-
-def quote(astring):
-    if astring.find("'") < 0:
-        return "'" + astring + "'"
-    else:
-        return '"' + astring + '"'
-
-try:
-    outfile = sys.argv[3]
-    if outfile.find("=") > 0:
-        name, value = outfile.split("=", 2)
-        params[name] = quote(value)
-        outfile = None
-
-    count = 4
-    while (sys.argv[count]):
-        try:
-            name, value = sys.argv[count].split("=", 2)
-            if params.has_key(name):
-                print "Warning: '%s' re-specified; replacing value" % name
-            params[name] = quote(value)
-        except ValueError:
-            print "Invalid parameter specification: '" + sys.argv[count] + "'"
-            print usage
-            sys.exit(1)
-        count = count+1
-except IndexError:
-    pass
-
-# ======================================================================
-# Memory debug specific
-# libxml2.debugMemory(1)
-
-# Setup environment
-libxml2.lineNumbersDefault(1)
-libxml2.substituteEntitiesDefault(1)
-libxslt.registerExtModuleFunction("adjustColumnWidths",
-                                  "http://nwalsh.com/xslt/ext/xsltproc/python/Table",
-                                  adjustColumnWidths)
-
-# Initialize and run
-styledoc = libxml2.parseFile(xslfile)
-style = libxslt.parseStylesheetDoc(styledoc)
-doc = libxml2.parseFile(xmlfile)
-result = style.applyStylesheet(doc, params)
-
-# Save the result
-if outfile:
-    style.saveResultToFilename(outfile, result, 0)
-else:
-    print result
-
-# Free things up
-style.freeStylesheet()
-doc.freeDoc()
-result.freeDoc()
-
-# Memory debug specific
-#libxslt.cleanup()
-#if libxml2.debugMemory(1) != 0:
-#    print "Memory leak %d bytes" % (libxml2.debugMemory(1))
-#    libxml2.dumpMemory()

+ 0 - 16
stylesheets/lfs-xsl/docbook-xsl-1.78.1/highlighting/README

@@ -1,16 +0,0 @@
-To use the syntax higlighting extension with DocBook-XSL 1.74.3+, you must:
-1. Use a processor that works with the extension: Saxon 6 or Xalan-J.
-2. Add the latest version of xslthl-2.X.X.jar to your classpath.
-3. Set the highlight.source parameter to 1.
-4. Import into your customization one of the following stylesheet module:
-  * html/highlight.xsl
-  * xhtml/highlight.xsl
-  * xhtml-1_1/highlight.xsl
-  * fo/highlight.xsl
-5. Use that customiztion layer.
-
-
-Note: Saxon 8.5 or later is also supported, but since it is an XSLT 2.0
-processor it is not guaranteed to work with DocBook-XSL in all
-circumstances. 
-

+ 0 - 95
stylesheets/lfs-xsl/docbook-xsl-1.78.1/highlighting/bourne-hl.xml

@@ -1,95 +0,0 @@
-<?xml version="1.0" encoding="utf-8"?>
-<!--
-
-Syntax highlighting definition for SH
-
-xslthl - XSLT Syntax Highlighting
-http://sourceforge.net/projects/xslthl/
-Copyright (C) 2010 Mathieu Malaterre
-
-This software is provided 'as-is', without any express or implied
-warranty.  In no event will the authors be held liable for any damages
-arising from the use of this software.
-
-Permission is granted to anyone to use this software for any purpose,
-including commercial applications, and to alter it and redistribute it
-freely, subject to the following restrictions:
-
-1. The origin of this software must not be misrepresented; you must not
-   claim that you wrote the original software. If you use this software
-   in a product, an acknowledgment in the product documentation would be
-   appreciated but is not required.
-2. Altered source versions must be plainly marked as such, and must not be
-   misrepresented as being the original software.
-3. This notice may not be removed or altered from any source distribution.
-
--->
-<highlighters>
-	<highlighter type="oneline-comment">#</highlighter>
-	<highlighter type="heredoc">
-		<start>&lt;&lt;</start>
-		<quote>'</quote>
-		<quote>"</quote>
-		<flag>-</flag>
-		<noWhiteSpace />
-		<looseTerminator />
-	</highlighter>
-	<highlighter type="string">
-		<string>"</string>
-		<escape>\</escape>
-	</highlighter>
-	<highlighter type="string">
-		<string>'</string>
-		<escape>\</escape>
-		<spanNewLines />
-	</highlighter>
-	<highlighter type="hexnumber">
-		<prefix>0x</prefix>
-		<ignoreCase />
-	</highlighter>
-	<highlighter type="number">
-		<point>.</point>
-		<pointStarts />
-		<ignoreCase />
-	</highlighter>
-	<highlighter type="keywords">
-		<!-- reserved words -->
-		<keyword>if</keyword>
-		<keyword>then</keyword>
-		<keyword>else</keyword>
-		<keyword>elif</keyword>
-		<keyword>fi</keyword>
-		<keyword>case</keyword>
-		<keyword>esac</keyword>
-		<keyword>for</keyword>
-		<keyword>while</keyword>
-		<keyword>until</keyword>
-		<keyword>do</keyword>
-		<keyword>done</keyword>
-		<!-- built-ins -->
-		<keyword>exec</keyword>
-		<keyword>shift</keyword>
-		<keyword>exit</keyword>
-		<keyword>times</keyword>
-		<keyword>break</keyword>
-		<keyword>export</keyword>
-		<keyword>trap</keyword>
-		<keyword>continue</keyword>
-		<keyword>readonly</keyword>
-		<keyword>wait</keyword>
-		<keyword>eval</keyword>
-		<keyword>return</keyword>
-		<!-- other commands -->
-		<keyword>cd</keyword>
-		<keyword>echo</keyword>
-		<keyword>hash</keyword>
-		<keyword>pwd</keyword>
-		<keyword>read</keyword>
-		<keyword>set</keyword>
-		<keyword>test</keyword>
-		<keyword>type</keyword>
-		<keyword>ulimit</keyword>
-		<keyword>umask</keyword>
-		<keyword>unset</keyword>
-	</highlighter>
-</highlighters>

+ 0 - 117
stylesheets/lfs-xsl/docbook-xsl-1.78.1/highlighting/c-hl.xml

@@ -1,117 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<!-- 
-Syntax highlighting definition for C
-	
-xslthl - XSLT Syntax Highlighting
-http://sourceforge.net/projects/xslthl/
-Copyright (C) 2005-2008 Michal Molhanec, Jirka Kosek, Michiel Hendriks
-
-This software is provided 'as-is', without any express or implied
-warranty.  In no event will the authors be held liable for any damages
-arising from the use of this software.
-
-Permission is granted to anyone to use this software for any purpose,
-including commercial applications, and to alter it and redistribute it
-freely, subject to the following restrictions:
-
-1. The origin of this software must not be misrepresented; you must not
-   claim that you wrote the original software. If you use this software
-   in a product, an acknowledgment in the product documentation would be
-   appreciated but is not required.
-2. Altered source versions must be plainly marked as such, and must not be
-   misrepresented as being the original software.
-3. This notice may not be removed or altered from any source distribution.
-
-Michal Molhanec <mol1111 at users.sourceforge.net>
-Jirka Kosek <kosek at users.sourceforge.net>
-Michiel Hendriks <elmuerte at users.sourceforge.net>
--->
-<highlighters>
-	<highlighter type="multiline-comment">
-		<start>/**</start>
-		<end>*/</end>
-		<style>doccomment</style>
-	</highlighter>
-	<highlighter type="oneline-comment">
-		<start><![CDATA[/// ]]></start>
-		<style>doccomment</style>
-	</highlighter>
-	<highlighter type="multiline-comment">
-		<start>/*</start>
-		<end>*/</end>
-	</highlighter>
-	<highlighter type="oneline-comment">//</highlighter>
-	<highlighter type="oneline-comment">
-		<!-- use the online-comment highlighter to detect directives -->
-		<start>#</start>
-		<lineBreakEscape>\</lineBreakEscape>
-		<style>directive</style>
-		<solitary />
-	</highlighter>
-	<highlighter type="string">
-		<string>"</string>
-		<escape>\</escape>
-	</highlighter>
-	<highlighter type="string">
-		<string>'</string>
-		<escape>\</escape>
-	</highlighter>
-	<highlighter type="hexnumber">
-		<prefix>0x</prefix>
-		<suffix>ul</suffix>
-		<suffix>lu</suffix>
-		<suffix>u</suffix>
-		<suffix>l</suffix>
-		<ignoreCase />
-	</highlighter>
-	<highlighter type="number">
-		<point>.</point>
-		<pointStarts />
-		<exponent>e</exponent>
-		<suffix>ul</suffix>
-		<suffix>lu</suffix>
-		<suffix>u</suffix>
-		<suffix>f</suffix>
-		<suffix>l</suffix>
-		<ignoreCase />
-	</highlighter>
-	<highlighter type="keywords">
-		<keyword>auto</keyword>
-		<keyword>_Bool</keyword>
-		<keyword>break</keyword>
-		<keyword>case</keyword>
-		<keyword>char</keyword>
-		<keyword>_Complex</keyword>
-		<keyword>const</keyword>
-		<keyword>continue</keyword>
-		<keyword>default</keyword>
-		<keyword>do</keyword>
-		<keyword>double</keyword>
-		<keyword>else</keyword>
-		<keyword>enum</keyword>
-		<keyword>extern</keyword>
-		<keyword>float</keyword>
-		<keyword>for</keyword>
-		<keyword>goto</keyword>
-		<keyword>if</keyword>
-		<keyword>_Imaginary</keyword>
-		<keyword>inline</keyword>
-		<keyword>int</keyword>
-		<keyword>long</keyword>
-		<keyword>register</keyword>
-		<keyword>restrict</keyword>
-		<keyword>return</keyword>
-		<keyword>short</keyword>
-		<keyword>signed</keyword>
-		<keyword>sizeof</keyword>
-		<keyword>static</keyword>
-		<keyword>struct</keyword>
-		<keyword>switch</keyword>
-		<keyword>typedef</keyword>
-		<keyword>union</keyword>
-		<keyword>unsigned</keyword>
-		<keyword>void</keyword>
-		<keyword>volatile</keyword>
-		<keyword>while</keyword>
-	</highlighter>
-</highlighters>

+ 0 - 187
stylesheets/lfs-xsl/docbook-xsl-1.78.1/highlighting/cmake-hl.xml

@@ -1,187 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<!--
-
-Syntax highlighting definition for CMake
-Copyright (c) 2010 Mathieu Malaterre
-
-This software is provided 'as-is', without any express or implied
-warranty. In no event will the authors be held liable for any damages
-arising from the use of this software.
-
-Permission is granted to anyone to use this software for any purpose,
-including commercial applications, and to alter it and redistribute it
-freely, subject to the following restrictions:
-
-1. The origin of this software must not be misrepresented; you must not
-claim that you wrote the original software. If you use this software
-in a product, an acknowledgment in the product documentation would be
-appreciated but is not required.
-2. Altered source versions must be plainly marked as such, and must not be
-misrepresented as being the original software.
-3. This notice may not be removed or altered from any source distribution.
-
--->
-<highlighters>
-	<highlighter type="oneline-comment">#</highlighter>
-	<highlighter type="string">
-		<string>"</string>
-		<endString>"</endString>
-		<spanNewLines />
-	</highlighter>
-	<highlighter type="hexnumber">
-		<prefix>0x</prefix>
-		<suffix>l</suffix>
-		<ignoreCase />
-		<style>string</style>
-	</highlighter>
-	<highlighter type="number">
-		<point>.</point>
-		<ignoreCase />
-		<style>string</style>
-	</highlighter>
-	<highlighter type="keywords">
-		<!-- system variable -->
-		<keyword>WIN32</keyword>
-		<keyword>UNIX</keyword>
-		<keyword>APPLE</keyword>
-		<keyword>CYGWIN</keyword>
-		<keyword>BORLAND</keyword>
-		<keyword>MINGW</keyword>
-		<keyword>MSVC</keyword>
-		<keyword>MSVC_IDE</keyword>
-		<keyword>MSVC60</keyword>
-		<keyword>MSVC70</keyword>
-		<keyword>MSVC71</keyword>
-		<keyword>MSVC80</keyword>
-		<style>attribute</style>
-	</highlighter>
-	<highlighter type="keywords">
-		<!-- operators -->
-		<keyword>AND</keyword>
-		<keyword>BOOL</keyword>
-		<keyword>CACHE</keyword>
-		<keyword>COMMAND</keyword>
-		<keyword>DEFINED</keyword>
-		<keyword>DOC</keyword>
-		<keyword>EQUAL</keyword>
-		<keyword>EXISTS</keyword>
-		<keyword>FALSE</keyword>
-		<keyword>GREATER</keyword>
-		<keyword>INTERNAL</keyword>
-		<keyword>LESS</keyword>
-		<keyword>MATCHES</keyword>
-		<keyword>NAME</keyword>
-		<keyword>NAMES</keyword>
-		<keyword>NAME_WE</keyword>
-		<keyword>NOT</keyword>
-		<keyword>OFF</keyword>
-		<keyword>ON</keyword>
-		<keyword>OR</keyword>
-		<keyword>PATH</keyword>
-		<keyword>PATHS</keyword>
-		<keyword>PROGRAM</keyword>
-		<keyword>STREQUAL</keyword>
-		<keyword>STRGREATER</keyword>
-		<keyword>STRING</keyword>
-		<keyword>STRLESS</keyword>
-		<keyword>TRUE</keyword>
-		<!-- color in blue -->
-		<!--style>doccomment</style> -->
-		<style>keyword</style>
-	</highlighter>
-	<highlighter type="keywords">
-		<!-- statement -->
-		<keyword>ADD_CUSTOM_COMMAND</keyword>
-		<keyword>ADD_CUSTOM_TARGET</keyword>
-		<keyword>ADD_DEFINITIONS</keyword>
-		<keyword>ADD_DEPENDENCIES</keyword>
-		<keyword>ADD_EXECUTABLE</keyword>
-		<keyword>ADD_LIBRARY</keyword>
-		<keyword>ADD_SUBDIRECTORY</keyword>
-		<keyword>ADD_TEST</keyword>
-		<keyword>AUX_SOURCE_DIRECTORY</keyword>
-		<keyword>BUILD_COMMAND</keyword>
-		<keyword>BUILD_NAME</keyword>
-		<keyword>CMAKE_MINIMUM_REQUIRED</keyword>
-		<keyword>CONFIGURE_FILE</keyword>
-		<keyword>CREATE_TEST_SOURCELIST</keyword>
-		<keyword>ELSE</keyword>
-		<keyword>ELSEIF</keyword>
-		<keyword>ENABLE_LANGUAGE</keyword>
-		<keyword>ENABLE_TESTING</keyword>
-		<keyword>ENDFOREACH</keyword>
-		<keyword>ENDIF</keyword>
-		<keyword>ENDWHILE</keyword>
-		<keyword>EXEC_PROGRAM</keyword>
-		<keyword>EXECUTE_PROCESS</keyword>
-		<keyword>EXPORT_LIBRARY_DEPENDENCIES</keyword>
-		<keyword>FILE</keyword>
-		<keyword>FIND_FILE</keyword>
-		<keyword>FIND_LIBRARY</keyword>
-		<keyword>FIND_PACKAGE</keyword>
-		<keyword>FIND_PATH</keyword>
-		<keyword>FIND_PROGRAM</keyword>
-		<keyword>FLTK_WRAP_UI</keyword>
-		<keyword>FOREACH</keyword>
-		<keyword>GET_CMAKE_PROPERTY</keyword>
-		<keyword>GET_DIRECTORY_PROPERTY</keyword>
-		<keyword>GET_FILENAME_COMPONENT</keyword>
-		<keyword>GET_SOURCE_FILE_PROPERTY</keyword>
-		<keyword>GET_TARGET_PROPERTY</keyword>
-		<keyword>GET_TEST_PROPERTY</keyword>
-		<keyword>IF</keyword>
-		<keyword>INCLUDE</keyword>
-		<keyword>INCLUDE_DIRECTORIES</keyword>
-		<keyword>INCLUDE_EXTERNAL_MSPROJECT</keyword>
-		<keyword>INCLUDE_REGULAR_EXPRESSION</keyword>
-		<keyword>INSTALL</keyword>
-		<keyword>INSTALL_FILES</keyword>
-		<keyword>INSTALL_PROGRAMS</keyword>
-		<keyword>INSTALL_TARGETS</keyword>
-		<keyword>LINK_DIRECTORIES</keyword>
-		<keyword>LINK_LIBRARIES</keyword>
-		<keyword>LIST</keyword>
-		<keyword>LOAD_CACHE</keyword>
-		<keyword>LOAD_COMMAND</keyword>
-		<keyword>MACRO</keyword>
-		<keyword>MAKE_DIRECTORY</keyword>
-		<keyword>MARK_AS_ADVANCED</keyword>
-		<keyword>MATH</keyword>
-		<keyword>MESSAGE</keyword>
-		<keyword>OPTION</keyword>
-		<keyword>OUTPUT_REQUIRED_FILES</keyword>
-		<keyword>PROJECT</keyword>
-		<keyword>QT_WRAP_CPP</keyword>
-		<keyword>QT_WRAP_UI</keyword>
-		<keyword>REMOVE</keyword>
-		<keyword>REMOVE_DEFINITIONS</keyword>
-		<keyword>SEPARATE_ARGUMENTS</keyword>
-		<keyword>SET</keyword>
-		<keyword>SET_DIRECTORY_PROPERTIES</keyword>
-		<keyword>SET_SOURCE_FILES_PROPERTIES</keyword>
-		<keyword>SET_TARGET_PROPERTIES</keyword>
-		<keyword>SET_TESTS_PROPERTIES</keyword>
-		<keyword>SITE_NAME</keyword>
-		<keyword>SOURCE_GROUP</keyword>
-		<keyword>STRING</keyword>
-		<keyword>SUBDIR_DEPENDS</keyword>
-		<keyword>SUBDIRS</keyword>
-		<keyword>TARGET_LINK_LIBRARIES</keyword>
-		<keyword>TRY_COMPILE</keyword>
-		<keyword>TRY_RUN</keyword>
-		<keyword>USE_MANGLED_MESA</keyword>
-		<keyword>UTILITY_SOURCE</keyword>
-		<keyword>VARIABLE_REQUIRES</keyword>
-		<keyword>VTK_MAKE_INSTANTIATOR</keyword>
-		<keyword>VTK_WRAP_JAVA</keyword>
-		<keyword>VTK_WRAP_PYTHON</keyword>
-		<keyword>VTK_WRAP_TCL</keyword>
-		<keyword>WHILE</keyword>
-		<keyword>WRITE_FILE</keyword>
-		<keyword>ENDMACRO</keyword>
-		<ignoreCase />
-		<beginChars>()</beginChars>
-		<partChars>()</partChars>
-		<style>directive</style>
-	</highlighter>
-</highlighters>

+ 0 - 120
stylesheets/lfs-xsl/docbook-xsl-1.78.1/highlighting/common.xsl

@@ -1,120 +0,0 @@
-<?xml version='1.0'?>
-<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
-
-		xmlns:s6hl="http://net.sf.xslthl/ConnectorSaxon6" 
-		xmlns:sbhl="http://net.sf.xslthl/ConnectorSaxonB" 
-		xmlns:xhl="http://net.sf.xslthl/ConnectorXalan"
-		xmlns:saxon6="http://icl.com/saxon" 
-		xmlns:saxonb="http://saxon.sf.net/" 
-		xmlns:xalan="http://xml.apache.org/xalan"
-		
-		xmlns:exsl="http://exslt.org/common"
-		xmlns:xslthl="http://xslthl.sf.net"
-		exclude-result-prefixes="exsl xslthl s6hl sbhl xhl"
-		version='1.0'>
-
-<!-- ********************************************************************
-     $Id: common.xsl 8257 2009-02-20 04:40:16Z abdelazer $
-     ********************************************************************
-
-     This file is part of the XSL DocBook Stylesheet distribution.
-     See ../README or http://docbook.sf.net/release/xsl/current/ for
-     and other information.
-
-     ******************************************************************** -->
-
-<!-- this construction is needed to have the saxon and xalan connectors working alongside each other -->
-<xalan:component prefix="xhl" functions="highlight"> 
-  <xalan:script lang="javaclass" src="xalan://net.sf.xslthl.ConnectorXalan" /> 
-</xalan:component> 
-
-<!-- for saxon 6 -->
-<saxon6:script implements-prefix="s6hl" language="java" src="java:net.sf.xslthl.ConnectorSaxon6" />
-
-<!-- for saxon 8.5 and later -->
-<saxonb:script implements-prefix="sbhl" language="java" src="java:net.sf.xslthl.ConnectorSaxonB" />
-
-
-<!-- You can override this template to do more complex mapping of
-     language attribute to highlighter language ID (see xslthl-config.xml) -->
-<xsl:template name="language.to.xslthl">
-  <xsl:param name="context"/>
-
-  <xsl:choose>
-    <xsl:when test="$context/@language != ''">
-      <xsl:value-of select="$context/@language"/>
-    </xsl:when>
-    <xsl:when test="$highlight.default.language != ''">
-      <xsl:value-of select="$highlight.default.language"/>
-    </xsl:when>
-  </xsl:choose>
-</xsl:template>
-
-<xsl:template name="apply-highlighting">
-  <xsl:choose>
-    <!-- Do we want syntax highlighting -->
-    <xsl:when test="$highlight.source != 0">
-      <xsl:variable name="language">
-	<xsl:call-template name="language.to.xslthl">
-	  <xsl:with-param name="context" select="."/>
-	</xsl:call-template>
-      </xsl:variable>
-      <xsl:choose>
-	<xsl:when test="$language != ''">
-	  <xsl:variable name="content">
-	    <xsl:apply-templates/>
-	  </xsl:variable>
-	  <xsl:choose>
-	    <xsl:when test="function-available('s6hl:highlight')">
-	      <xsl:apply-templates select="s6hl:highlight($language, exsl:node-set($content), $highlight.xslthl.config)"
-				   mode="xslthl"/>
-	    </xsl:when>
-	    <xsl:when test="function-available('sbhl:highlight')">
-	      <xsl:apply-templates select="sbhl:highlight($language, exsl:node-set($content), $highlight.xslthl.config)"
-				   mode="xslthl"/>
-	    </xsl:when>
-	    <xsl:when test="function-available('xhl:highlight')">
-	      <xsl:apply-templates select="xhl:highlight($language, exsl:node-set($content), $highlight.xslthl.config)"
-				   mode="xslthl"/>
-	    </xsl:when>
-	    <xsl:otherwise>
-	      <xsl:copy-of select="$content"/>
-	    </xsl:otherwise>
-	  </xsl:choose>
-	</xsl:when>
-	<xsl:otherwise>
-	  <xsl:apply-templates/>
-	</xsl:otherwise>
-      </xsl:choose>
-    </xsl:when>
-    <!-- No syntax highlighting -->
-    <xsl:otherwise>
-      <xsl:apply-templates/>
-    </xsl:otherwise>
-  </xsl:choose>
-</xsl:template>
-
-<!-- A fallback when the specific style isn't recognized -->
-<xsl:template match="xslthl:*" mode="xslthl">
-  <xsl:message>
-    <xsl:text>unprocessed xslthl style: </xsl:text>
-    <xsl:value-of select="local-name(.)" />
-  </xsl:message>
-  <xsl:apply-templates mode="xslthl"/>
-</xsl:template>
-
-<!-- Copy over already produced markup (FO/HTML) -->
-<xsl:template match="node()" mode="xslthl" priority="-1">
-  <xsl:copy>
-    <xsl:apply-templates select="node()" mode="xslthl"/>
-  </xsl:copy>
-</xsl:template>
-
-<xsl:template match="*" mode="xslthl">
-  <xsl:copy>
-    <xsl:copy-of select="@*"/>
-    <xsl:apply-templates select="node()" mode="xslthl"/>
-  </xsl:copy>
-</xsl:template>
-
-</xsl:stylesheet>

+ 0 - 151
stylesheets/lfs-xsl/docbook-xsl-1.78.1/highlighting/cpp-hl.xml

@@ -1,151 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<!--
-
-Syntax highlighting definition for C++
-
-xslthl - XSLT Syntax Highlighting
-http://sourceforge.net/projects/xslthl/
-Copyright (C) 2005-2008 Michal Molhanec, Jirka Kosek, Michiel Hendriks
-
-This software is provided 'as-is', without any express or implied
-warranty.  In no event will the authors be held liable for any damages
-arising from the use of this software.
-
-Permission is granted to anyone to use this software for any purpose,
-including commercial applications, and to alter it and redistribute it
-freely, subject to the following restrictions:
-
-1. The origin of this software must not be misrepresented; you must not
-   claim that you wrote the original software. If you use this software
-   in a product, an acknowledgment in the product documentation would be
-   appreciated but is not required.
-2. Altered source versions must be plainly marked as such, and must not be
-   misrepresented as being the original software.
-3. This notice may not be removed or altered from any source distribution.
-
-Michal Molhanec <mol1111 at users.sourceforge.net>
-Jirka Kosek <kosek at users.sourceforge.net>
-Michiel Hendriks <elmuerte at users.sourceforge.net>
-
--->
-<highlighters>
-	<highlighter type="multiline-comment">
-		<start>/**</start>
-		<end>*/</end>
-		<style>doccomment</style>
-	</highlighter>
-	<highlighter type="oneline-comment">
-		<start><![CDATA[/// ]]></start>
-		<style>doccomment</style>
-	</highlighter>
-	<highlighter type="multiline-comment">
-		<start>/*</start>
-		<end>*/</end>
-	</highlighter>
-	<highlighter type="oneline-comment">//</highlighter>
-	<highlighter type="oneline-comment">
-		<!-- use the online-comment highlighter to detect directives -->
-		<start>#</start>
-		<lineBreakEscape>\</lineBreakEscape>
-		<style>directive</style>
-		<solitary/>
-	</highlighter>
-	<highlighter type="string">
-		<string>"</string>
-		<escape>\</escape>
-	</highlighter>
-	<highlighter type="string">
-		<string>'</string>
-		<escape>\</escape>
-	</highlighter>
-	<highlighter type="hexnumber">
-		<prefix>0x</prefix>
-		<suffix>ul</suffix>
-		<suffix>lu</suffix>
-		<suffix>u</suffix>
-		<suffix>l</suffix>
-		<ignoreCase />
-	</highlighter>
-	<highlighter type="number">
-		<point>.</point>
-		<pointStarts />
-		<exponent>e</exponent>
-		<suffix>ul</suffix>
-		<suffix>lu</suffix>
-		<suffix>u</suffix>
-		<suffix>f</suffix>
-		<suffix>l</suffix>
-		<ignoreCase />
-	</highlighter>
-	<highlighter type="keywords">
-		<!-- C keywords -->
-		<keyword>auto</keyword>
-		<keyword>_Bool</keyword>
-		<keyword>break</keyword>
-		<keyword>case</keyword>
-		<keyword>char</keyword>
-		<keyword>_Complex</keyword>
-		<keyword>const</keyword>
-		<keyword>continue</keyword>
-		<keyword>default</keyword>
-		<keyword>do</keyword>
-		<keyword>double</keyword>
-		<keyword>else</keyword>
-		<keyword>enum</keyword>
-		<keyword>extern</keyword>
-		<keyword>float</keyword>
-		<keyword>for</keyword>
-		<keyword>goto</keyword>
-		<keyword>if</keyword>
-		<keyword>_Imaginary</keyword>
-		<keyword>inline</keyword>
-		<keyword>int</keyword>
-		<keyword>long</keyword>
-		<keyword>register</keyword>
-		<keyword>restrict</keyword>
-		<keyword>return</keyword>
-		<keyword>short</keyword>
-		<keyword>signed</keyword>
-		<keyword>sizeof</keyword>
-		<keyword>static</keyword>
-		<keyword>struct</keyword>
-		<keyword>switch</keyword>
-		<keyword>typedef</keyword>
-		<keyword>union</keyword>
-		<keyword>unsigned</keyword>
-		<keyword>void</keyword>
-		<keyword>volatile</keyword>
-		<keyword>while</keyword>
-		<!-- C++ keywords -->
-		<keyword>asm</keyword>
-		<keyword>dynamic_cast</keyword>
-		<keyword>namespace</keyword>
-		<keyword>reinterpret_cast</keyword>
-		<keyword>try</keyword>
-		<keyword>bool</keyword>
-		<keyword>explicit</keyword>
-		<keyword>new</keyword>
-		<keyword>static_cast</keyword>
-		<keyword>typeid</keyword>
-		<keyword>catch</keyword>
-		<keyword>false</keyword>
-		<keyword>operator</keyword>
-		<keyword>template</keyword>
-		<keyword>typename</keyword>
-		<keyword>class</keyword>
-		<keyword>friend</keyword>
-		<keyword>private</keyword>
-		<keyword>this</keyword>
-		<keyword>using</keyword>
-		<keyword>const_cast</keyword>
-		<keyword>inline</keyword>
-		<keyword>public</keyword>
-		<keyword>throw</keyword>
-		<keyword>virtual</keyword>
-		<keyword>delete</keyword>
-		<keyword>mutable</keyword>
-		<keyword>protected</keyword>
-		<keyword>true</keyword>
-		<keyword>wchar_t</keyword>
-	</highlighter>
-</highlighters>

+ 0 - 194
stylesheets/lfs-xsl/docbook-xsl-1.78.1/highlighting/csharp-hl.xml

@@ -1,194 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<!--
-
-Syntax highlighting definition for C#
-
-xslthl - XSLT Syntax Highlighting
-http://sourceforge.net/projects/xslthl/
-Copyright (C) 2005-2008 Michal Molhanec, Jirka Kosek, Michiel Hendriks
-
-This software is provided 'as-is', without any express or implied
-warranty.  In no event will the authors be held liable for any damages
-arising from the use of this software.
-
-Permission is granted to anyone to use this software for any purpose,
-including commercial applications, and to alter it and redistribute it
-freely, subject to the following restrictions:
-
-1. The origin of this software must not be misrepresented; you must not
-   claim that you wrote the original software. If you use this software
-   in a product, an acknowledgment in the product documentation would be
-   appreciated but is not required.
-2. Altered source versions must be plainly marked as such, and must not be
-   misrepresented as being the original software.
-3. This notice may not be removed or altered from any source distribution.
-
-Michal Molhanec <mol1111 at users.sourceforge.net>
-Jirka Kosek <kosek at users.sourceforge.net>
-Michiel Hendriks <elmuerte at users.sourceforge.net>
-
--->
-<highlighters>
-	<highlighter type="multiline-comment">
-		<start>/**</start>
-		<end>*/</end>
-		<style>doccomment</style>
-	</highlighter>
-	<highlighter type="oneline-comment">
-		<start>///</start>
-		<style>doccomment</style>
-	</highlighter>
-	<highlighter type="multiline-comment">
-		<start>/*</start>
-		<end>*/</end>
-	</highlighter>
-	<highlighter type="oneline-comment">//</highlighter>
-	<highlighter type="annotation">
-		<!-- annotations are called (custom) "attributes" in .NET -->
-		<start>[</start>
-		<end>]</end>
-		<valueStart>(</valueStart>
-		<valueEnd>)</valueEnd>
-	</highlighter>
-	<highlighter type="oneline-comment">
-		<!-- C# supports a couple of directives -->
-		<start>#</start>
-		<lineBreakEscape>\</lineBreakEscape>
-		<style>directive</style>
-		<solitary/>
-	</highlighter>
-	<highlighter type="string">
-		<!-- strings starting with an "@" can span multiple lines -->
-		<string>@"</string>
-		<endString>"</endString>
-		<escape>\</escape>
-		<spanNewLines />
-	</highlighter>
-	<highlighter type="string">
-		<string>"</string>
-		<escape>\</escape>
-	</highlighter>
-	<highlighter type="string">
-		<string>'</string>
-		<escape>\</escape>
-	</highlighter>
-	<highlighter type="hexnumber">
-		<prefix>0x</prefix>
-		<suffix>ul</suffix>
-		<suffix>lu</suffix>
-		<suffix>u</suffix>
-		<suffix>l</suffix>
-		<ignoreCase />
-	</highlighter>
-	<highlighter type="number">
-		<point>.</point>
-		<pointStarts />
-		<exponent>e</exponent>
-		<suffix>ul</suffix>
-		<suffix>lu</suffix>
-		<suffix>u</suffix>
-		<suffix>f</suffix>
-		<suffix>d</suffix>
-		<suffix>m</suffix>
-		<suffix>l</suffix>
-		<ignoreCase />
-	</highlighter>
-	<highlighter type="keywords">
-		<keyword>abstract</keyword>
-		<keyword>as</keyword>
-		<keyword>base</keyword>
-		<keyword>bool</keyword>
-		<keyword>break</keyword>
-		<keyword>byte</keyword>
-		<keyword>case</keyword>
-		<keyword>catch</keyword>
-		<keyword>char</keyword>
-		<keyword>checked</keyword>
-		<keyword>class</keyword>
-		<keyword>const</keyword>
-		<keyword>continue</keyword>
-		<keyword>decimal</keyword>
-		<keyword>default</keyword>
-		<keyword>delegate</keyword>
-		<keyword>do</keyword>
-		<keyword>double</keyword>
-		<keyword>else</keyword>
-		<keyword>enum</keyword>
-		<keyword>event</keyword>
-		<keyword>explicit</keyword>
-		<keyword>extern</keyword>
-		<keyword>false</keyword>
-		<keyword>finally</keyword>
-		<keyword>fixed</keyword>
-		<keyword>float</keyword>
-		<keyword>for</keyword>
-		<keyword>foreach</keyword>
-		<keyword>goto</keyword>
-		<keyword>if</keyword>
-		<keyword>implicit</keyword>
-		<keyword>in</keyword>
-		<keyword>int</keyword>
-		<keyword>interface</keyword>
-		<keyword>internal</keyword>
-		<keyword>is</keyword>
-		<keyword>lock</keyword>
-		<keyword>long</keyword>
-		<keyword>namespace</keyword>
-		<keyword>new</keyword>
-		<keyword>null</keyword>
-		<keyword>object</keyword>
-		<keyword>operator</keyword>
-		<keyword>out</keyword>
-		<keyword>override</keyword>
-		<keyword>params</keyword>
-		<keyword>private</keyword>
-		<keyword>protected</keyword>
-		<keyword>public</keyword>
-		<keyword>readonly</keyword>
-		<keyword>ref</keyword>
-		<keyword>return</keyword>
-		<keyword>sbyte</keyword>
-		<keyword>sealed</keyword>
-		<keyword>short</keyword>
-		<keyword>sizeof</keyword>
-		<keyword>stackalloc</keyword>
-		<keyword>static</keyword>
-		<keyword>string</keyword>
-		<keyword>struct</keyword>
-		<keyword>switch</keyword>
-		<keyword>this</keyword>
-		<keyword>throw</keyword>
-		<keyword>true</keyword>
-		<keyword>try</keyword>
-		<keyword>typeof</keyword>
-		<keyword>uint</keyword>
-		<keyword>ulong</keyword>
-		<keyword>unchecked</keyword>
-		<keyword>unsafe</keyword>
-		<keyword>ushort</keyword>
-		<keyword>using</keyword>
-		<keyword>virtual</keyword>
-		<keyword>void</keyword>
-		<keyword>volatile</keyword>
-		<keyword>while</keyword>
-	</highlighter>
-	<highlighter type="keywords">
-		<!-- special words, not really keywords -->
-		<keyword>add</keyword>
-		<keyword>alias</keyword>
-		<keyword>from</keyword>
-		<keyword>get</keyword>
-		<keyword>global</keyword>
-		<keyword>group</keyword>
-		<keyword>into</keyword>
-		<keyword>join</keyword>
-		<keyword>orderby</keyword>
-		<keyword>partial</keyword>
-		<keyword>remove</keyword>
-		<keyword>select</keyword>
-		<keyword>set</keyword>
-		<keyword>value</keyword>
-		<keyword>where</keyword>
-		<keyword>yield</keyword>
-	</highlighter>
-</highlighters>

+ 0 - 176
stylesheets/lfs-xsl/docbook-xsl-1.78.1/highlighting/css21-hl.xml

@@ -1,176 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<!--
-
-Syntax highlighting definition for CSS files
-
-xslthl - XSLT Syntax Highlighting
-http://sourceforge.net/projects/xslthl/
-Copyright (C) 2011-2012 Martin Hujer, Michiel Hendriks
-
-This software is provided 'as-is', without any express or implied
-warranty.  In no event will the authors be held liable for any damages
-arising from the use of this software.
-
-Permission is granted to anyone to use this software for any purpose,
-including commercial applications, and to alter it and redistribute it
-freely, subject to the following restrictions:
-
-1. The origin of this software must not be misrepresented; you must not
-   claim that you wrote the original software. If you use this software
-   in a product, an acknowledgment in the product documentation would be
-   appreciated but is not required.
-2. Altered source versions must be plainly marked as such, and must not be
-   misrepresented as being the original software.
-3. This notice may not be removed or altered from any source distribution.
-
-Martin Hujer <mhujer at users.sourceforge.net>
-Michiel Hendriks <elmuerte at users.sourceforge.net>
-
-Reference: http://www.w3.org/TR/CSS21/propidx.html
-
--->
-<highlighters>
-    <highlighter type="multiline-comment">
-        <start>/*</start>
-        <end>*/</end>
-    </highlighter>
-    <highlighter type="string">
-		<string>"</string>
-        <escape>\</escape>
-        <spanNewLines/>        
-    </highlighter>
-    <highlighter type="string">
-		<string>'</string>
-		<escape>\</escape>
-        <spanNewLines/>
-    </highlighter>
-    <highlighter type="number">
-        <point>.</point>
-        <pointStarts />
-    </highlighter>
-    <highlighter type="word">
-    	<word>@charset</word>
-    	<word>@import</word>
-    	<word>@media</word>
-    	<word>@page</word>
-    	<style>directive</style>
-    </highlighter>
-    <highlighter type="keywords">
-        <partChars>-</partChars>
-        <keyword>azimuth</keyword>
-        <keyword>background-attachment</keyword>
-        <keyword>background-color</keyword>
-        <keyword>background-image</keyword>
-        <keyword>background-position</keyword>
-        <keyword>background-repeat</keyword>
-        <keyword>background</keyword>
-        <keyword>border-collapse</keyword>
-        <keyword>border-color</keyword>
-        <keyword>border-spacing</keyword>
-        <keyword>border-style</keyword>
-        <keyword>border-top</keyword>
-        <keyword>border-right</keyword>
-        <keyword>border-bottom</keyword>
-        <keyword>border-left</keyword>
-        <keyword>border-top-color</keyword>
-        <keyword>border-right-color</keyword>
-        <keyword>border-bottom-color</keyword>
-        <keyword>border-left-color</keyword>
-        <keyword>border-top-style</keyword>
-        <keyword>border-right-style</keyword>
-        <keyword>border-bottom-style</keyword>
-        <keyword>border-left-style</keyword>
-        <keyword>border-top-width</keyword>
-        <keyword>border-right-width</keyword>
-        <keyword>border-bottom-width</keyword>
-        <keyword>border-left-width</keyword>
-        <keyword>border-width</keyword>
-        <keyword>border</keyword>
-        <keyword>bottom</keyword>
-        <keyword>caption-side</keyword>
-        <keyword>clear</keyword>
-        <keyword>clip</keyword>
-        <keyword>color</keyword>
-        <keyword>content</keyword>
-        <keyword>counter-increment</keyword>
-        <keyword>counter-reset</keyword>
-        <keyword>cue-after</keyword>
-        <keyword>cue-before</keyword>
-        <keyword>cue</keyword>
-        <keyword>cursor</keyword>
-        <keyword>direction</keyword>
-        <keyword>display</keyword>
-        <keyword>elevation</keyword>
-        <keyword>empty-cells</keyword>
-        <keyword>float</keyword>
-        <keyword>font-family</keyword>
-        <keyword>font-size</keyword>
-        <keyword>font-style</keyword>
-        <keyword>font-variant</keyword>
-        <keyword>font-weight</keyword>
-        <keyword>font</keyword>
-        <keyword>height</keyword>
-        <keyword>left</keyword>
-        <keyword>letter-spacing</keyword>
-        <keyword>line-height</keyword>
-        <keyword>list-style-image</keyword>
-        <keyword>list-style-position</keyword>
-        <keyword>list-style-type</keyword>
-        <keyword>list-style</keyword>
-        <keyword>margin-right</keyword>
-        <keyword>margin-left</keyword>
-        <keyword>margin-top</keyword>
-        <keyword>margin-bottom</keyword>
-        <keyword>margin</keyword>
-        <keyword>max-height</keyword>
-        <keyword>max-width</keyword>
-        <keyword>min-height</keyword>
-        <keyword>min-width</keyword>
-        <keyword>orphans</keyword>
-        <keyword>outline-color</keyword>
-        <keyword>outline-style</keyword>
-        <keyword>outline-width</keyword>
-        <keyword>outline</keyword>
-        <keyword>overflow</keyword>
-        <keyword>padding-top</keyword>
-        <keyword>padding-right</keyword>
-        <keyword>padding-bottom</keyword>
-        <keyword>padding-left</keyword>
-        <keyword>padding</keyword>
-        <keyword>page-break-after</keyword>
-        <keyword>page-break-before</keyword>
-        <keyword>page-break-inside</keyword>
-        <keyword>pause-after</keyword>
-        <keyword>pause-before</keyword>
-        <keyword>pause</keyword>
-        <keyword>pitch-range</keyword>
-        <keyword>pitch</keyword>
-        <keyword>play-during</keyword>
-        <keyword>position</keyword>
-        <keyword>quotes</keyword>
-        <keyword>richness</keyword>
-        <keyword>right</keyword>
-        <keyword>speak-header</keyword>
-        <keyword>speak-numeral</keyword>
-        <keyword>speak-punctuation</keyword>
-        <keyword>speak</keyword>
-        <keyword>speech-rate</keyword>
-        <keyword>stress</keyword>
-        <keyword>table-layout</keyword>
-        <keyword>text-align</keyword>
-        <keyword>text-decoration</keyword>
-        <keyword>text-indent</keyword>
-        <keyword>text-transform</keyword>
-        <keyword>top</keyword>
-        <keyword>unicode-bidi</keyword>
-        <keyword>vertical-align</keyword>
-        <keyword>visibility</keyword>
-        <keyword>voice-family</keyword>
-        <keyword>volume</keyword>
-        <keyword>white-space</keyword>
-        <keyword>widows</keyword>
-        <keyword>width</keyword>
-        <keyword>word-spacing</keyword>
-        <keyword>z-index</keyword>
-    </highlighter>
-</highlighters>

+ 0 - 220
stylesheets/lfs-xsl/docbook-xsl-1.78.1/highlighting/delphi-hl.xml

@@ -1,220 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<!--
-
-Syntax highlighting definition for Delphi (also suitable for Pascal)
-
-xslthl - XSLT Syntax Highlighting
-http://sourceforge.net/projects/xslthl/
-Copyright (C) 2005-2008 Michal Molhanec, Jirka Kosek, Michiel Hendriks
-
-This software is provided 'as-is', without any express or implied
-warranty.  In no event will the authors be held liable for any damages
-arising from the use of this software.
-
-Permission is granted to anyone to use this software for any purpose,
-including commercial applications, and to alter it and redistribute it
-freely, subject to the following restrictions:
-
-1. The origin of this software must not be misrepresented; you must not
-   claim that you wrote the original software. If you use this software
-   in a product, an acknowledgment in the product documentation would be
-   appreciated but is not required.
-2. Altered source versions must be plainly marked as such, and must not be
-   misrepresented as being the original software.
-3. This notice may not be removed or altered from any source distribution.
-
-Michal Molhanec <mol1111 at users.sourceforge.net>
-Jirka Kosek <kosek at users.sourceforge.net>
-Michiel Hendriks <elmuerte at users.sourceforge.net>
-
--->
-<highlighters>
-        <highlighter type="multiline-comment">
-                <!-- multiline comments starting with an $ are directives -->
-                <start>{$</start>
-                <end>}</end>
-                <style>directive</style>
-        </highlighter>
-        <highlighter type="multiline-comment">
-                <!-- multiline comments starting with an $ are directives -->
-                <start>(*$</start>
-                <end>)</end>
-                <style>directive</style>
-        </highlighter>
-        <highlighter type="multiline-comment">
-                <start>{</start>
-                <end>}</end>
-        </highlighter>
-        <highlighter type="multiline-comment">
-                <start>(*</start>
-                <end>*)</end>
-        </highlighter>
-        <highlighter type="oneline-comment">//</highlighter>
-        <highlighter type="string">
-                <string>'</string>
-                <doubleEscapes />
-        </highlighter>
-        <highlighter type="hexnumber">
-                <prefix>#$</prefix>
-                <ignoreCase />
-                <style>string</style>           
-        </highlighter>
-        <highlighter type="number">
-                <prefix>#</prefix>
-                <ignoreCase />
-                <style>string</style>           
-        </highlighter>
-        <highlighter type="hexnumber">
-                <prefix>$</prefix>
-                <ignoreCase />
-        </highlighter>
-        <highlighter type="number">
-                <point>.</point>
-                <exponent>e</exponent>
-                <ignoreCase />
-        </highlighter>
-        <highlighter type="keywords">
-                <!-- Reserved words -->
-                <keyword>and</keyword>
-                <keyword>else</keyword>
-                <keyword>inherited</keyword>
-                <keyword>packed</keyword>
-                <keyword>then</keyword>
-                <keyword>array</keyword>
-                <keyword>end</keyword>
-                <keyword>initialization</keyword>
-                <keyword>procedure</keyword>
-                <keyword>threadvar</keyword>
-                <keyword>as</keyword>
-                <keyword>except</keyword>
-                <keyword>inline</keyword>
-                <keyword>program</keyword>
-                <keyword>to</keyword>
-                <keyword>asm</keyword>
-                <keyword>exports</keyword>
-                <keyword>interface</keyword>
-                <keyword>property</keyword>
-                <keyword>try</keyword>
-                <keyword>begin</keyword>
-                <keyword>file</keyword>
-                <keyword>is</keyword>
-                <keyword>raise</keyword>
-                <keyword>type</keyword>
-                <keyword>case</keyword>
-                <keyword>final</keyword>
-                <keyword>label</keyword>
-                <keyword>record</keyword>
-                <keyword>unit</keyword>
-                <keyword>class</keyword>
-                <keyword>finalization</keyword>
-                <keyword>library</keyword>
-                <keyword>repeat</keyword>
-                <keyword>unsafe</keyword>
-                <keyword>const</keyword>
-                <keyword>finally</keyword>
-                <keyword>mod</keyword>
-                <keyword>resourcestring</keyword>
-                <keyword>until</keyword>
-                <keyword>constructor</keyword>
-                <keyword>for</keyword>
-                <keyword>nil</keyword>
-                <keyword>sealed</keyword>
-                <keyword>uses</keyword>
-                <keyword>destructor</keyword>
-                <keyword>function</keyword>
-                <keyword>not</keyword>
-                <keyword>set</keyword>
-                <keyword>var</keyword>
-                <keyword>dispinterface</keyword>
-                <keyword>goto</keyword>
-                <keyword>object</keyword>
-                <keyword>shl</keyword>
-                <keyword>while</keyword>
-                <keyword>div</keyword>
-                <keyword>if</keyword>
-                <keyword>of</keyword>
-                <keyword>shr</keyword>
-                <keyword>with</keyword>
-                <keyword>do</keyword>
-                <keyword>implementation</keyword>
-                <keyword>or</keyword>
-                <keyword>static</keyword>
-                <keyword>xor</keyword>
-                <keyword>downto</keyword>
-                <keyword>in</keyword>
-                <keyword>out</keyword>
-                <keyword>string</keyword>
-                <keyword>exit</keyword> 
-                <keyword>break</keyword>
-                <keyword>continue</keyword>
-
-                <!-- Special meaning -->
-                <keyword>at</keyword>
-                <keyword>on</keyword>
-  
-                <!-- Directives -->
-                <keyword>absolute</keyword>
-                <keyword>dynamic</keyword>
-                <keyword>local</keyword>
-                <keyword>platform</keyword>
-                <keyword>requires</keyword>
-                <keyword>abstract</keyword>
-                <keyword>export</keyword>
-                <keyword>message</keyword>
-                <keyword>private</keyword>
-                <keyword>resident</keyword>
-                <keyword>assembler</keyword>
-                <keyword>external</keyword>
-                <keyword>name</keyword>
-                <keyword>protected</keyword>
-                <keyword>safecall</keyword>
-                <keyword>automated</keyword>
-                <keyword>far</keyword>
-                <keyword>near</keyword>
-                <keyword>public</keyword>
-                <keyword>stdcall</keyword>
-                <keyword>cdecl</keyword>
-                <keyword>forward</keyword>
-                <keyword>nodefault</keyword>
-                <keyword>published</keyword>
-                <keyword>stored</keyword>
-                <keyword>contains</keyword>
-                <keyword>implements</keyword>
-                <keyword>overload</keyword>
-                <keyword>read</keyword>
-                <keyword>varargs</keyword>
-                <keyword>default</keyword>
-                <keyword>index</keyword>
-                <keyword>override</keyword>
-                <keyword>readonly</keyword>
-                <keyword>virtual</keyword>
-                <keyword>deprecated</keyword>
-                <keyword>inline</keyword>
-                <keyword>package</keyword>
-                <keyword>register</keyword>
-                <keyword>write</keyword>
-                <keyword>dispid</keyword>
-                <keyword>library</keyword>
-                <keyword>pascal</keyword>
-                <keyword>reintroduce</keyword>
-                <keyword>writeonly</keyword>
-
-                <!-- Native pascal types of data  -->
-                <keyword>byte</keyword>
-                <keyword>shortint</keyword>
-                <keyword>word</keyword>
-                <keyword>smallint</keyword>
-                <keyword>longint</keyword>
-                <keyword>integer</keyword>
-                <keyword>cardinal</keyword>
-                <keyword>char</keyword>
-                <keyword>real</keyword>
-                <keyword>double</keyword>
-                <keyword>single</keyword>
-                <keyword>extended</keyword>
-                <keyword>comp</keyword>
-                <keyword>boolean</keyword>
-
-                <ignoreCase />
-        </highlighter>
-</highlighters>

+ 0 - 45
stylesheets/lfs-xsl/docbook-xsl-1.78.1/highlighting/ini-hl.xml

@@ -1,45 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<!--
-
-Syntax highlighting definition for ini files
-
-xslthl - XSLT Syntax Highlighting
-http://sourceforge.net/projects/xslthl/
-Copyright (C) 2005-2008 Michal Molhanec, Jirka Kosek, Michiel Hendriks
-
-This software is provided 'as-is', without any express or implied
-warranty.  In no event will the authors be held liable for any damages
-arising from the use of this software.
-
-Permission is granted to anyone to use this software for any purpose,
-including commercial applications, and to alter it and redistribute it
-freely, subject to the following restrictions:
-
-1. The origin of this software must not be misrepresented; you must not
-   claim that you wrote the original software. If you use this software
-   in a product, an acknowledgment in the product documentation would be
-   appreciated but is not required.
-2. Altered source versions must be plainly marked as such, and must not be
-   misrepresented as being the original software.
-3. This notice may not be removed or altered from any source distribution.
-
-Michal Molhanec <mol1111 at users.sourceforge.net>
-Jirka Kosek <kosek at users.sourceforge.net>
-Michiel Hendriks <elmuerte at users.sourceforge.net>
-
--->
-<highlighters>
-	<highlighter type="oneline-comment">;</highlighter>
-	<highlighter type="regex">	
-		<!-- ini sections -->
-		<pattern>^(\[.+\]\s*)$</pattern>
-		<style>keyword</style>
-		<flags>MULTILINE</flags>
-	</highlighter>
-	<highlighter type="regex">
-		<!-- the keys in an ini section -->
-		<pattern>^(.+)(?==)</pattern>
-		<style>attribute</style>
-		<flags>MULTILINE</flags>
-	</highlighter>
-</highlighters>

+ 0 - 117
stylesheets/lfs-xsl/docbook-xsl-1.78.1/highlighting/java-hl.xml

@@ -1,117 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<!--
-
-Syntax highlighting definition for Java
-
-xslthl - XSLT Syntax Highlighting
-http://sourceforge.net/projects/xslthl/
-Copyright (C) 2005-2008 Michal Molhanec, Jirka Kosek, Michiel Hendriks
-
-This software is provided 'as-is', without any express or implied
-warranty.  In no event will the authors be held liable for any damages
-arising from the use of this software.
-
-Permission is granted to anyone to use this software for any purpose,
-including commercial applications, and to alter it and redistribute it
-freely, subject to the following restrictions:
-
-1. The origin of this software must not be misrepresented; you must not
-   claim that you wrote the original software. If you use this software
-   in a product, an acknowledgment in the product documentation would be
-   appreciated but is not required.
-2. Altered source versions must be plainly marked as such, and must not be
-   misrepresented as being the original software.
-3. This notice may not be removed or altered from any source distribution.
-
-Michal Molhanec <mol1111 at users.sourceforge.net>
-Jirka Kosek <kosek at users.sourceforge.net>
-Michiel Hendriks <elmuerte at users.sourceforge.net>
-
--->
-<highlighters>
-	<highlighter type="multiline-comment">
-		<start>/**</start>
-		<end>*/</end>
-		<style>doccomment</style>
-	</highlighter>
-	<highlighter type="multiline-comment">
-		<start>/*</start>
-		<end>*/</end>
-	</highlighter>
-	<highlighter type="oneline-comment">//</highlighter>
-	<highlighter type="string">
-		<string>"</string>
-		<escape>\</escape>
-	</highlighter>
-	<highlighter type="string">
-		<string>'</string>
-		<escape>\</escape>
-	</highlighter>
-	<highlighter type="annotation">
-		<start>@</start>
-		<valueStart>(</valueStart>
-		<valueEnd>)</valueEnd>
-	</highlighter>
-	<highlighter type="hexnumber">
-		<prefix>0x</prefix>
-		<ignoreCase />
-	</highlighter>
-	<highlighter type="number">
-		<point>.</point>
-		<exponent>e</exponent>
-		<suffix>f</suffix>
-		<suffix>d</suffix>
-		<suffix>l</suffix>
-		<ignoreCase />
-	</highlighter>
-	<highlighter type="keywords">
-		<keyword>abstract</keyword>
-		<keyword>boolean</keyword>
-		<keyword>break</keyword>
-		<keyword>byte</keyword>
-		<keyword>case</keyword>
-		<keyword>catch</keyword>
-		<keyword>char</keyword>
-		<keyword>class</keyword>
-		<keyword>const</keyword>
-		<keyword>continue</keyword>
-		<keyword>default</keyword>
-		<keyword>do</keyword>
-		<keyword>double</keyword>
-		<keyword>else</keyword>
-		<keyword>extends</keyword>
-		<keyword>final</keyword>
-		<keyword>finally</keyword>
-		<keyword>float</keyword>
-		<keyword>for</keyword>
-		<keyword>goto</keyword>
-		<keyword>if</keyword>
-		<keyword>implements</keyword>
-		<keyword>import</keyword>
-		<keyword>instanceof</keyword>
-		<keyword>int</keyword>
-		<keyword>interface</keyword>
-		<keyword>long</keyword>
-		<keyword>native</keyword>
-		<keyword>new</keyword>
-		<keyword>package</keyword>
-		<keyword>private</keyword>
-		<keyword>protected</keyword>
-		<keyword>public</keyword>
-		<keyword>return</keyword>
-		<keyword>short</keyword>
-		<keyword>static</keyword>
-		<keyword>strictfp</keyword>
-		<keyword>super</keyword>
-		<keyword>switch</keyword>
-		<keyword>synchronized</keyword>
-		<keyword>this</keyword>
-		<keyword>throw</keyword>
-		<keyword>throws</keyword>
-		<keyword>transient</keyword>
-		<keyword>try</keyword>
-		<keyword>void</keyword>
-		<keyword>volatile</keyword>
-		<keyword>while</keyword>
-	</highlighter>
-</highlighters>

+ 0 - 147
stylesheets/lfs-xsl/docbook-xsl-1.78.1/highlighting/javascript-hl.xml

@@ -1,147 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<!--
-
-Syntax highlighting definition for JavaScript
-
-xslthl - XSLT Syntax Highlighting
-http://sourceforge.net/projects/xslthl/
-Copyright (C) 2005-2008 Michal Molhanec, Jirka Kosek, Michiel Hendriks
-
-This software is provided 'as-is', without any express or implied
-warranty.  In no event will the authors be held liable for any damages
-arising from the use of this software.
-
-Permission is granted to anyone to use this software for any purpose,
-including commercial applications, and to alter it and redistribute it
-freely, subject to the following restrictions:
-
-1. The origin of this software must not be misrepresented; you must not
-   claim that you wrote the original software. If you use this software
-   in a product, an acknowledgment in the product documentation would be
-   appreciated but is not required.
-2. Altered source versions must be plainly marked as such, and must not be
-   misrepresented as being the original software.
-3. This notice may not be removed or altered from any source distribution.
-
-Michal Molhanec <mol1111 at users.sourceforge.net>
-Jirka Kosek <kosek at users.sourceforge.net>
-Michiel Hendriks <elmuerte at users.sourceforge.net>
-
--->
-<highlighters>
-	<highlighter type="multiline-comment">
-		<start>/*</start>
-		<end>*/</end>
-	</highlighter>
-	<highlighter type="oneline-comment">//</highlighter>
-	<highlighter type="string">
-		<string>"</string>
-		<escape>\</escape>
-	</highlighter>
-	<highlighter type="string">
-		<string>'</string>
-		<escape>\</escape>
-	</highlighter>
-	<highlighter type="hexnumber">
-		<prefix>0x</prefix>
-		<ignoreCase />
-	</highlighter>
-	<highlighter type="number">
-		<point>.</point>
-		<exponent>e</exponent>
-		<ignoreCase />
-	</highlighter>
-	<highlighter type="keywords">
-		<keyword>break</keyword>
-		<keyword>case</keyword>
-		<keyword>catch</keyword>
-		<keyword>continue</keyword>
-		<keyword>default</keyword>
-		<keyword>delete</keyword>
-		<keyword>do</keyword>
-		<keyword>else</keyword>
-		<keyword>finally</keyword>
-		<keyword>for</keyword>
-		<keyword>function</keyword>
-		<keyword>if</keyword>
-		<keyword>in</keyword>
-		<keyword>instanceof</keyword>
-		<keyword>new</keyword>
-		<keyword>return</keyword>
-		<keyword>switch</keyword>
-		<keyword>this</keyword>
-		<keyword>throw</keyword>
-		<keyword>try</keyword>
-		<keyword>typeof</keyword>
-		<keyword>var</keyword>
-		<keyword>void</keyword>
-		<keyword>while</keyword>
-		<keyword>with</keyword>
-		<!-- future keywords -->
-		<keyword>abstract</keyword>
-		<keyword>boolean</keyword>
-		<keyword>byte</keyword>
-		<keyword>char</keyword>
-		<keyword>class</keyword>
-		<keyword>const</keyword>
-		<keyword>debugger</keyword>
-		<keyword>double</keyword>
-		<keyword>enum</keyword>
-		<keyword>export</keyword>
-		<keyword>extends</keyword>
-		<keyword>final</keyword>
-		<keyword>float</keyword>
-		<keyword>goto</keyword>
-		<keyword>implements</keyword>
-		<keyword>import</keyword>
-		<keyword>int</keyword>
-		<keyword>interface</keyword>
-		<keyword>long</keyword>
-		<keyword>native</keyword>
-		<keyword>package</keyword>
-		<keyword>private</keyword>
-		<keyword>protected</keyword>
-		<keyword>public</keyword>
-		<keyword>short</keyword>
-		<keyword>static</keyword>
-		<keyword>super</keyword>
-		<keyword>synchronized</keyword>
-		<keyword>throws</keyword>
-		<keyword>transient</keyword>
-		<keyword>volatile</keyword>
-	</highlighter>
-	<highlighter type="keywords">
-		<keyword>prototype</keyword>
-		<!-- Global Objects -->
-		<keyword>Array</keyword>
-		<keyword>Boolean</keyword>
-		<keyword>Date</keyword>
-		<keyword>Error</keyword>
-		<keyword>EvalError</keyword>
-		<keyword>Function</keyword>
-		<keyword>Math</keyword>
-		<keyword>Number</keyword>
-		<keyword>Object</keyword>
-		<keyword>RangeError</keyword>
-		<keyword>ReferenceError</keyword>
-		<keyword>RegExp</keyword>
-		<keyword>String</keyword>
-		<keyword>SyntaxError</keyword>
-		<keyword>TypeError</keyword>
-		<keyword>URIError</keyword>
-		<!-- Global functions -->
-		<keyword>decodeURI</keyword>
-		<keyword>decodeURIComponent</keyword>
-		<keyword>encodeURI</keyword>
-		<keyword>encodeURIComponent</keyword>
-		<keyword>eval</keyword>
-		<keyword>isFinite</keyword>
-		<keyword>isNaN</keyword>
-		<keyword>parseFloat</keyword>
-		<keyword>parseInt</keyword>
-		<!-- Global properties -->
-		<keyword>Infinity</keyword>
-		<keyword>NaN</keyword>
-		<keyword>undefined</keyword>
-	</highlighter>
-</highlighters>

+ 0 - 140
stylesheets/lfs-xsl/docbook-xsl-1.78.1/highlighting/lua-hl.xml

@@ -1,140 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<!--
-
-Syntax highlighting definition for Lua 5.1 and 5.2
-
-xslthl - XSLT Syntax Highlighting
-http://sourceforge.net/projects/xslthl/
-Copyright (C) 2012 Patrick Rapin
-
-This software is provided 'as-is', without any express or implied
-warranty.  In no event will the authors be held liable for any damages
-arising from the use of this software.
-
-Permission is granted to anyone to use this software for any purpose,
-including commercial applications, and to alter it and redistribute it
-freely, subject to the following restrictions:
-
-1. The origin of this software must not be misrepresented; you must not
-   claim that you wrote the original software. If you use this software
-   in a product, an acknowledgment in the product documentation would be
-   appreciated but is not required.
-2. Altered source versions must be plainly marked as such, and must not be
-   misrepresented as being the original software.
-3. This notice may not be removed or altered from any source distribution.
-
- If you want to send an e-mail to Patrick Rapin, please execute the 
- following decrypting script in Lua 5.1 or 5.2:
-    print(('oc mia.l@kmgrtci.naparip'):gsub('(..)(..)','%2%1'):reverse())
--->
-
-<highlighters>
-  <highlighter type="keywords">
-    <keyword>and</keyword>
-    <keyword>break</keyword>
-    <keyword>do</keyword>
-    <keyword>else</keyword>
-    <keyword>elseif</keyword>
-    <keyword>end</keyword>
-    <keyword>false</keyword>
-    <keyword>for</keyword>
-    <keyword>function</keyword>
-    <keyword>goto</keyword>
-    <keyword>if</keyword>
-    <keyword>in</keyword>
-    <keyword>local</keyword>
-    <keyword>nil</keyword>
-    <keyword>not</keyword>
-    <keyword>or</keyword>
-    <keyword>repeat</keyword>
-    <keyword>return</keyword>
-    <keyword>then</keyword>
-    <keyword>true</keyword>
-    <keyword>until</keyword>
-    <keyword>while</keyword>
-  </highlighter>
-  
-  <!-- Multiline comments can have any number of equal signs 
-    between brackets. Let's support up to 4 -->
-  <highlighter type="multiline-comment">
-    <start>--[[</start>
-    <end>]]</end>
-  </highlighter>
-  <highlighter type="multiline-comment">
-    <start>--[=[</start>
-    <end>]=]</end>
-  </highlighter>
-  <highlighter type="multiline-comment">
-    <start>--[==[</start>
-    <end>]==]</end>
-  </highlighter>
-  <highlighter type="multiline-comment">
-    <start>--[===[</start>
-    <end>]===]</end>
-  </highlighter>
-  <highlighter type="multiline-comment">
-    <start>--[====[</start>
-    <end>]====]</end>
-  </highlighter>
-
-  <highlighter type="oneline-comment">
-    --
-  </highlighter>
-  
-  <highlighter type="string">
-    <string>"</string>
-    <endString>"</endString>
-    <escape>\</escape>
-    <spanNewLines/>
-  </highlighter>
-  
-  <highlighter type="string">
-    <string>'</string>
-    <endString>'</endString>
-    <escape>\</escape>
-    <spanNewLines/>
-  </highlighter>
-
-  <!-- Long strings can also have any number of equal signs. -->
-  <highlighter type="string">
-    <string>[[</string>
-    <endString>]]</endString>
-    <spanNewLines/>
-  </highlighter>
-  <highlighter type="string">
-    <string>[=[</string>
-    <endString>]=]</endString>
-    <spanNewLines/>
-  </highlighter>
-  <highlighter type="string">
-    <string>[==[</string>
-    <endString>]==]</endString>
-    <spanNewLines/>
-  </highlighter>
-  <highlighter type="string">
-    <string>[===[</string>
-    <endString>]===]</endString>
-    <spanNewLines/>
-  </highlighter>
-  <highlighter type="string">
-    <string>[====[</string>
-    <endString>]====]</endString>
-    <spanNewLines/>
-  </highlighter>
-
-  <highlighter type="number">
-    <point>.</point>
-    <pointStarts />
-    <exponent>e</exponent>
-    <ignoreCase />
-  </highlighter>
-
-  <highlighter type="hexnumber">
-    <prefix>0x</prefix>
-    <point>.</point>
-    <pointStarts />
-    <exponent>p</exponent>
-    <ignoreCase />
-  </highlighter>
-  
-</highlighters>

+ 0 - 90
stylesheets/lfs-xsl/docbook-xsl-1.78.1/highlighting/m2-hl.xml

@@ -1,90 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<!--
-
-Syntax highlighting definition for Modulo-2
-
-xslthl - XSLT Syntax Highlighting
-http://sourceforge.net/projects/xslthl/
-Copyright (C) 2005-2008 Michal Molhanec, Jirka Kosek, Michiel Hendriks
-
-This software is provided 'as-is', without any express or implied
-warranty.  In no event will the authors be held liable for any damages
-arising from the use of this software.
-
-Permission is granted to anyone to use this software for any purpose,
-including commercial applications, and to alter it and redistribute it
-freely, subject to the following restrictions:
-
-1. The origin of this software must not be misrepresented; you must not
-   claim that you wrote the original software. If you use this software
-   in a product, an acknowledgment in the product documentation would be
-   appreciated but is not required.
-2. Altered source versions must be plainly marked as such, and must not be
-   misrepresented as being the original software.
-3. This notice may not be removed or altered from any source distribution.
-
-Michal Molhanec <mol1111 at users.sourceforge.net>
-Jirka Kosek <kosek at users.sourceforge.net>
-Michiel Hendriks <elmuerte at users.sourceforge.net>
-
--->
-<highlighters>
-	<highlighter type="nested-multiline-comment">
-		<start>(*</start>
-		<end>*)</end>
-	</highlighter>
-	<highlighter type="string">
-		<string>"</string>
-	</highlighter>
-	<highlighter type="string">
-		<string>'</string>
-	</highlighter>
-	<highlighter type="number">
-		<point>.</point>
-		<exponent>e</exponent>
-		<ignoreCase />
-	</highlighter>
-	<highlighter type="keywords">
-		<keyword>and</keyword>
-		<keyword>array</keyword>
-		<keyword>begin</keyword>
-		<keyword>by</keyword>
-		<keyword>case</keyword>
-		<keyword>const</keyword>
-		<keyword>definition</keyword>
-		<keyword>div</keyword>
-		<keyword>do</keyword>
-		<keyword>else</keyword>
-		<keyword>elsif</keyword>
-		<keyword>end</keyword>
-		<keyword>exit</keyword>
-		<keyword>export</keyword>
-		<keyword>for</keyword>
-		<keyword>from</keyword>
-		<keyword>if</keyword>
-		<keyword>implementation</keyword>
-		<keyword>import</keyword>
-		<keyword>in</keyword>
-		<keyword>loop</keyword>
-		<keyword>mod</keyword>
-		<keyword>module</keyword>
-		<keyword>not</keyword>
-		<keyword>of</keyword>
-		<keyword>or</keyword>
-		<keyword>pointer</keyword>
-		<keyword>procedure</keyword>
-		<keyword>qualified</keyword>
-		<keyword>record</keyword>
-		<keyword>repeat</keyword>
-		<keyword>return</keyword>
-		<keyword>set</keyword>
-		<keyword>then</keyword>
-		<keyword>to</keyword>
-		<keyword>type</keyword>
-		<keyword>until</keyword>
-		<keyword>var</keyword>
-		<keyword>while</keyword>
-		<keyword>with</keyword>
-		<ignoreCase />
-	</highlighter>
-</highlighters>

+ 0 - 116
stylesheets/lfs-xsl/docbook-xsl-1.78.1/highlighting/myxml-hl.xml

@@ -1,116 +0,0 @@
-<?xml version='1.0'?>
-<!--
-
-  Bakalarska prace: Zvyraznovani syntaxe v XSLT
-  Michal Molhanec 2005
-
-  myxml-hl.xml - konfigurace zvyraznovace XML, ktera zvlast zvyrazni
-                 HTML elementy a XSL elementy
-
--->
-<highlighters>
-
-<wholehighlighter type='xml'>
-  <elementSet>
-    <style>html</style>
-    <element>A</element>
-    <element>ABBR</element>
-    <element>ACRONYM</element>
-    <element>ADDRESS</element>
-    <element>APPLET</element>
-    <element>AREA</element>
-    <element>B</element>
-    <element>BASE</element>
-    <element>BASEFONT</element>
-    <element>BDO</element>
-    <element>BIG</element>
-    <element>BLOCKQUOTE</element>
-    <element>BODY</element>
-    <element>BR</element>
-    <element>BUTTON</element>
-    <element>CAPTION</element>
-    <element>CENTER</element>
-    <element>CITE</element>
-    <element>CODE</element>
-    <element>COL</element>
-    <element>COLGROUP</element>
-    <element>DD</element>
-    <element>DEL</element>
-    <element>DFN</element>
-    <element>DIR</element>
-    <element>DIV</element>
-    <element>DL</element>
-    <element>DT</element>
-    <element>EM</element>
-    <element>FIELDSET</element>
-    <element>FONT</element>
-    <element>FORM</element>
-    <element>FRAME</element>
-    <element>FRAMESET</element>
-    <element>H1</element>
-    <element>H2</element>
-    <element>H3</element>
-    <element>H4</element>
-    <element>H5</element>
-    <element>H6</element>
-    <element>HEAD</element>
-    <element>HR</element>
-    <element>HTML</element>
-    <element>I</element>
-    <element>IFRAME</element>
-    <element>IMG</element>
-    <element>INPUT</element>
-    <element>INS</element>
-    <element>ISINDEX</element>
-    <element>KBD</element>
-    <element>LABEL</element>
-    <element>LEGEND</element>
-    <element>LI</element>
-    <element>LINK</element>
-    <element>MAP</element>
-    <element>MENU</element>
-    <element>META</element>
-    <element>NOFRAMES</element>
-    <element>NOSCRIPT</element>
-    <element>OBJECT</element>
-    <element>OL</element>
-    <element>OPTGROUP</element>
-    <element>OPTION</element>
-    <element>P</element>
-    <element>PARAM</element>
-    <element>PRE</element>
-    <element>Q</element>
-    <element>S</element>
-    <element>SAMP</element>
-    <element>SCRIPT</element>
-    <element>SELECT</element>
-    <element>SMALL</element>
-    <element>SPAN</element>
-    <element>STRIKE</element>
-    <element>STRONG</element>
-    <element>STYLE</element>
-    <element>SUB</element>
-    <element>SUP</element>
-    <element>TABLE</element>
-    <element>TBODY</element>
-    <element>TD</element>
-    <element>TEXTAREA</element>
-    <element>TFOOT</element>
-    <element>TH</element>
-    <element>THEAD</element>
-    <element>TITLE</element>
-    <element>TR</element>
-    <element>TT</element>
-    <element>U</element>
-    <element>UL</element>
-    <element>VAR</element>
-    <element>XMP</element>
-    <ignoreCase/>
-  </elementSet>
-  <elementPrefix>
-    <style>xslt</style>
-    <prefix>xsl:</prefix>
-  </elementPrefix>
-</wholehighlighter>
-
-</highlighters>

+ 0 - 120
stylesheets/lfs-xsl/docbook-xsl-1.78.1/highlighting/perl-hl.xml

@@ -1,120 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<!--
-
-Syntax highlighting definition for Perl
-
-xslthl - XSLT Syntax Highlighting
-http://sourceforge.net/projects/xslthl/
-Copyright (C) 2005-2008 Michal Molhanec, Jirka Kosek, Michiel Hendriks
-
-This software is provided 'as-is', without any express or implied
-warranty.  In no event will the authors be held liable for any damages
-arising from the use of this software.
-
-Permission is granted to anyone to use this software for any purpose,
-including commercial applications, and to alter it and redistribute it
-freely, subject to the following restrictions:
-
-1. The origin of this software must not be misrepresented; you must not
-   claim that you wrote the original software. If you use this software
-   in a product, an acknowledgment in the product documentation would be
-   appreciated but is not required.
-2. Altered source versions must be plainly marked as such, and must not be
-   misrepresented as being the original software.
-3. This notice may not be removed or altered from any source distribution.
-
-Michal Molhanec <mol1111 at users.sourceforge.net>
-Jirka Kosek <kosek at users.sourceforge.net>
-Michiel Hendriks <elmuerte at users.sourceforge.net>
-
--->
-<highlighters>
-	<highlighter type="oneline-comment">#</highlighter>
-	<highlighter type="heredoc">
-		<start>&lt;&lt;</start>
-		<quote>'</quote>
-		<quote>"</quote>
-		<noWhiteSpace/>
-	</highlighter>
-	<highlighter type="string">
-		<string>"</string>
-		<escape>\</escape>
-	</highlighter>
-	<highlighter type="string">
-		<string>'</string>
-		<escape>\</escape>
-		<spanNewLines/>
-	</highlighter>
-	<highlighter type="hexnumber">
-		<prefix>0x</prefix>
-		<ignoreCase />
-	</highlighter>
-	<highlighter type="number">
-		<point>.</point>
-		<pointStarts />
-		<ignoreCase />
-	</highlighter>
-	<highlighter type="keywords">
-		<keyword>if</keyword>
-		<keyword>unless</keyword>
-		<keyword>while</keyword>
-		<keyword>until</keyword>
-		<keyword>foreach</keyword>
-		<keyword>else</keyword>
-		<keyword>elsif</keyword>
-		<keyword>for</keyword>
-		<keyword>when</keyword>
-		<keyword>default</keyword>
-		<keyword>given</keyword>
-		<!-- Keywords related to the control flow of your perl program  -->
-		<keyword>caller</keyword>
-		<keyword>continue</keyword> 
-		<keyword>die</keyword>
-		<keyword>do</keyword>
-		<keyword>dump</keyword>
-		<keyword>eval</keyword>
-		<keyword>exit</keyword>
-		<keyword>goto</keyword>
-		<keyword>last</keyword>
-		<keyword>next</keyword>
-		<keyword>redo</keyword>
-		<keyword>return</keyword>
-		<keyword>sub</keyword>
-		<keyword>wantarray</keyword>
-		<!-- Keywords related to scoping  -->
-		<keyword>caller</keyword>
-		<keyword>import</keyword>
-		<keyword>local</keyword>
-		<keyword>my</keyword>
-		<keyword>package</keyword>
-		<keyword>use</keyword>
-		<!-- Keywords related to perl modules  -->
-		<keyword>do</keyword>
-		<keyword>import</keyword>
-		<keyword>no</keyword>
-		<keyword>package</keyword>
-		<keyword>require</keyword>
-		<keyword>use</keyword>
-		<!-- Keywords related to classes and object-orientedness  -->
-		<keyword>bless</keyword>
-		<keyword>dbmclose</keyword>
-		<keyword>dbmopen</keyword>
-		<keyword>package</keyword>
-		<keyword>ref</keyword>
-		<keyword>tie</keyword>
-		<keyword>tied</keyword>
-		<keyword>untie</keyword>
-		<keyword>use</keyword>
-		<!-- operators -->
-		<keyword>and</keyword>
-		<keyword>or</keyword>
-		<keyword>not</keyword>
-		<keyword>eq</keyword>
-		<keyword>ne</keyword>
-		<keyword>lt</keyword>
-		<keyword>gt</keyword>
-		<keyword>le</keyword>
-		<keyword>ge</keyword>
-		<keyword>cmp</keyword>
-	</highlighter>
-</highlighters>

+ 0 - 154
stylesheets/lfs-xsl/docbook-xsl-1.78.1/highlighting/php-hl.xml

@@ -1,154 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<!--
-
-Syntax highlighting definition for PHP
-
-xslthl - XSLT Syntax Highlighting
-http://sourceforge.net/projects/xslthl/
-Copyright (C) 2005-2008 Michal Molhanec, Jirka Kosek, Michiel Hendriks
-
-This software is provided 'as-is', without any express or implied
-warranty.  In no event will the authors be held liable for any damages
-arising from the use of this software.
-
-Permission is granted to anyone to use this software for any purpose,
-including commercial applications, and to alter it and redistribute it
-freely, subject to the following restrictions:
-
-1. The origin of this software must not be misrepresented; you must not
-   claim that you wrote the original software. If you use this software
-   in a product, an acknowledgment in the product documentation would be
-   appreciated but is not required.
-2. Altered source versions must be plainly marked as such, and must not be
-   misrepresented as being the original software.
-3. This notice may not be removed or altered from any source distribution.
-
-Michal Molhanec <mol1111 at users.sourceforge.net>
-Jirka Kosek <kosek at users.sourceforge.net>
-Michiel Hendriks <elmuerte at users.sourceforge.net>
-
--->
-<highlighters>
-	<highlighter type="multiline-comment">
-		<start>/**</start>
-		<end>*/</end>
-		<style>doccomment</style>
-	</highlighter>
-	<highlighter type="oneline-comment">
-		<start><![CDATA[/// ]]></start>
-		<style>doccomment</style>
-	</highlighter>
-	<highlighter type="multiline-comment">
-		<start>/*</start>
-		<end>*/</end>
-	</highlighter>
-	<highlighter type="oneline-comment">//</highlighter>
-	<highlighter type="oneline-comment">#</highlighter>
-	<highlighter type="string">
-		<string>"</string>
-		<escape>\</escape>
-		<spanNewLines />
-	</highlighter>
-	<highlighter type="string">
-		<string>'</string>
-		<escape>\</escape>
-		<spanNewLines />
-	</highlighter>
-	<highlighter type="heredoc">
-		<start>&lt;&lt;&lt;</start>
-	</highlighter>
-	<highlighter type="hexnumber">
-		<prefix>0x</prefix>
-		<ignoreCase />
-	</highlighter>
-	<highlighter type="number">
-		<point>.</point>
-		<exponent>e</exponent>
-		<ignoreCase />
-	</highlighter>
-	<highlighter type="keywords">
-		<keyword>and</keyword>
-		<keyword>or</keyword>
-		<keyword>xor</keyword>
-		<keyword>__FILE__</keyword>
-		<keyword>exception</keyword>
-		<keyword>__LINE__</keyword>
-		<keyword>array</keyword>
-		<keyword>as</keyword>
-		<keyword>break</keyword>
-		<keyword>case</keyword>
-		<keyword>class</keyword>
-		<keyword>const</keyword>
-		<keyword>continue</keyword>
-		<keyword>declare</keyword>
-		<keyword>default</keyword>
-		<keyword>die</keyword>
-		<keyword>do</keyword>
-		<keyword>echo</keyword>
-		<keyword>else</keyword>
-		<keyword>elseif</keyword>
-		<keyword>empty</keyword>
-		<keyword>enddeclare</keyword>
-		<keyword>endfor</keyword>
-		<keyword>endforeach</keyword>
-		<keyword>endif</keyword>
-		<keyword>endswitch</keyword>
-		<keyword>endwhile</keyword>
-		<keyword>eval</keyword>
-		<keyword>exit</keyword>
-		<keyword>extends</keyword>
-		<keyword>for</keyword>
-		<keyword>foreach</keyword>
-		<keyword>function</keyword>
-		<keyword>global</keyword>
-		<keyword>if</keyword>
-		<keyword>include</keyword>
-		<keyword>include_once</keyword>
-		<keyword>isset</keyword>
-		<keyword>list</keyword>
-		<keyword>new</keyword>
-		<keyword>print</keyword>
-		<keyword>require</keyword>
-		<keyword>require_once</keyword>
-		<keyword>return</keyword>
-		<keyword>static</keyword>
-		<keyword>switch</keyword>
-		<keyword>unset</keyword>
-		<keyword>use</keyword>
-		<keyword>var</keyword>
-		<keyword>while</keyword>
-		<keyword>__FUNCTION__</keyword>
-		<keyword>__CLASS__</keyword>
-		<keyword>__METHOD__</keyword>
-		<keyword>final</keyword>
-		<keyword>php_user_filter</keyword>
-		<keyword>interface</keyword>
-		<keyword>implements</keyword>
-		<keyword>extends</keyword>
-		<keyword>public</keyword>
-		<keyword>private</keyword>
-		<keyword>protected</keyword>
-		<keyword>abstract</keyword>
-		<keyword>clone</keyword>
-		<keyword>try</keyword>
-		<keyword>catch</keyword>
-		<keyword>throw</keyword>
-		<keyword>cfunction</keyword>
-		<keyword>old_function</keyword>
-		<keyword>true</keyword>
-		<keyword>false</keyword>
-		<!-- PHP 5.3 -->
-		<keyword>namespace</keyword>
-		<keyword>__NAMESPACE__</keyword>
-		<keyword>goto</keyword>
-		<keyword>__DIR__</keyword>
-		<ignoreCase />
-	</highlighter>
-	<highlighter type="word">
-		<!-- highlight the php open and close tags as directives -->
-		<word>?&gt;</word>
-		<word>&lt;?php</word>
-		<word>&lt;?=</word>
-		<style>directive</style>
-	</highlighter>
-</highlighters>

+ 0 - 100
stylesheets/lfs-xsl/docbook-xsl-1.78.1/highlighting/python-hl.xml

@@ -1,100 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<!--
-
-Syntax highlighting definition for Python
-
-xslthl - XSLT Syntax Highlighting
-http://sourceforge.net/projects/xslthl/
-Copyright (C) 2005-2008 Michal Molhanec, Jirka Kosek, Michiel Hendriks
-
-This software is provided 'as-is', without any express or implied
-warranty.  In no event will the authors be held liable for any damages
-arising from the use of this software.
-
-Permission is granted to anyone to use this software for any purpose,
-including commercial applications, and to alter it and redistribute it
-freely, subject to the following restrictions:
-
-1. The origin of this software must not be misrepresented; you must not
-   claim that you wrote the original software. If you use this software
-   in a product, an acknowledgment in the product documentation would be
-   appreciated but is not required.
-2. Altered source versions must be plainly marked as such, and must not be
-   misrepresented as being the original software.
-3. This notice may not be removed or altered from any source distribution.
-
-Michal Molhanec <mol1111 at users.sourceforge.net>
-Jirka Kosek <kosek at users.sourceforge.net>
-Michiel Hendriks <elmuerte at users.sourceforge.net>
-
--->
-<highlighters>
-	<highlighter type="annotation">
-		<!-- these are actually called decorators -->
-		<start>@</start>
-		<valueStart>(</valueStart>
-		<valueEnd>)</valueEnd>
-	</highlighter>
-	<highlighter type="oneline-comment">#</highlighter>
-	<highlighter type="string">
-		<string>"""</string>
-		<spanNewLines />
-	</highlighter>
-	<highlighter type="string">
-		<string>'''</string>
-		<spanNewLines />
-	</highlighter>
-	<highlighter type="string">
-		<string>"</string>
-		<escape>\</escape>
-	</highlighter>
-	<highlighter type="string">
-		<string>'</string>
-		<escape>\</escape>
-	</highlighter>
-	<highlighter type="hexnumber">
-		<prefix>0x</prefix>
-		<suffix>l</suffix>
-		<ignoreCase />
-	</highlighter>
-	<highlighter type="number">
-		<point>.</point>
-		<pointStarts />
-		<exponent>e</exponent>
-		<suffix>l</suffix>
-		<ignoreCase />
-	</highlighter>
-	<highlighter type="keywords">
-		<keyword>and</keyword>
-		<keyword>del</keyword>
-		<keyword>from</keyword>
-		<keyword>not</keyword>
-		<keyword>while</keyword>
-		<keyword>as</keyword>
-		<keyword>elif</keyword>
-		<keyword>global</keyword>
-		<keyword>or</keyword>
-		<keyword>with</keyword>
-		<keyword>assert</keyword>
-		<keyword>else</keyword>
-		<keyword>if</keyword>
-		<keyword>pass</keyword>
-		<keyword>yield</keyword>
-		<keyword>break</keyword>
-		<keyword>except</keyword>
-		<keyword>import</keyword>
-		<keyword>print</keyword>
-		<keyword>class</keyword>
-		<keyword>exec</keyword>
-		<keyword>in</keyword>
-		<keyword>raise</keyword>
-		<keyword>continue</keyword>
-		<keyword>finally</keyword>
-		<keyword>is</keyword>
-		<keyword>return</keyword>
-		<keyword>def</keyword>
-		<keyword>for</keyword>
-		<keyword>lambda</keyword>
-		<keyword>try</keyword>
-	</highlighter>
-</highlighters>

+ 0 - 109
stylesheets/lfs-xsl/docbook-xsl-1.78.1/highlighting/ruby-hl.xml

@@ -1,109 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<!--
-
-Syntax highlighting definition for Ruby
-
-xslthl - XSLT Syntax Highlighting
-http://sourceforge.net/projects/xslthl/
-Copyright (C) 2005-2008 Michal Molhanec, Jirka Kosek, Michiel Hendriks
-
-This software is provided 'as-is', without any express or implied
-warranty.  In no event will the authors be held liable for any damages
-arising from the use of this software.
-
-Permission is granted to anyone to use this software for any purpose,
-including commercial applications, and to alter it and redistribute it
-freely, subject to the following restrictions:
-
-1. The origin of this software must not be misrepresented; you must not
-   claim that you wrote the original software. If you use this software
-   in a product, an acknowledgment in the product documentation would be
-   appreciated but is not required.
-2. Altered source versions must be plainly marked as such, and must not be
-   misrepresented as being the original software.
-3. This notice may not be removed or altered from any source distribution.
-
-Michal Molhanec <mol1111 at users.sourceforge.net>
-Jirka Kosek <kosek at users.sourceforge.net>
-Michiel Hendriks <elmuerte at users.sourceforge.net>
-
--->
-<highlighters>
-	<highlighter type="oneline-comment">#</highlighter>
-	<highlighter type="heredoc">
-		<start>&lt;&lt;</start>
-		<noWhiteSpace/>
-	</highlighter>
-	<highlighter type="string">
-		<string>"</string>
-		<escape>\</escape>
-	</highlighter>
-	<highlighter type="string">
-		<string>%Q{</string>
-		<endString>}</endString>
-		<escape>\</escape>
-	</highlighter>
-	<highlighter type="string">
-		<string>%/</string>
-		<endString>/</endString>
-		<escape>\</escape>
-	</highlighter>
-	<highlighter type="string">
-		<string>'</string>
-		<escape>\</escape>
-	</highlighter>
-	<highlighter type="string">
-		<string>%q{</string>
-		<endString>}</endString>
-		<escape>\</escape>
-	</highlighter>
-	<highlighter type="hexnumber">
-		<prefix>0x</prefix>
-		<ignoreCase />
-	</highlighter>
-	<highlighter type="number">
-		<point>.</point>
-		<exponent>e</exponent>
-		<ignoreCase />
-	</highlighter>
-	<highlighter type="keywords">
-		<keyword>alias</keyword>
-		<keyword>and</keyword>
-		<keyword>BEGIN</keyword>
-		<keyword>begin</keyword>
-		<keyword>break</keyword>
-		<keyword>case</keyword>
-		<keyword>class</keyword>
-		<keyword>def</keyword>
-		<keyword>defined</keyword>
-		<keyword>do</keyword>
-		<keyword>else</keyword>
-		<keyword>elsif</keyword>
-		<keyword>END</keyword>
-		<keyword>end</keyword>
-		<keyword>ensure</keyword>
-		<keyword>false</keyword>
-		<keyword>for</keyword>
-		<keyword>if</keyword>
-		<keyword>in</keyword>
-		<keyword>module</keyword>
-		<keyword>next</keyword>
-		<keyword>nil</keyword>
-		<keyword>not</keyword>
-		<keyword>or</keyword>
-		<keyword>redo</keyword>
-		<keyword>rescue</keyword>
-		<keyword>retry</keyword>
-		<keyword>return</keyword>
-		<keyword>self</keyword>
-		<keyword>super</keyword>
-		<keyword>then</keyword>
-		<keyword>true</keyword>
-		<keyword>undef</keyword>
-		<keyword>unless</keyword>
-		<keyword>until</keyword>
-		<keyword>when</keyword>
-		<keyword>while</keyword>
-		<keyword>yield</keyword>
-	</highlighter>
-</highlighters>

+ 0 - 496
stylesheets/lfs-xsl/docbook-xsl-1.78.1/highlighting/sql1999-hl.xml

@@ -1,496 +0,0 @@
-<?xml version="1.0" encoding="utf-8"?>
-<!--
-
-Syntax highlighting definition for SQL:1999
-
-xslthl - XSLT Syntax Highlighting
-http://sourceforge.net/projects/xslthl/
-Copyright (C) 2012 Michiel Hendriks, Martin Hujer, k42b3
-
-This software is provided 'as-is', without any express or implied
-warranty.  In no event will the authors be held liable for any damages
-arising from the use of this software.
-
-Permission is granted to anyone to use this software for any purpose,
-including commercial applications, and to alter it and redistribute it
-freely, subject to the following restrictions:
-
-1. The origin of this software must not be misrepresented; you must not
-   claim that you wrote the original software. If you use this software
-   in a product, an acknowledgment in the product documentation would be
-   appreciated but is not required.
-2. Altered source versions must be plainly marked as such, and must not be
-   misrepresented as being the original software.
-3. This notice may not be removed or altered from any source distribution.
-
--->
-<highlighters>
-	<highlighter type="oneline-comment">--</highlighter>
-	<highlighter type="multiline-comment">
-		<start>/*</start>
-		<end>*/</end>
-	</highlighter>
-	<highlighter type="string">
-		<string>'</string>
-		<doubleEscapes />
-	</highlighter>
-	<highlighter type="string">
-		<string>B'</string>
-		<endString>'</endString>
-		<doubleEscapes />
-	</highlighter>
-	<highlighter type="string">
-		<string>N'</string>
-		<endString>'</endString>
-		<doubleEscapes />
-	</highlighter>
-	<highlighter type="string">
-		<string>X'</string>
-		<endString>'</endString>
-		<doubleEscapes />
-	</highlighter>
-	<highlighter type="number">
-		<point>.</point>
-		<pointStarts />
-		<exponent>e</exponent>
-		<ignoreCase />
-	</highlighter>
-	<highlighter type="keywords">
-		<ignoreCase />
-		<!-- reserved -->
-		<keyword>ABSOLUTE</keyword>
-		<keyword>ACTION</keyword>
-		<keyword>ADD</keyword>
-		<keyword>AFTER</keyword>
-		<keyword>ALL</keyword>
-		<keyword>ALLOCATE</keyword>
-		<keyword>ALTER</keyword>
-		<keyword>AND</keyword>
-		<keyword>ANY</keyword>
-		<keyword>ARE</keyword>
-		<keyword>ARRAY</keyword>
-		<keyword>AS</keyword>
-		<keyword>ASC</keyword>
-		<keyword>ASSERTION</keyword>
-		<keyword>AT</keyword>
-		<keyword>AUTHORIZATION</keyword>
-		<keyword>BEFORE</keyword>
-		<keyword>BEGIN</keyword>
-		<keyword>BETWEEN</keyword>
-		<keyword>BINARY</keyword>
-		<keyword>BIT</keyword>
-		<keyword>BLOB</keyword>
-		<keyword>BOOLEAN</keyword>
-		<keyword>BOTH</keyword>
-		<keyword>BREADTH</keyword>
-		<keyword>BY</keyword>
-		<keyword>CALL</keyword>
-		<keyword>CASCADE</keyword>
-		<keyword>CASCADED</keyword>
-		<keyword>CASE</keyword>
-		<keyword>CAST</keyword>
-		<keyword>CATALOG</keyword>
-		<keyword>CHAR</keyword>
-		<keyword>CHARACTER</keyword>
-		<keyword>CHECK</keyword>
-		<keyword>CLOB</keyword>
-		<keyword>CLOSE</keyword>
-		<keyword>COLLATE</keyword>
-		<keyword>COLLATION</keyword>
-		<keyword>COLUMN</keyword>
-		<keyword>COMMIT</keyword>
-		<keyword>CONDITION</keyword>
-		<keyword>CONNECT</keyword>
-		<keyword>CONNECTION</keyword>
-		<keyword>CONSTRAINT</keyword>
-		<keyword>CONSTRAINTS</keyword>
-		<keyword>CONSTRUCTOR</keyword>
-		<keyword>CONTINUE</keyword>
-		<keyword>CORRESPONDING</keyword>
-		<keyword>CREATE</keyword>
-		<keyword>CROSS</keyword>
-		<keyword>CUBE</keyword>
-		<keyword>CURRENT</keyword>
-		<keyword>CURRENT_DATE</keyword>
-		<keyword>CURRENT_DEFAULT_TRANSFORM_GROUP</keyword>
-		<keyword>CURRENT_TRANSFORM_GROUP_FOR_TYPE</keyword>
-		<keyword>CURRENT_PATH</keyword>
-		<keyword>CURRENT_ROLE</keyword>
-		<keyword>CURRENT_TIME</keyword>
-		<keyword>CURRENT_TIMESTAMP</keyword>
-		<keyword>CURRENT_USER</keyword>
-		<keyword>CURSOR</keyword>
-		<keyword>CYCLE</keyword>
-		<keyword>DATA</keyword>
-		<keyword>DATE</keyword>
-		<keyword>DAY</keyword>
-		<keyword>DEALLOCATE</keyword>
-		<keyword>DEC</keyword>
-		<keyword>DECIMAL</keyword>
-		<keyword>DECLARE</keyword>
-		<keyword>DEFAULT</keyword>
-		<keyword>DEFERRABLE</keyword>
-		<keyword>DEFERRED</keyword>
-		<keyword>DELETE</keyword>
-		<keyword>DEPTH</keyword>
-		<keyword>DEREF</keyword>
-		<keyword>DESC</keyword>
-		<keyword>DESCRIBE</keyword>
-		<keyword>DESCRIPTOR</keyword>
-		<keyword>DETERMINISTIC</keyword>
-		<keyword>DIAGNOSTICS</keyword>
-		<keyword>DISCONNECT</keyword>
-		<keyword>DISTINCT</keyword>
-		<keyword>DO</keyword>
-		<keyword>DOMAIN</keyword>
-		<keyword>DOUBLE</keyword>
-		<keyword>DROP</keyword>
-		<keyword>DYNAMIC</keyword>
-		<keyword>EACH</keyword>
-		<keyword>ELSE</keyword>
-		<keyword>ELSEIF</keyword>
-		<keyword>END</keyword>
-		<keyword>END-EXEC</keyword>
-		<keyword>EQUALS</keyword>
-		<keyword>ESCAPE</keyword>
-		<keyword>EXCEPT</keyword>
-		<keyword>EXCEPTION</keyword>
-		<keyword>EXEC</keyword>
-		<keyword>EXECUTE</keyword>
-		<keyword>EXISTS</keyword>
-		<keyword>EXIT</keyword>
-		<keyword>EXTERNAL</keyword>
-		<keyword>FALSE</keyword>
-		<keyword>FETCH</keyword>
-		<keyword>FIRST</keyword>
-		<keyword>FLOAT</keyword>
-		<keyword>FOR</keyword>
-		<keyword>FOREIGN</keyword>
-		<keyword>FOUND</keyword>
-		<keyword>FROM</keyword>
-		<keyword>FREE</keyword>
-		<keyword>FULL</keyword>
-		<keyword>FUNCTION</keyword>
-		<keyword>GENERAL</keyword>
-		<keyword>GET</keyword>
-		<keyword>GLOBAL</keyword>
-		<keyword>GO</keyword>
-		<keyword>GOTO</keyword>
-		<keyword>GRANT</keyword>
-		<keyword>GROUP</keyword>
-		<keyword>GROUPING</keyword>
-		<keyword>HANDLE</keyword>
-		<keyword>HAVING</keyword>
-		<keyword>HOLD</keyword>
-		<keyword>HOUR</keyword>
-		<keyword>IDENTITY</keyword>
-		<keyword>IF</keyword>
-		<keyword>IMMEDIATE</keyword>
-		<keyword>IN</keyword>
-		<keyword>INDICATOR</keyword>
-		<keyword>INITIALLY</keyword>
-		<keyword>INNER</keyword>
-		<keyword>INOUT</keyword>
-		<keyword>INPUT</keyword>
-		<keyword>INSERT</keyword>
-		<keyword>INT</keyword>
-		<keyword>INTEGER</keyword>
-		<keyword>INTERSECT</keyword>
-		<keyword>INTERVAL</keyword>
-		<keyword>INTO</keyword>
-		<keyword>IS</keyword>
-		<keyword>ISOLATION</keyword>
-		<keyword>JOIN</keyword>
-		<keyword>KEY</keyword>
-		<keyword>LANGUAGE</keyword>
-		<keyword>LARGE</keyword>
-		<keyword>LAST</keyword>
-		<keyword>LATERAL</keyword>
-		<keyword>LEADING</keyword>
-		<keyword>LEAVE</keyword>
-		<keyword>LEFT</keyword>
-		<keyword>LEVEL</keyword>
-		<keyword>LIKE</keyword>
-		<keyword>LOCAL</keyword>
-		<keyword>LOCALTIME</keyword>
-		<keyword>LOCALTIMESTAMP</keyword>
-		<keyword>LOCATOR</keyword>
-		<keyword>LOOP</keyword>
-		<keyword>MAP</keyword>
-		<keyword>MATCH</keyword>
-		<keyword>METHOD</keyword>
-		<keyword>MINUTE</keyword>
-		<keyword>MODIFIES</keyword>
-		<keyword>MODULE</keyword>
-		<keyword>MONTH</keyword>
-		<keyword>NAMES</keyword>
-		<keyword>NATIONAL</keyword>
-		<keyword>NATURAL</keyword>
-		<keyword>NCHAR</keyword>
-		<keyword>NCLOB</keyword>
-		<keyword>NESTING</keyword>
-		<keyword>NEW</keyword>
-		<keyword>NEXT</keyword>
-		<keyword>NO</keyword>
-		<keyword>NONE</keyword>
-		<keyword>NOT</keyword>
-		<keyword>NULL</keyword>
-		<keyword>NUMERIC</keyword>
-		<keyword>OBJECT</keyword>
-		<keyword>OF</keyword>
-		<keyword>OLD</keyword>
-		<keyword>ON</keyword>
-		<keyword>ONLY</keyword>
-		<keyword>OPEN</keyword>
-		<keyword>OPTION</keyword>
-		<keyword>OR</keyword>
-		<keyword>ORDER</keyword>
-		<keyword>ORDINALITY</keyword>
-		<keyword>OUT</keyword>
-		<keyword>OUTER</keyword>
-		<keyword>OUTPUT</keyword>
-		<keyword>OVERLAPS</keyword>
-		<keyword>PAD</keyword>
-		<keyword>PARAMETER</keyword>
-		<keyword>PARTIAL</keyword>
-		<keyword>PATH</keyword>
-		<keyword>PRECISION</keyword>
-		<keyword>PREPARE</keyword>
-		<keyword>PRESERVE</keyword>
-		<keyword>PRIMARY</keyword>
-		<keyword>PRIOR</keyword>
-		<keyword>PRIVILEGES</keyword>
-		<keyword>PROCEDURE</keyword>
-		<keyword>PUBLIC</keyword>
-		<keyword>READ</keyword>
-		<keyword>READS</keyword>
-		<keyword>REAL</keyword>
-		<keyword>RECURSIVE</keyword>
-		<keyword>REDO</keyword>
-		<keyword>REF</keyword>
-		<keyword>REFERENCES</keyword>
-		<keyword>REFERENCING</keyword>
-		<keyword>RELATIVE</keyword>
-		<keyword>RELEASE</keyword>
-		<keyword>REPEAT</keyword>
-		<keyword>RESIGNAL</keyword>
-		<keyword>RESTRICT</keyword>
-		<keyword>RESULT</keyword>
-		<keyword>RETURN</keyword>
-		<keyword>RETURNS</keyword>
-		<keyword>REVOKE</keyword>
-		<keyword>RIGHT</keyword>
-		<keyword>ROLE</keyword>
-		<keyword>ROLLBACK</keyword>
-		<keyword>ROLLUP</keyword>
-		<keyword>ROUTINE</keyword>
-		<keyword>ROW</keyword>
-		<keyword>ROWS</keyword>
-		<keyword>SAVEPOINT</keyword>
-		<keyword>SCHEMA</keyword>
-		<keyword>SCROLL</keyword>
-		<keyword>SEARCH</keyword>
-		<keyword>SECOND</keyword>
-		<keyword>SECTION</keyword>
-		<keyword>SELECT</keyword>
-		<keyword>SESSION</keyword>
-		<keyword>SESSION_USER</keyword>
-		<keyword>SET</keyword>
-		<keyword>SETS</keyword>
-		<keyword>SIGNAL</keyword>
-		<keyword>SIMILAR</keyword>
-		<keyword>SIZE</keyword>
-		<keyword>SMALLINT</keyword>
-		<keyword>SOME</keyword>
-		<keyword>SPACE</keyword>
-		<keyword>SPECIFIC</keyword>
-		<keyword>SPECIFICTYPE</keyword>
-		<keyword>SQL</keyword>
-		<keyword>SQLEXCEPTION</keyword>
-		<keyword>SQLSTATE</keyword>
-		<keyword>SQLWARNING</keyword>
-		<keyword>START</keyword>
-		<keyword>STATE</keyword>
-		<keyword>STATIC</keyword>
-		<keyword>SYSTEM_USER</keyword>
-		<keyword>TABLE</keyword>
-		<keyword>TEMPORARY</keyword>
-		<keyword>THEN</keyword>
-		<keyword>TIME</keyword>
-		<keyword>TIMESTAMP</keyword>
-		<keyword>TIMEZONE_HOUR</keyword>
-		<keyword>TIMEZONE_MINUTE</keyword>
-		<keyword>TO</keyword>
-		<keyword>TRAILING</keyword>
-		<keyword>TRANSACTION</keyword>
-		<keyword>TRANSLATION</keyword>
-		<keyword>TREAT</keyword>
-		<keyword>TRIGGER</keyword>
-		<keyword>TRUE</keyword>
-		<keyword>UNDER</keyword>
-		<keyword>UNDO</keyword>
-		<keyword>UNION</keyword>
-		<keyword>UNIQUE</keyword>
-		<keyword>UNKNOWN</keyword>
-		<keyword>UNNEST</keyword>
-		<keyword>UNTIL</keyword>
-		<keyword>UPDATE</keyword>
-		<keyword>USAGE</keyword>
-		<keyword>USER</keyword>
-		<keyword>USING</keyword>
-		<keyword>VALUE</keyword>
-		<keyword>VALUES</keyword>
-		<keyword>VARCHAR</keyword>
-		<keyword>VARYING</keyword>
-		<keyword>VIEW</keyword>
-		<keyword>WHEN</keyword>
-		<keyword>WHENEVER</keyword>
-		<keyword>WHERE</keyword>
-		<keyword>WHILE</keyword>
-		<keyword>WITH</keyword>
-		<keyword>WITHOUT</keyword>
-		<keyword>WORK</keyword>
-		<keyword>WRITE</keyword>
-		<keyword>YEAR</keyword>
-		<keyword>ZONE</keyword>
-		<!-- non reserved -->
-		<keyword>ABS</keyword>
-		<keyword>ADA</keyword>
-		<keyword>ADMIN</keyword>
-		<keyword>ASENSITIVE</keyword>
-		<keyword>ASSIGNMENT</keyword>
-		<keyword>ASYMMETRIC</keyword>
-		<keyword>ATOMIC</keyword>
-		<keyword>ATTRIBUTE</keyword>
-		<keyword>AVG</keyword>
-		<keyword>BIT_LENGTH</keyword>
-		<keyword>C</keyword>
-		<keyword>CALLED</keyword>
-		<keyword>CARDINALITY</keyword>
-		<keyword>CATALOG_NAME</keyword>
-		<keyword>CHAIN</keyword>
-		<keyword>CHAR_LENGTH</keyword>
-		<keyword>CHARACTERISTICS</keyword>
-		<keyword>CHARACTER_LENGTH</keyword>
-		<keyword>CHARACTER_SET_CATALOG</keyword>
-		<keyword>CHARACTER_SET_NAME</keyword>
-		<keyword>CHARACTER_SET_SCHEMA</keyword>
-		<keyword>CHECKED</keyword>
-		<keyword>CLASS_ORIGIN</keyword>
-		<keyword>COALESCE</keyword>
-		<keyword>COBOL</keyword>
-		<keyword>COLLATION_CATALOG</keyword>
-		<keyword>COLLATION_NAME</keyword>
-		<keyword>COLLATION_SCHEMA</keyword>
-		<keyword>COLUMN_NAME</keyword>
-		<keyword>COMMAND_FUNCTION</keyword>
-		<keyword>COMMAND_FUNCTION_CODE</keyword>
-		<keyword>COMMITTED</keyword>
-		<keyword>CONDITION_IDENTIFIER</keyword>
-		<keyword>CONDITION_NUMBER</keyword>
-		<keyword>CONNECTION_NAME</keyword>
-		<keyword>CONSTRAINT_CATALOG</keyword>
-		<keyword>CONSTRAINT_NAME</keyword>
-		<keyword>CONSTRAINT_SCHEMA</keyword>
-		<keyword>CONTAINS</keyword>
-		<keyword>CONVERT</keyword>
-		<keyword>COUNT</keyword>
-		<keyword>CURSOR_NAME</keyword>
-		<keyword>DATETIME_INTERVAL_CODE</keyword>
-		<keyword>DATETIME_INTERVAL_PRECISION</keyword>
-		<keyword>DEFINED</keyword>
-		<keyword>DEFINER</keyword>
-		<keyword>DEGREE</keyword>
-		<keyword>DERIVED</keyword>
-		<keyword>DISPATCH</keyword>
-		<keyword>EVERY</keyword>
-		<keyword>EXTRACT</keyword>
-		<keyword>FINAL</keyword>
-		<keyword>FORTRAN</keyword>
-		<keyword>G</keyword>
-		<keyword>GENERATED</keyword>
-		<keyword>GRANTED</keyword>
-		<keyword>HIERARCHY</keyword>
-		<keyword>IMPLEMENTATION</keyword>
-		<keyword>INSENSITIVE</keyword>
-		<keyword>INSTANCE</keyword>
-		<keyword>INSTANTIABLE</keyword>
-		<keyword>INVOKER</keyword>
-		<keyword>K</keyword>
-		<keyword>KEY_MEMBER</keyword>
-		<keyword>KEY_TYPE</keyword>
-		<keyword>LENGTH</keyword>
-		<keyword>LOWER</keyword>
-		<keyword>M</keyword>
-		<keyword>MAX</keyword>
-		<keyword>MIN</keyword>
-		<keyword>MESSAGE_LENGTH</keyword>
-		<keyword>MESSAGE_OCTET_LENGTH</keyword>
-		<keyword>MESSAGE_TEXT</keyword>
-		<keyword>MOD</keyword>
-		<keyword>MORE</keyword>
-		<keyword>MUMPS</keyword>
-		<keyword>NAME</keyword>
-		<keyword>NULLABLE</keyword>
-		<keyword>NUMBER</keyword>
-		<keyword>NULLIF</keyword>
-		<keyword>OCTET_LENGTH</keyword>
-		<keyword>ORDERING</keyword>
-		<keyword>OPTIONS</keyword>
-		<keyword>OVERLAY</keyword>
-		<keyword>OVERRIDING</keyword>
-		<keyword>PASCAL</keyword>
-		<keyword>PARAMETER_MODE</keyword>
-		<keyword>PARAMETER_NAME</keyword>
-		<keyword>PARAMETER_ORDINAL_POSITION</keyword>
-		<keyword>PARAMETER_SPECIFIC_CATALOG</keyword>
-		<keyword>PARAMETER_SPECIFIC_NAME</keyword>
-		<keyword>PARAMETER_SPECIFIC_SCHEMA</keyword>
-		<keyword>PLI</keyword>
-		<keyword>POSITION</keyword>
-		<keyword>REPEATABLE</keyword>
-		<keyword>RETURNED_CARDINALITY</keyword>
-		<keyword>RETURNED_LENGTH</keyword>
-		<keyword>RETURNED_OCTET_LENGTH</keyword>
-		<keyword>RETURNED_SQLSTATE</keyword>
-		<keyword>ROUTINE_CATALOG</keyword>
-		<keyword>ROUTINE_NAME</keyword>
-		<keyword>ROUTINE_SCHEMA</keyword>
-		<keyword>ROW_COUNT</keyword>
-		<keyword>SCALE</keyword>
-		<keyword>SCHEMA_NAME</keyword>
-		<keyword>SCOPE</keyword>
-		<keyword>SECURITY</keyword>
-		<keyword>SELF</keyword>
-		<keyword>SENSITIVE</keyword>
-		<keyword>SERIALIZABLE</keyword>
-		<keyword>SERVER_NAME</keyword>
-		<keyword>SIMPLE</keyword>
-		<keyword>SOURCE</keyword>
-		<keyword>SPECIFIC_NAME</keyword>
-		<keyword>STATEMENT</keyword>
-		<keyword>STRUCTURE</keyword>
-		<keyword>STYLE</keyword>
-		<keyword>SUBCLASS_ORIGIN</keyword>
-		<keyword>SUBSTRING</keyword>
-		<keyword>SUM</keyword>
-		<keyword>SYMMETRIC</keyword>
-		<keyword>SYSTEM</keyword>
-		<keyword>TABLE_NAME</keyword>
-		<keyword>TOP_LEVEL_COUNT</keyword>
-		<keyword>TRANSACTIONS_COMMITTED</keyword>
-		<keyword>TRANSACTIONS_ROLLED_BACK</keyword>
-		<keyword>TRANSACTION_ACTIVE</keyword>
-		<keyword>TRANSFORM</keyword>
-		<keyword>TRANSFORMS</keyword>
-		<keyword>TRANSLATE</keyword>
-		<keyword>TRIGGER_CATALOG</keyword>
-		<keyword>TRIGGER_SCHEMA</keyword>
-		<keyword>TRIGGER_NAME</keyword>
-		<keyword>TRIM</keyword>
-		<keyword>TYPE</keyword>
-		<keyword>UNCOMMITTED</keyword>
-		<keyword>UNNAMED</keyword>
-		<keyword>UPPER</keyword>
-	</highlighter>
-</highlighters>

+ 0 - 565
stylesheets/lfs-xsl/docbook-xsl-1.78.1/highlighting/sql2003-hl.xml

@@ -1,565 +0,0 @@
-<?xml version="1.0" encoding="utf-8"?>
-<!--
-
-Syntax highlighting definition for SQL:1999
-
-xslthl - XSLT Syntax Highlighting
-http://sourceforge.net/projects/xslthl/
-Copyright (C) 2012 Michiel Hendriks, Martin Hujer, k42b3
-
-This software is provided 'as-is', without any express or implied
-warranty.  In no event will the authors be held liable for any damages
-arising from the use of this software.
-
-Permission is granted to anyone to use this software for any purpose,
-including commercial applications, and to alter it and redistribute it
-freely, subject to the following restrictions:
-
-1. The origin of this software must not be misrepresented; you must not
-   claim that you wrote the original software. If you use this software
-   in a product, an acknowledgment in the product documentation would be
-   appreciated but is not required.
-2. Altered source versions must be plainly marked as such, and must not be
-   misrepresented as being the original software.
-3. This notice may not be removed or altered from any source distribution.
-
--->
-<highlighters>
-	<highlighter type="oneline-comment">--</highlighter>
-	<highlighter type="multiline-comment">
-		<start>/*</start>
-		<end>*/</end>
-	</highlighter>
-	<highlighter type="string">
-		<string>'</string>
-		<doubleEscapes />
-	</highlighter>
-	<highlighter type="string">
-		<string>U'</string>
-		<endString>'</endString>
-		<doubleEscapes />
-	</highlighter>
-	<highlighter type="string">
-		<string>B'</string>
-		<endString>'</endString>
-		<doubleEscapes />
-	</highlighter>
-	<highlighter type="string">
-		<string>N'</string>
-		<endString>'</endString>
-		<doubleEscapes />
-	</highlighter>
-	<highlighter type="string">
-		<string>X'</string>
-		<endString>'</endString>
-		<doubleEscapes />
-	</highlighter>
-	<highlighter type="number">
-		<point>.</point>
-		<pointStarts />
-		<exponent>e</exponent>
-		<ignoreCase />
-	</highlighter>
-	<highlighter type="keywords">
-		<ignoreCase />
-		<!-- reserved -->
-		<keyword>A</keyword>
-		<keyword>ABS</keyword>
-		<keyword>ABSOLUTE</keyword>
-		<keyword>ACTION</keyword>
-		<keyword>ADA</keyword>
-		<keyword>ADMIN</keyword>
-		<keyword>AFTER</keyword>
-		<keyword>ALWAYS</keyword>
-		<keyword>ASC</keyword>
-		<keyword>ASSERTION</keyword>
-		<keyword>ASSIGNMENT</keyword>
-		<keyword>ATTRIBUTE</keyword>
-		<keyword>ATTRIBUTES</keyword>
-		<keyword>AVG</keyword>
-		<keyword>BEFORE</keyword>
-		<keyword>BERNOULLI</keyword>
-		<keyword>BREADTH</keyword>
-		<keyword>C</keyword>
-		<keyword>CARDINALITY</keyword>
-		<keyword>CASCADE</keyword>
-		<keyword>CATALOG_NAME</keyword>
-		<keyword>CATALOG</keyword>
-		<keyword>CEIL</keyword>
-		<keyword>CEILING</keyword>
-		<keyword>CHAIN</keyword>
-		<keyword>CHAR_LENGTH</keyword>
-		<keyword>CHARACTER_LENGTH</keyword>
-		<keyword>CHARACTER_SET_CATALOG</keyword>
-		<keyword>CHARACTER_SET_NAME</keyword>
-		<keyword>CHARACTER_SET_SCHEMA</keyword>
-		<keyword>CHARACTERISTICS</keyword>
-		<keyword>CHARACTERS</keyword>
-		<keyword>CHECKED</keyword>
-		<keyword>CLASS_ORIGIN</keyword>
-		<keyword>COALESCE</keyword>
-		<keyword>COBOL</keyword>
-		<keyword>CODE_UNITS</keyword>
-		<keyword>COLLATION_CATALOG</keyword>
-		<keyword>COLLATION_NAME</keyword>
-		<keyword>COLLATION_SCHEMA</keyword>
-		<keyword>COLLATION</keyword>
-		<keyword>COLLECT</keyword>
-		<keyword>COLUMN_NAME</keyword>
-		<keyword>COMMAND_FUNCTION_CODE</keyword>
-		<keyword>COMMAND_FUNCTION</keyword>
-		<keyword>COMMITTED</keyword>
-		<keyword>CONDITION_NUMBER</keyword>
-		<keyword>CONDITION</keyword>
-		<keyword>CONNECTION_NAME</keyword>
-		<keyword>CONSTRAINT_CATALOG</keyword>
-		<keyword>CONSTRAINT_NAME</keyword>
-		<keyword>CONSTRAINT_SCHEMA</keyword>
-		<keyword>CONSTRAINTS</keyword>
-		<keyword>CONSTRUCTORS</keyword>
-		<keyword>CONTAINS</keyword>
-		<keyword>CONVERT</keyword>
-		<keyword>CORR</keyword>
-		<keyword>COUNT</keyword>
-		<keyword>COVAR_POP</keyword>
-		<keyword>COVAR_SAMP</keyword>
-		<keyword>CUME_DIST</keyword>
-		<keyword>CURRENT_COLLATION</keyword>
-		<keyword>CURSOR_NAME</keyword>
-		<keyword>DATA</keyword>
-		<keyword>DATETIME_INTERVAL_CODE</keyword>
-		<keyword>DATETIME_INTERVAL_PRECISION</keyword>
-		<keyword>DEFAULTS</keyword>
-		<keyword>DEFERRABLE</keyword>
-		<keyword>DEFERRED</keyword>
-		<keyword>DEFINED</keyword>
-		<keyword>DEFINER</keyword>
-		<keyword>DEGREE</keyword>
-		<keyword>DENSE_RANK</keyword>
-		<keyword>DEPTH</keyword>
-		<keyword>DERIVED</keyword>
-		<keyword>DESC</keyword>
-		<keyword>DESCRIPTOR</keyword>
-		<keyword>DIAGNOSTICS</keyword>
-		<keyword>DISPATCH</keyword>
-		<keyword>DOMAIN</keyword>
-		<keyword>DYNAMIC_FUNCTION_CODE</keyword>
-		<keyword>DYNAMIC_FUNCTION</keyword>
-		<keyword>EQUALS</keyword>
-		<keyword>EVERY</keyword>
-		<keyword>EXCEPTION</keyword>
-		<keyword>EXCLUDE</keyword>
-		<keyword>EXCLUDING</keyword>
-		<keyword>EXP</keyword>
-		<keyword>EXTRACT</keyword>
-		<keyword>FINAL</keyword>
-		<keyword>FIRST</keyword>
-		<keyword>FLOOR</keyword>
-		<keyword>FOLLOWING</keyword>
-		<keyword>FORTRAN</keyword>
-		<keyword>FOUND</keyword>
-		<keyword>FUSION</keyword>
-		<keyword>G</keyword>
-		<keyword>GENERAL</keyword>
-		<keyword>GO</keyword>
-		<keyword>GOTO</keyword>
-		<keyword>GRANTED</keyword>
-		<keyword>HIERARCHY</keyword>
-		<keyword>IMPLEMENTATION</keyword>
-		<keyword>INCLUDING</keyword>
-		<keyword>INCREMENT</keyword>
-		<keyword>INITIALLY</keyword>
-		<keyword>INSTANCE</keyword>
-		<keyword>INSTANTIABLE</keyword>
-		<keyword>INTERSECTION</keyword>
-		<keyword>INVOKER</keyword>
-		<keyword>ISOLATION</keyword>
-		<keyword>K</keyword>
-		<keyword>KEY_MEMBER</keyword>
-		<keyword>KEY_TYPE</keyword>
-		<keyword>KEY</keyword>
-		<keyword>LAST</keyword>
-		<keyword>LENGTH</keyword>
-		<keyword>LEVEL</keyword>
-		<keyword>LN</keyword>
-		<keyword>LOCATOR</keyword>
-		<keyword>LOWER</keyword>
-		<keyword>M</keyword>
-		<keyword>MAP</keyword>
-		<keyword>MATCHED</keyword>
-		<keyword>MAX</keyword>
-		<keyword>MAXVALUE</keyword>
-		<keyword>MESSAGE_LENGTH</keyword>
-		<keyword>MESSAGE_OCTET_LENGTH</keyword>
-		<keyword>MESSAGE_TEXT</keyword>
-		<keyword>MIN</keyword>
-		<keyword>MINVALUE</keyword>
-		<keyword>MOD</keyword>
-		<keyword>MORE</keyword>
-		<keyword>MUMPS</keyword>
-		<keyword>NAME</keyword>
-		<keyword>NAMES</keyword>
-		<keyword>NESTING</keyword>
-		<keyword>NEXT</keyword>
-		<keyword>NORMALIZE</keyword>
-		<keyword>NORMALIZED</keyword>
-		<keyword>NULLABLE</keyword>
-		<keyword>NULLIF</keyword>
-		<keyword>NULLS</keyword>
-		<keyword>NUMBER</keyword>
-		<keyword>OBJECT</keyword>
-		<keyword>OCTET_LENGTH</keyword>
-		<keyword>OCTETS</keyword>
-		<keyword>OPTION</keyword>
-		<keyword>OPTIONS</keyword>
-		<keyword>ORDERING</keyword>
-		<keyword>ORDINALITY</keyword>
-		<keyword>OTHERS</keyword>
-		<keyword>OVERLAY</keyword>
-		<keyword>OVERRIDING</keyword>
-		<keyword>PAD</keyword>
-		<keyword>PARAMETER_MODE</keyword>
-		<keyword>PARAMETER_NAME</keyword>
-		<keyword>PARAMETER_ORDINAL_POSITION</keyword>
-		<keyword>PARAMETER_SPECIFIC_CATALOG</keyword>
-		<keyword>PARAMETER_SPECIFIC_NAME</keyword>
-		<keyword>PARAMETER_SPECIFIC_SCHEMA</keyword>
-		<keyword>PARTIAL</keyword>
-		<keyword>PASCAL</keyword>
-		<keyword>PATH</keyword>
-		<keyword>PERCENT_RANK</keyword>
-		<keyword>PERCENTILE_CONT</keyword>
-		<keyword>PERCENTILE_DISC</keyword>
-		<keyword>PLACING</keyword>
-		<keyword>PLI</keyword>
-		<keyword>POSITION</keyword>
-		<keyword>POWER</keyword>
-		<keyword>PRECEDING</keyword>
-		<keyword>PRESERVE</keyword>
-		<keyword>PRIOR</keyword>
-		<keyword>PRIVILEGES</keyword>
-		<keyword>PUBLIC</keyword>
-		<keyword>RANK</keyword>
-		<keyword>READ</keyword>
-		<keyword>RELATIVE</keyword>
-		<keyword>REPEATABLE</keyword>
-		<keyword>RESTART</keyword>
-		<keyword>RETURNED_CARDINALITY</keyword>
-		<keyword>RETURNED_LENGTH</keyword>
-		<keyword>RETURNED_OCTET_LENGTH</keyword>
-		<keyword>RETURNED_SQLSTATE</keyword>
-		<keyword>ROLE</keyword>
-		<keyword>ROUTINE_CATALOG</keyword>
-		<keyword>ROUTINE_NAME</keyword>
-		<keyword>ROUTINE_SCHEMA</keyword>
-		<keyword>ROUTINE</keyword>
-		<keyword>ROW_COUNT</keyword>
-		<keyword>ROW_NUMBER</keyword>
-		<keyword>SCALE</keyword>
-		<keyword>SCHEMA_NAME</keyword>
-		<keyword>SCHEMA</keyword>
-		<keyword>SCOPE_CATALOG</keyword>
-		<keyword>SCOPE_NAME</keyword>
-		<keyword>SCOPE_SCHEMA</keyword>
-		<keyword>SECTION</keyword>
-		<keyword>SECURITY</keyword>
-		<keyword>SELF</keyword>
-		<keyword>SEQUENCE</keyword>
-		<keyword>SERIALIZABLE</keyword>
-		<keyword>SERVER_NAME</keyword>
-		<keyword>SESSION</keyword>
-		<keyword>SETS</keyword>
-		<keyword>SIMPLE</keyword>
-		<keyword>SIZE</keyword>
-		<keyword>SOURCE</keyword>
-		<keyword>SPACE</keyword>
-		<keyword>SPECIFIC_NAME</keyword>
-		<keyword>SQRT</keyword>
-		<keyword>STATE</keyword>
-		<keyword>STATEMENT</keyword>
-		<keyword>STDDEV_POP</keyword>
-		<keyword>STDDEV_SAMP</keyword>
-		<keyword>STRUCTURE</keyword>
-		<keyword>STYLE</keyword>
-		<keyword>SUBCLASS_ORIGIN</keyword>
-		<keyword>SUBSTRING</keyword>
-		<keyword>SUM</keyword>
-		<keyword>TABLE_NAME</keyword>
-		<keyword>TABLESAMPLE</keyword>
-		<keyword>TEMPORARY</keyword>
-		<keyword>TIES</keyword>
-		<keyword>TOP_LEVEL_COUNT</keyword>
-		<keyword>TRANSACTION_ACTIVE</keyword>
-		<keyword>TRANSACTION</keyword>
-		<keyword>TRANSACTIONS_COMMITTED</keyword>
-		<keyword>TRANSACTIONS_ROLLED_BACK</keyword>
-		<keyword>TRANSFORM</keyword>
-		<keyword>TRANSFORMS</keyword>
-		<keyword>TRANSLATE</keyword>
-		<keyword>TRIGGER_CATALOG</keyword>
-		<keyword>TRIGGER_NAME</keyword>
-		<keyword>TRIGGER_SCHEMA</keyword>
-		<keyword>TRIM</keyword>
-		<keyword>TYPE</keyword>
-		<keyword>UNBOUNDED</keyword>
-		<keyword>UNCOMMITTED</keyword>
-		<keyword>UNDER</keyword>
-		<keyword>UNNAMED</keyword>
-		<keyword>USAGE</keyword>
-		<keyword>USER_DEFINED_TYPE_CATALOG</keyword>
-		<keyword>USER_DEFINED_TYPE_CODE</keyword>
-		<keyword>USER_DEFINED_TYPE_NAME</keyword>
-		<keyword>USER_DEFINED_TYPE_SCHEMA</keyword>
-		<keyword>VIEW</keyword>
-		<keyword>WORK</keyword>
-		<keyword>WRITE</keyword>
-		<keyword>ZONE</keyword>
-		<!-- non reserved -->
-		<keyword>ADD</keyword>
-		<keyword>ALL</keyword>
-		<keyword>ALLOCATE</keyword>
-		<keyword>ALTER</keyword>
-		<keyword>AND</keyword>
-		<keyword>ANY</keyword>
-		<keyword>ARE</keyword>
-		<keyword>ARRAY</keyword>
-		<keyword>AS</keyword>
-		<keyword>ASENSITIVE</keyword>
-		<keyword>ASYMMETRIC</keyword>
-		<keyword>AT</keyword>
-		<keyword>ATOMIC</keyword>
-		<keyword>AUTHORIZATION</keyword>
-		<keyword>BEGIN</keyword>
-		<keyword>BETWEEN</keyword>
-		<keyword>BIGINT</keyword>
-		<keyword>BINARY</keyword>
-		<keyword>BLOB</keyword>
-		<keyword>BOOLEAN</keyword>
-		<keyword>BOTH</keyword>
-		<keyword>BY</keyword>
-		<keyword>CALL</keyword>
-		<keyword>CALLED</keyword>
-		<keyword>CASCADED</keyword>
-		<keyword>CASE</keyword>
-		<keyword>CAST</keyword>
-		<keyword>CHAR</keyword>
-		<keyword>CHARACTER</keyword>
-		<keyword>CHECK</keyword>
-		<keyword>CLOB</keyword>
-		<keyword>CLOSE</keyword>
-		<keyword>COLLATE</keyword>
-		<keyword>COLUMN</keyword>
-		<keyword>COMMIT</keyword>
-		<keyword>CONNECT</keyword>
-		<keyword>CONSTRAINT</keyword>
-		<keyword>CONTINUE</keyword>
-		<keyword>CORRESPONDING</keyword>
-		<keyword>CREATE</keyword>
-		<keyword>CROSS</keyword>
-		<keyword>CUBE</keyword>
-		<keyword>CURRENT_DATE</keyword>
-		<keyword>CURRENT_DEFAULT_TRANSFORM_GROUP</keyword>
-		<keyword>CURRENT_PATH</keyword>
-		<keyword>CURRENT_ROLE</keyword>
-		<keyword>CURRENT_TIME</keyword>
-		<keyword>CURRENT_TIMESTAMP</keyword>
-		<keyword>CURRENT_TRANSFORM_GROUP_FOR_TYPE</keyword>
-		<keyword>CURRENT_USER</keyword>
-		<keyword>CURRENT</keyword>
-		<keyword>CURSOR</keyword>
-		<keyword>CYCLE</keyword>
-		<keyword>DATE</keyword>
-		<keyword>DAY</keyword>
-		<keyword>DEALLOCATE</keyword>
-		<keyword>DEC</keyword>
-		<keyword>DECIMAL</keyword>
-		<keyword>DECLARE</keyword>
-		<keyword>DEFAULT</keyword>
-		<keyword>DELETE</keyword>
-		<keyword>DEREF</keyword>
-		<keyword>DESCRIBE</keyword>
-		<keyword>DETERMINISTIC</keyword>
-		<keyword>DISCONNECT</keyword>
-		<keyword>DISTINCT</keyword>
-		<keyword>DOUBLE</keyword>
-		<keyword>DROP</keyword>
-		<keyword>DYNAMIC</keyword>
-		<keyword>EACH</keyword>
-		<keyword>ELEMENT</keyword>
-		<keyword>ELSE</keyword>
-		<keyword>END</keyword>
-		<keyword>END-EXEC</keyword>
-		<keyword>ESCAPE</keyword>
-		<keyword>EXCEPT</keyword>
-		<keyword>EXEC</keyword>
-		<keyword>EXECUTE</keyword>
-		<keyword>EXISTS</keyword>
-		<keyword>EXTERNAL</keyword>
-		<keyword>FALSE</keyword>
-		<keyword>FETCH</keyword>
-		<keyword>FILTER</keyword>
-		<keyword>FLOAT</keyword>
-		<keyword>FOR</keyword>
-		<keyword>FOREIGN</keyword>
-		<keyword>FREE</keyword>
-		<keyword>FROM</keyword>
-		<keyword>FULL</keyword>
-		<keyword>FUNCTION</keyword>
-		<keyword>GET</keyword>
-		<keyword>GLOBAL</keyword>
-		<keyword>GRANT</keyword>
-		<keyword>GROUP</keyword>
-		<keyword>GROUPING</keyword>
-		<keyword>HAVING</keyword>
-		<keyword>HOLD</keyword>
-		<keyword>HOUR</keyword>
-		<keyword>IDENTITY</keyword>
-		<keyword>IMMEDIATE</keyword>
-		<keyword>IN</keyword>
-		<keyword>INDICATOR</keyword>
-		<keyword>INNER</keyword>
-		<keyword>INOUT</keyword>
-		<keyword>INPUT</keyword>
-		<keyword>INSENSITIVE</keyword>
-		<keyword>INSERT</keyword>
-		<keyword>INT</keyword>
-		<keyword>INTEGER</keyword>
-		<keyword>INTERSECT</keyword>
-		<keyword>INTERVAL</keyword>
-		<keyword>INTO</keyword>
-		<keyword>IS</keyword>
-		<keyword>ISOLATION</keyword>
-		<keyword>JOIN</keyword>
-		<keyword>LANGUAGE</keyword>
-		<keyword>LARGE</keyword>
-		<keyword>LATERAL</keyword>
-		<keyword>LEADING</keyword>
-		<keyword>LEFT</keyword>
-		<keyword>LIKE</keyword>
-		<keyword>LOCAL</keyword>
-		<keyword>LOCALTIME</keyword>
-		<keyword>LOCALTIMESTAMP</keyword>
-		<keyword>MATCH</keyword>
-		<keyword>MEMBER</keyword>
-		<keyword>MERGE</keyword>
-		<keyword>METHOD</keyword>
-		<keyword>MINUTE</keyword>
-		<keyword>MODIFIES</keyword>
-		<keyword>MODULE</keyword>
-		<keyword>MONTH</keyword>
-		<keyword>MULTISET</keyword>
-		<keyword>NATIONAL</keyword>
-		<keyword>NATURAL</keyword>
-		<keyword>NCHAR</keyword>
-		<keyword>NCLOB</keyword>
-		<keyword>NEW</keyword>
-		<keyword>NO</keyword>
-		<keyword>NONE</keyword>
-		<keyword>NOT</keyword>
-		<keyword>NULL</keyword>
-		<keyword>NUMERIC</keyword>
-		<keyword>OF</keyword>
-		<keyword>OLD</keyword>
-		<keyword>ON</keyword>
-		<keyword>ONLY</keyword>
-		<keyword>OPEN</keyword>
-		<keyword>OR</keyword>
-		<keyword>ORDER</keyword>
-		<keyword>OUT</keyword>
-		<keyword>OUTER</keyword>
-		<keyword>OUTPUT</keyword>
-		<keyword>OVER</keyword>
-		<keyword>OVERLAPS</keyword>
-		<keyword>PARAMETER</keyword>
-		<keyword>PARTITION</keyword>
-		<keyword>PRECISION</keyword>
-		<keyword>PREPARE</keyword>
-		<keyword>PRIMARY</keyword>
-		<keyword>PROCEDURE</keyword>
-		<keyword>RANGE</keyword>
-		<keyword>READS</keyword>
-		<keyword>REAL</keyword>
-		<keyword>RECURSIVE</keyword>
-		<keyword>REF</keyword>
-		<keyword>REFERENCES</keyword>
-		<keyword>REFERENCING</keyword>
-		<keyword>REGR_AVGX</keyword>
-		<keyword>REGR_AVGY</keyword>
-		<keyword>REGR_COUNT</keyword>
-		<keyword>REGR_INTERCEPT</keyword>
-		<keyword>REGR_R2</keyword>
-		<keyword>REGR_SLOPE</keyword>
-		<keyword>REGR_SXX</keyword>
-		<keyword>REGR_SXY</keyword>
-		<keyword>REGR_SYY</keyword>
-		<keyword>RELEASE</keyword>
-		<keyword>RESULT</keyword>
-		<keyword>RETURN</keyword>
-		<keyword>RETURNS</keyword>
-		<keyword>REVOKE</keyword>
-		<keyword>RIGHT</keyword>
-		<keyword>ROLLBACK</keyword>
-		<keyword>ROLLUP</keyword>
-		<keyword>ROW</keyword>
-		<keyword>ROWS</keyword>
-		<keyword>SAVEPOINT</keyword>
-		<keyword>SCROLL</keyword>
-		<keyword>SEARCH</keyword>
-		<keyword>SECOND</keyword>
-		<keyword>SELECT</keyword>
-		<keyword>SENSITIVE</keyword>
-		<keyword>SESSION_USER</keyword>
-		<keyword>SET</keyword>
-		<keyword>SIMILAR</keyword>
-		<keyword>SMALLINT</keyword>
-		<keyword>SOME</keyword>
-		<keyword>SPECIFIC</keyword>
-		<keyword>SPECIFICTYPE</keyword>
-		<keyword>SQL</keyword>
-		<keyword>SQLEXCEPTION</keyword>
-		<keyword>SQLSTATE</keyword>
-		<keyword>SQLWARNING</keyword>
-		<keyword>START</keyword>
-		<keyword>STATIC</keyword>
-		<keyword>SUBMULTISET</keyword>
-		<keyword>SYMMETRIC</keyword>
-		<keyword>SYSTEM_USER</keyword>
-		<keyword>SYSTEM</keyword>
-		<keyword>TABLE</keyword>
-		<keyword>THEN</keyword>
-		<keyword>TIME</keyword>
-		<keyword>TIMESTAMP</keyword>
-		<keyword>TIMEZONE_HOUR</keyword>
-		<keyword>TIMEZONE_MINUTE</keyword>
-		<keyword>TO</keyword>
-		<keyword>TRAILING</keyword>
-		<keyword>TRANSLATION</keyword>
-		<keyword>TREAT</keyword>
-		<keyword>TRIGGER</keyword>
-		<keyword>TRUE</keyword>
-		<keyword>UESCAPE</keyword>
-		<keyword>UNION</keyword>
-		<keyword>UNIQUE</keyword>
-		<keyword>UNKNOWN</keyword>
-		<keyword>UNNEST</keyword>
-		<keyword>UPDATE</keyword>
-		<keyword>UPPER</keyword>
-		<keyword>USER</keyword>
-		<keyword>USING</keyword>
-		<keyword>VALUE</keyword>
-		<keyword>VALUES</keyword>
-		<keyword>VAR_POP</keyword>
-		<keyword>VAR_SAMP</keyword>
-		<keyword>VARCHAR</keyword>
-		<keyword>VARYING</keyword>
-		<keyword>WHEN</keyword>
-		<keyword>WHENEVER</keyword>
-		<keyword>WHERE</keyword>
-		<keyword>WIDTH_BUCKET</keyword>
-		<keyword>WINDOW</keyword>
-		<keyword>WITH</keyword>
-		<keyword>WITHIN</keyword>
-		<keyword>WITHOUT</keyword>
-		<keyword>YEAR</keyword>
-	</highlighter>
-</highlighters>

+ 0 - 339
stylesheets/lfs-xsl/docbook-xsl-1.78.1/highlighting/sql92-hl.xml

@@ -1,339 +0,0 @@
-<?xml version="1.0" encoding="utf-8"?>
-<!--
-
-Syntax highlighting definition for SQL-92
-
-xslthl - XSLT Syntax Highlighting
-http://sourceforge.net/projects/xslthl/
-Copyright (C) 2012 Michiel Hendriks, Martin Hujer, k42b3
-
-This software is provided 'as-is', without any express or implied
-warranty.  In no event will the authors be held liable for any damages
-arising from the use of this software.
-
-Permission is granted to anyone to use this software for any purpose,
-including commercial applications, and to alter it and redistribute it
-freely, subject to the following restrictions:
-
-1. The origin of this software must not be misrepresented; you must not
-   claim that you wrote the original software. If you use this software
-   in a product, an acknowledgment in the product documentation would be
-   appreciated but is not required.
-2. Altered source versions must be plainly marked as such, and must not be
-   misrepresented as being the original software.
-3. This notice may not be removed or altered from any source distribution.
-
--->
-<highlighters>
-	<highlighter type="oneline-comment">--</highlighter>
-	<highlighter type="multiline-comment">
-		<start>/*</start>
-		<end>*/</end>
-	</highlighter>
-	<highlighter type="string">
-		<string>'</string>
-		<doubleEscapes />
-	</highlighter>
-	<highlighter type="string">
-		<string>B'</string>
-		<endString>'</endString>
-		<doubleEscapes />
-	</highlighter>
-	<highlighter type="string">
-		<string>N'</string>
-		<endString>'</endString>
-		<doubleEscapes />
-	</highlighter>
-	<highlighter type="string">
-		<string>X'</string>
-		<endString>'</endString>
-		<doubleEscapes />
-	</highlighter>
-	<highlighter type="number">
-		<point>.</point>
-		<pointStarts />
-		<exponent>e</exponent>
-		<ignoreCase />
-	</highlighter>
-	<highlighter type="keywords">
-		<ignoreCase />
-		<!-- reserved -->
-		<keyword>ABSOLUTE</keyword>
-		<keyword>ACTION</keyword>
-		<keyword>ADD</keyword>
-		<keyword>ALL</keyword>
-		<keyword>ALLOCATE</keyword>
-		<keyword>ALTER</keyword>
-		<keyword>AND</keyword>
-		<keyword>ANY</keyword>
-		<keyword>ARE</keyword>
-		<keyword>AS</keyword>
-		<keyword>ASC</keyword>
-		<keyword>ASSERTION</keyword>
-		<keyword>AT</keyword>
-		<keyword>AUTHORIZATION</keyword>
-		<keyword>AVG</keyword>
-		<keyword>BEGIN</keyword>
-		<keyword>BETWEEN</keyword>
-		<keyword>BIT_LENGTH</keyword>
-		<keyword>BIT</keyword>
-		<keyword>BOTH</keyword>
-		<keyword>BY</keyword>
-		<keyword>CASCADE</keyword>
-		<keyword>CASCADED</keyword>
-		<keyword>CASE</keyword>
-		<keyword>CAST</keyword>
-		<keyword>CATALOG</keyword>
-		<keyword>CHAR_LENGTH</keyword>
-		<keyword>CHAR</keyword>
-		<keyword>CHARACTER_LENGTH</keyword>
-		<keyword>CHARACTER</keyword>
-		<keyword>CHECK</keyword>
-		<keyword>CLOSE</keyword>
-		<keyword>COALESCE</keyword>
-		<keyword>COLLATE</keyword>
-		<keyword>COLLATION</keyword>
-		<keyword>COLUMN</keyword>
-		<keyword>COMMIT</keyword>
-		<keyword>CONNECT</keyword>
-		<keyword>CONNECTION</keyword>
-		<keyword>CONSTRAINT</keyword>
-		<keyword>CONSTRAINTS</keyword>
-		<keyword>CONTINUE</keyword>
-		<keyword>CONVERT</keyword>
-		<keyword>CORRESPONDING</keyword>
-		<keyword>CREATE</keyword>
-		<keyword>CROSS</keyword>
-		<keyword>CURRENT_DATE</keyword>
-		<keyword>CURRENT_TIME</keyword>
-		<keyword>CURRENT_TIMESTAMP</keyword>
-		<keyword>CURRENT_USER</keyword>
-		<keyword>CURRENT</keyword>
-		<keyword>CURSOR</keyword>
-		<keyword>DATE</keyword>
-		<keyword>DAY</keyword>
-		<keyword>DEALLOCATE</keyword>
-		<keyword>DEC</keyword>
-		<keyword>DECIMAL</keyword>
-		<keyword>DECLARE</keyword>
-		<keyword>DEFAULT</keyword>
-		<keyword>DEFERRABLE</keyword>
-		<keyword>DEFERRED</keyword>
-		<keyword>DELETE</keyword>
-		<keyword>DESC</keyword>
-		<keyword>DESCRIBE</keyword>
-		<keyword>DESCRIPTOR</keyword>
-		<keyword>DIAGNOSTICS</keyword>
-		<keyword>DISCONNECT</keyword>
-		<keyword>DISTINCT</keyword>
-		<keyword>DOMAIN</keyword>
-		<keyword>DOUBLE</keyword>
-		<keyword>DROP</keyword>
-		<keyword>ELSE</keyword>
-		<keyword>END</keyword>
-		<keyword>END-EXEC</keyword>
-		<keyword>ESCAPE</keyword>
-		<keyword>EXCEPT</keyword>
-		<keyword>EXCEPTION</keyword>
-		<keyword>EXEC</keyword>
-		<keyword>EXECUTE</keyword>
-		<keyword>EXISTS</keyword>
-		<keyword>EXTERNAL</keyword>
-		<keyword>EXTRACT</keyword>
-		<keyword>FALSE</keyword>
-		<keyword>FETCH</keyword>
-		<keyword>FIRST</keyword>
-		<keyword>FLOAT</keyword>
-		<keyword>FOR</keyword>
-		<keyword>FOREIGN</keyword>
-		<keyword>FOUND</keyword>
-		<keyword>FROM</keyword>
-		<keyword>FULL</keyword>
-		<keyword>GET</keyword>
-		<keyword>GLOBAL</keyword>
-		<keyword>GO</keyword>
-		<keyword>GOTO</keyword>
-		<keyword>GRANT</keyword>
-		<keyword>GROUP</keyword>
-		<keyword>HAVING</keyword>
-		<keyword>HOUR</keyword>
-		<keyword>IDENTITY</keyword>
-		<keyword>IMMEDIATE</keyword>
-		<keyword>IN</keyword>
-		<keyword>INDICATOR</keyword>
-		<keyword>INITIALLY</keyword>
-		<keyword>INNER</keyword>
-		<keyword>INPUT</keyword>
-		<keyword>INSENSITIVE</keyword>
-		<keyword>INSERT</keyword>
-		<keyword>INT</keyword>
-		<keyword>INTEGER</keyword>
-		<keyword>INTERSECT</keyword>
-		<keyword>INTERVAL</keyword>
-		<keyword>INTO</keyword>
-		<keyword>IS</keyword>
-		<keyword>ISOLATION</keyword>
-		<keyword>JOIN</keyword>
-		<keyword>KEY</keyword>
-		<keyword>LANGUAGE</keyword>
-		<keyword>LAST</keyword>
-		<keyword>LEADING</keyword>
-		<keyword>LEFT</keyword>
-		<keyword>LEVEL</keyword>
-		<keyword>LIKE</keyword>
-		<keyword>LOCAL</keyword>
-		<keyword>LOWER</keyword>
-		<keyword>MATCH</keyword>
-		<keyword>MAX</keyword>
-		<keyword>MIN</keyword>
-		<keyword>MINUTE</keyword>
-		<keyword>MODULE</keyword>
-		<keyword>MONTH</keyword>
-		<keyword>NAMES</keyword>
-		<keyword>NATIONAL</keyword>
-		<keyword>NATURAL</keyword>
-		<keyword>NCHAR</keyword>
-		<keyword>NEXT</keyword>
-		<keyword>NO</keyword>
-		<keyword>NOT</keyword>
-		<keyword>NULL</keyword>
-		<keyword>NULLIF</keyword>
-		<keyword>NUMERIC</keyword>
-		<keyword>OCTET_LENGTH</keyword>
-		<keyword>OF</keyword>
-		<keyword>ON</keyword>
-		<keyword>ONLY</keyword>
-		<keyword>OPEN</keyword>
-		<keyword>OPTION</keyword>
-		<keyword>OR</keyword>
-		<keyword>ORDER</keyword>
-		<keyword>OUTER</keyword>
-		<keyword>OUTPUT</keyword>
-		<keyword>OVERLAPS</keyword>
-		<keyword>PAD</keyword>
-		<keyword>PARTIAL</keyword>
-		<keyword>POSITION</keyword>
-		<keyword>PRECISION</keyword>
-		<keyword>PREPARE</keyword>
-		<keyword>PRESERVE</keyword>
-		<keyword>PRIMARY</keyword>
-		<keyword>PRIOR</keyword>
-		<keyword>PRIVILEGES</keyword>
-		<keyword>PROCEDURE</keyword>
-		<keyword>PUBLIC</keyword>
-		<keyword>READ</keyword>
-		<keyword>REAL</keyword>
-		<keyword>REFERENCES</keyword>
-		<keyword>RELATIVE</keyword>
-		<keyword>RESTRICT</keyword>
-		<keyword>REVOKE</keyword>
-		<keyword>RIGHT</keyword>
-		<keyword>ROLLBACK</keyword>
-		<keyword>ROWS</keyword>
-		<keyword>SCHEMA</keyword>
-		<keyword>SCROLL</keyword>
-		<keyword>SECOND</keyword>
-		<keyword>SECTION</keyword>
-		<keyword>SELECT</keyword>
-		<keyword>SESSION_USER</keyword>
-		<keyword>SESSION</keyword>
-		<keyword>SET</keyword>
-		<keyword>SIZE</keyword>
-		<keyword>SMALLINT</keyword>
-		<keyword>SOME</keyword>
-		<keyword>SPACE</keyword>
-		<keyword>SQL</keyword>
-		<keyword>SQLCODE</keyword>
-		<keyword>SQLERROR</keyword>
-		<keyword>SQLSTATE</keyword>
-		<keyword>SUBSTRING</keyword>
-		<keyword>SUM</keyword>
-		<keyword>SYSTEM_USER</keyword>
-		<keyword>TABLE</keyword>
-		<keyword>TEMPORARY</keyword>
-		<keyword>THEN</keyword>
-		<keyword>TIME</keyword>
-		<keyword>TIMESTAMP</keyword>
-		<keyword>TIMEZONE_HOUR</keyword>
-		<keyword>TIMEZONE_MINUTE</keyword>
-		<keyword>TO</keyword>
-		<keyword>TRAILING</keyword>
-		<keyword>TRANSACTION</keyword>
-		<keyword>TRANSLATE</keyword>
-		<keyword>TRANSLATION</keyword>
-		<keyword>TRIM</keyword>
-		<keyword>TRUE</keyword>
-		<keyword>UNION</keyword>
-		<keyword>UNIQUE</keyword>
-		<keyword>UNKNOWN</keyword>
-		<keyword>UPDATE</keyword>
-		<keyword>UPPER</keyword>
-		<keyword>USAGE</keyword>
-		<keyword>USER</keyword>
-		<keyword>USING</keyword>
-		<keyword>VALUE</keyword>
-		<keyword>VALUES</keyword>
-		<keyword>VARCHAR</keyword>
-		<keyword>VARYING</keyword>
-		<keyword>VIEW</keyword>
-		<keyword>WHEN</keyword>
-		<keyword>WHENEVER</keyword>
-		<keyword>WHERE</keyword>
-		<keyword>WITH</keyword>
-		<keyword>WORK</keyword>
-		<keyword>WRITE</keyword>
-		<keyword>YEAR</keyword>
-		<keyword>ZONE</keyword>
-		<!-- non reserved keywords -->
-		<keyword>ADA</keyword>
-		<keyword>C</keyword>
-		<keyword>CATALOG_NAME</keyword>
-		<keyword>CHARACTER_SET_CATALOG</keyword>
-		<keyword>CHARACTER_SET_NAME</keyword>
-		<keyword>CHARACTER_SET_SCHEMA</keyword>
-		<keyword>CLASS_ORIGIN</keyword>
-		<keyword>COBOL</keyword>
-		<keyword>COLLATION_CATALOG</keyword>
-		<keyword>COLLATION_NAME</keyword>
-		<keyword>COLLATION_SCHEMA</keyword>
-		<keyword>COLUMN_NAME</keyword>
-		<keyword>COMMAND_FUNCTION</keyword>
-		<keyword>COMMITTED</keyword>
-		<keyword>CONDITION_NUMBER</keyword>
-		<keyword>CONNECTION_NAME</keyword>
-		<keyword>CONSTRAINT_CATALOG</keyword>
-		<keyword>CONSTRAINT_NAME</keyword>
-		<keyword>CONSTRAINT_SCHEMA</keyword>
-		<keyword>CURSOR_NAME</keyword>
-		<keyword>DATA</keyword>
-		<keyword>DATETIME_INTERVAL_CODE</keyword>
-		<keyword>DATETIME_INTERVAL_PRECISION</keyword>
-		<keyword>DYNAMIC_FUNCTION</keyword>
-		<keyword>FORTRAN</keyword>
-		<keyword>LENGTH</keyword>
-		<keyword>MESSAGE_LENGTH</keyword>
-		<keyword>MESSAGE_OCTET_LENGTH</keyword>
-		<keyword>MESSAGE_TEXT</keyword>
-		<keyword>MORE</keyword>
-		<keyword>MUMPS</keyword>
-		<keyword>NAME</keyword>
-		<keyword>NULLABLE</keyword>
-		<keyword>NUMBER</keyword>
-		<keyword>PASCAL</keyword>
-		<keyword>PLI</keyword>
-		<keyword>REPEATABLE</keyword>
-		<keyword>RETURNED_LENGTH</keyword>
-		<keyword>RETURNED_OCTET_LENGTH</keyword>
-		<keyword>RETURNED_SQLSTATE</keyword>
-		<keyword>ROW_COUNT</keyword>
-		<keyword>SCALE</keyword>
-		<keyword>SCHEMA_NAME</keyword>
-		<keyword>SERIALIZABLE</keyword>
-		<keyword>SERVER_NAME</keyword>
-		<keyword>SUBCLASS_ORIGIN</keyword>
-		<keyword>TABLE_NAME</keyword>
-		<keyword>TYPE</keyword>
-		<keyword>UNCOMMITTED</keyword>
-		<keyword>UNNAMED</keyword>
-	</highlighter>
-</highlighters>

+ 0 - 180
stylesheets/lfs-xsl/docbook-xsl-1.78.1/highlighting/tcl-hl.xml

@@ -1,180 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<!--
-
-xslthl highlighter definition fof Tcl/Tk.
-written by Arndt Roger Schneider
-
-Copyright 2008 Arndt Roger Schneider
-License: xlib/libpng
-
-This software is provided "as-is", without any express or implied
-warranty. In no event will the authors be held liable for any damages
-arising from the use of this software.
-
-Permission is granted to anyone to use this software for any purpose,
-including commercial applications, and to alter it and redistribute it
-freely, subject to the following restrictions:
-
-1. The origin of this software must not be misrepresented; you must
-   not claim that you wrote the original software. If you use this
-   software in a product, an acknowledgment in the product
-   documentation would be appreciated but is not required.
-
-2. Altered source versions must be plainly marked as such, and must
-   not be misrepresented as being the original software.
-
-3. This notice may not be removed or altered from any source
-   distribution.
-   
--->
-<highlighters>
-	<highlighter type="oneline-comment">#</highlighter>
-	<highlighter type="string">
-		<string>"</string>
-		<escape>\</escape>
-	</highlighter>
-	<highlighter type="regex">
-		<pattern>-[\p{javaJavaIdentifierStart}][\p{javaJavaIdentifierPart}]+
-		</pattern>
-		<style>none</style>
-	</highlighter>
-	<highlighter type="number">
-		<point>.</point>
-		<ignoreCase />
-	</highlighter>
-	<highlighter type="keywords">
-		<!-- Tcl and itcl / structural -->
-		<keyword>if</keyword>
-		<keyword>then</keyword>
-		<keyword>else</keyword>
-		<keyword>elseif</keyword>
-		<keyword>for</keyword>
-		<keyword>foreach</keyword>
-		<keyword>break</keyword>
-		<keyword>continue</keyword>
-		<keyword>while</keyword>
-		<keyword>eval</keyword>
-		<keyword>case</keyword>
-		<keyword>in</keyword>
-		<keyword>switch</keyword>
-		<keyword>default</keyword>
-		<keyword>exit</keyword>
-		<keyword>error</keyword>
-		<keyword>proc</keyword>
-		<keyword>rename</keyword>
-		<keyword>exec</keyword>
-		<keyword>return</keyword>
-		<keyword>uplevel</keyword>
-		<keyword>upvar</keyword>
-		<keyword>constructor</keyword>
-		<keyword>destructor</keyword>
-		<keyword>itcl_class</keyword>
-		<keyword>loop</keyword>
-		<keyword>for_array_keys</keyword>
-		<keyword>for_recursive_glob</keyword>
-		<keyword>for_file</keyword>
-		<keyword>method</keyword>
-		<keyword>body</keyword>
-		<keyword>configbody</keyword>
-		<keyword>catch</keyword>
-		<keyword>namespace</keyword>
-		<keyword>class</keyword>
-		<keyword>array</keyword>
-		<keyword>set</keyword>
-		<keyword>unset</keyword>
-		<keyword>package</keyword>
-		<keyword>source</keyword>
-
-    <!-- Additional commands -->
-		<keyword>subst</keyword>
-		<keyword>list</keyword>
-		<keyword>format</keyword>
-		<keyword>lappend</keyword>
-		<keyword>option</keyword>
-		<keyword>expr</keyword>
-		<keyword>puts</keyword>
-		<keyword>winfo</keyword>
-		<keyword>lindex</keyword>
-		<keyword>string</keyword>
-
-
-    <!-- Runtime Library / structural -->
-		<keyword>verified</keyword>
-		<keyword>seteach</keyword>
-		<keyword>fixme</keyword>
-		<keyword>debug</keyword>
-		<keyword>rtl::debug</keyword>
-		<keyword>rtl::verified</keyword>
-		<keyword>rtl::template</keyword>
-		<keyword>rtl::seteach</keyword>
-
-    <!-- Runtime Library / Additional -->
-		<keyword>mkProc</keyword>
-		<keyword>getCreator</keyword>
-		<keyword>properties</keyword>
-		<keyword>lappendunique</keyword>
-		<keyword>rtl::lappendunique</keyword>
-
-    <!-- geometry managers from Tk -->
-		<keyword>place</keyword>
-		<keyword>pack</keyword>
-		<keyword>grid</keyword>
-
-
-    <!-- Additional Tk stuff -->
-		<keyword>image</keyword>
-		<keyword>font</keyword>
-		<keyword>focus</keyword>
-		<keyword>tk</keyword>
-		<keyword>bind</keyword>
-		<keyword>after</keyword>
-
-    <!-- Window classes from Tk, ... -->
-		<keyword>toplevel</keyword>
-		<keyword>frame</keyword>
-		<keyword>entry</keyword>
-		<keyword>listbox</keyword>
-		<keyword>button</keyword>
-		<keyword>radiobutton</keyword>
-		<keyword>checkbutton</keyword>
-		<keyword>canvas</keyword>
-		<keyword>menu</keyword>
-		<keyword>menubutton</keyword>
-		<keyword>text</keyword>
-		<keyword>label</keyword>
-		<keyword>message</keyword>
-		<!--
-			The rest of Tk's windows is omitted: scrollbar, scale, panedwindow, labelframe, spinbox ...
-		-->
-
-    <!-- ... from tkZinc, ... -->
-		<keyword>zinc</keyword>
-  
-    <!-- ... from tkpath, ... -->
-		<keyword>tkpath::gradient</keyword>
-
-    <!-- ... from Runtime Library, ... -->
-		<keyword>rtl_combobox</keyword>
-		<keyword>rtl_tree</keyword>
-		<keyword>rtl_tabset</keyword>
-		<keyword>rtl_mlistbox</keyword>
-		<keyword>rtl_gridwin</keyword>
-		<keyword>rtlysizer</keyword>
-		<keyword>rtlxsizer</keyword>
-		<!--
-			The rest of RTL's windows is omitted: spinbox, decoratedframe, symbolbar, symbolbarcustomize, question ...
-		-->
-
-    <!-- ... from GEI, ... -->
-		<keyword>goolbar</keyword>
-		<keyword>gstripes</keyword>
-		<keyword>zoolbar</keyword>
-		<keyword>gistbox</keyword>
-		<keyword>gooleditor</keyword>
-		<keyword>galette</keyword>
-	</highlighter>
-</highlighters>
-	<!--
-		Local Variables: mode: sgml coding: utf-8-unix sgml-indent-step: 2 sgml-indent-data: t sgml-set-face: t
-		sgml-insert-missing-element-comment: nil End:
-	-->

+ 0 - 133
stylesheets/lfs-xsl/docbook-xsl-1.78.1/highlighting/upc-hl.xml

@@ -1,133 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<!-- 
-Syntax highlighting definition for Unified Parallel C
-	
-xslthl - XSLT Syntax Highlighting
-http://sourceforge.net/projects/xslthl/
-Copyright (C) 2005-2008 Michal Molhanec, Jirka Kosek, Michiel Hendriks, 
-	Viraj Sinha
-
-This software is provided 'as-is', without any express or implied
-warranty.  In no event will the authors be held liable for any damages
-arising from the use of this software.
-
-Permission is granted to anyone to use this software for any purpose,
-including commercial applications, and to alter it and redistribute it
-freely, subject to the following restrictions:
-
-1. The origin of this software must not be misrepresented; you must not
-   claim that you wrote the original software. If you use this software
-   in a product, an acknowledgment in the product documentation would be
-   appreciated but is not required.
-2. Altered source versions must be plainly marked as such, and must not be
-   misrepresented as being the original software.
-3. This notice may not be removed or altered from any source distribution.
-
-Michal Molhanec <mol1111 at users.sourceforge.net>
-Jirka Kosek <kosek at users.sourceforge.net>
-Michiel Hendriks <elmuerte at users.sourceforge.net>
--->
-<!-- This file is a modified version of c-hl.xml adapted for UPC compatability 
-	by , who in no way takes credit for the original creation of this 
-	file or the rest of xslthl. -->
-<highlighters>
-	<highlighter type="multiline-comment">
-		<start>/**</start>
-		<end>*/</end>
-		<style>doccomment</style>
-	</highlighter>
-	<highlighter type="oneline-comment">
-		<start><![CDATA[/// ]]></start>
-		<style>doccomment</style>
-	</highlighter>
-	<highlighter type="multiline-comment">
-		<start>/*</start>
-		<end>*/</end>
-	</highlighter>
-	<highlighter type="oneline-comment">//</highlighter>
-	<highlighter type="oneline-comment">
-		<!-- use the online-comment highlighter to detect directives -->
-		<start>#</start>
-		<lineBreakEscape>\</lineBreakEscape>
-		<style>directive</style>
-		<solitary />
-	</highlighter>
-	<highlighter type="string">
-		<string>"</string>
-		<escape>\</escape>
-	</highlighter>
-	<highlighter type="string">
-		<string>'</string>
-		<escape>\</escape>
-	</highlighter>
-	<highlighter type="hexnumber">
-		<prefix>0x</prefix>
-		<suffix>ul</suffix>
-		<suffix>lu</suffix>
-		<suffix>u</suffix>
-		<suffix>l</suffix>
-		<ignoreCase />
-	</highlighter>
-	<highlighter type="number">
-		<point>.</point>
-		<pointStarts />
-		<exponent>e</exponent>
-		<suffix>ul</suffix>
-		<suffix>lu</suffix>
-		<suffix>u</suffix>
-		<suffix>f</suffix>
-		<suffix>l</suffix>
-		<ignoreCase />
-	</highlighter>
-	<highlighter type="keywords">
-		<keyword>auto</keyword>
-		<keyword>_Bool</keyword>
-		<keyword>break</keyword>
-		<keyword>case</keyword>
-		<keyword>char</keyword>
-		<keyword>_Complex</keyword>
-		<keyword>const</keyword>
-		<keyword>continue</keyword>
-		<keyword>default</keyword>
-		<keyword>do</keyword>
-		<keyword>double</keyword>
-		<keyword>else</keyword>
-		<keyword>enum</keyword>
-		<keyword>extern</keyword>
-		<keyword>float</keyword>
-		<keyword>for</keyword>
-		<keyword>goto</keyword>
-		<keyword>if</keyword>
-		<keyword>_Imaginary</keyword>
-		<keyword>inline</keyword>
-		<keyword>int</keyword>
-		<keyword>long</keyword>
-		<keyword>register</keyword>
-		<keyword>relaxed</keyword>
-		<keyword>restrict</keyword>
-		<keyword>return</keyword>
-		<keyword>shared</keyword>
-		<keyword>strict</keyword>
-		<keyword>short</keyword>
-		<keyword>signed</keyword>
-		<keyword>sizeof</keyword>
-		<keyword>static</keyword>
-		<keyword>struct</keyword>
-		<keyword>switch</keyword>
-		<keyword>typedef</keyword>
-		<keyword>union</keyword>
-		<keyword>unsigned</keyword>
-		<keyword>upc_blocksizeof</keyword>
-		<keyword>upc_elemsizeof</keyword>
-		<keyword>upc_localsizeof</keyword>
-		<keyword>upc_lock_t</keyword>
-		<keyword>upc_forall</keyword>
-		<keyword>upc_barrier</keyword>
-		<keyword>upc_wait</keyword>
-		<keyword>upc_notify</keyword>
-		<keyword>upc_fence</keyword>
-		<keyword>void</keyword>
-		<keyword>volatile</keyword>
-		<keyword>while</keyword>
-	</highlighter>
-</highlighters>

+ 0 - 56
stylesheets/lfs-xsl/docbook-xsl-1.78.1/highlighting/xslthl-config.xml

@@ -1,56 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<!-- 
-
-xslthl - XSLT Syntax Highlighting
-http://sourceforge.net/projects/xslthl/
-Copyright (C) 2005-2012 Michal Molhanec, Jirka Kosek, Michiel Hendriks
-
-This software is provided 'as-is', without any express or implied
-warranty.  In no event will the authors be held liable for any damages
-arising from the use of this software.
-
-Permission is granted to anyone to use this software for any purpose,
-including commercial applications, and to alter it and redistribute it
-freely, subject to the following restrictions:
-
-1. The origin of this software must not be misrepresented; you must not
-   claim that you wrote the original software. If you use this software
-   in a product, an acknowledgment in the product documentation would be
-   appreciated but is not required.
-2. Altered source versions must be plainly marked as such, and must not be
-   misrepresented as being the original software.
-3. This notice may not be removed or altered from any source distribution.
-
-Michal Molhanec <mol1111 at users.sourceforge.net>
-Jirka Kosek <kosek at users.sourceforge.net>
-Michiel Hendriks <elmuerte at users.sourceforge.net>
-
--->
-<xslthl-config>
-	<highlighter id="java" file="java-hl.xml" />
-	<highlighter id="delphi" file="delphi-hl.xml" />
-	<highlighter id="pascal" file="delphi-hl.xml" />
-	<highlighter id="ini" file="ini-hl.xml" />
-	<highlighter id="php" file="php-hl.xml" />
-	<highlighter id="myxml" file="myxml-hl.xml" />
-	<highlighter id="m2" file="m2-hl.xml" />
-	<highlighter id="tcl" file="tcl-hl.xml" />
-	<highlighter id="c" file="c-hl.xml" />
-	<highlighter id="cpp" file="cpp-hl.xml" />
-	<highlighter id="csharp" file="csharp-hl.xml" />
-	<highlighter id="python" file="python-hl.xml" />
-	<highlighter id="ruby" file="ruby-hl.xml" />
-	<highlighter id="perl" file="perl-hl.xml" />	
-	<highlighter id="javascript" file="javascript-hl.xml" />
-	<highlighter id="bourne" file="bourne-hl.xml" />
-	<highlighter id="css" file="css21-hl.xml" />
-	<highlighter id="css21" file="css21-hl.xml" />
-	<highlighter id="cmake" file="cmake-hl.xml" />
-	<highlighter id="upc" file="upc-hl.xml" />
-	<highlighter id="lua" file="lua-hl.xml" />
-	<highlighter id="sql92" file="sql92-hl.xml" />
-	<highlighter id="sql1999" file="sql1999-hl.xml" />
-	<highlighter id="sql2003" file="sql2003-hl.xml" />
-	<highlighter id="sql" file="sql2003-hl.xml" />
-	<namespace prefix="xslthl" uri="http://xslthl.sf.net" />
-</xslthl-config>

+ 0 - 1120
stylesheets/lfs-xsl/docbook-xsl-1.78.1/htmlhelp/htmlhelp-common.xsl

@@ -1,1120 +0,0 @@
-<?xml version="1.0"?>
-<!DOCTYPE xsl:stylesheet [
-<!ENTITY lf '<xsl:text xmlns:xsl="http://www.w3.org/1999/XSL/Transform">&#xA;</xsl:text>'>
-]>
-<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
-  xmlns:doc="http://nwalsh.com/xsl/documentation/1.0"
-  xmlns:exsl="http://exslt.org/common"
-  xmlns:set="http://exslt.org/sets"
-  xmlns:h="urn:x-hex"
-  xmlns:ng="http://docbook.org/docbook-ng"
-  xmlns:db="http://docbook.org/ns/docbook"
-  version="1.0"
-  exclude-result-prefixes="doc exsl set h db ng">
-
-<!-- ********************************************************************
-     $Id: htmlhelp-common.xsl 9151 2011-11-12 00:16:19Z bobstayton $
-     ******************************************************************** -->
-
-<!-- ==================================================================== -->
-<!-- Customizations of standard HTML stylesheet parameters -->
-
-<!-- no navigation on pages by default, HTML Help provides its own navigation controls -->
-<xsl:param name="suppress.navigation" select="1"/>
-
-<!-- no separate HTML page with index, index is built inside CHM index pane -->
-<xsl:param name="generate.index" select="0"/>
-
-<!-- ==================================================================== -->
-
-<xsl:param name="htmlhelp.generate.index" select="//indexterm[1]|//db:indexterm[1]|//ng:indexterm[1]"/>
-  
-<!-- Set up HTML Help flag -->
-<xsl:variable name="htmlhelp.output" select="1"/>
-
-<!-- ==================================================================== -->
-
-<xsl:template match="/">
-
-  <!-- * Get a title for current doc so that we let the user -->
-  <!-- * know what document we are processing at this point. -->
-  <xsl:variable name="doc.title">
-    <xsl:call-template name="get.doc.title"/>
-  </xsl:variable>
-  <xsl:choose>
-    <!-- Hack! If someone hands us a DocBook V5.x or DocBook NG document,
-         toss the namespace and continue.  Use the docbook5 namespaced
-         stylesheets for DocBook5 if you don't want to use this feature.-->
-    <xsl:when test="$exsl.node.set.available != 0
-                    and (*/self::ng:* or */self::db:*)">
-      <xsl:call-template name="log.message">
-        <xsl:with-param name="level">Note</xsl:with-param>
-        <xsl:with-param name="source" select="$doc.title"/>
-        <xsl:with-param name="context-desc">
-          <xsl:text>namesp. cut</xsl:text>
-        </xsl:with-param>
-        <xsl:with-param name="message">
-          <xsl:text>stripped namespace before processing</xsl:text>
-        </xsl:with-param>
-      </xsl:call-template>
-      <xsl:variable name="nons">
-        <xsl:apply-templates mode="stripNS"/>
-      </xsl:variable>
-      <xsl:call-template name="log.message">
-        <xsl:with-param name="level">Note</xsl:with-param>
-        <xsl:with-param name="source" select="$doc.title"/>
-        <xsl:with-param name="context-desc">
-          <xsl:text>namesp. cut</xsl:text>
-        </xsl:with-param>
-        <xsl:with-param name="message">
-          <xsl:text>processing stripped document</xsl:text>
-        </xsl:with-param>
-      </xsl:call-template>
-      <xsl:apply-templates select="exsl:node-set($nons)"/>
-    </xsl:when>
-    <xsl:otherwise>
-  <xsl:if test="$htmlhelp.only != 1">
-    <xsl:choose>
-      <xsl:when test="$rootid != ''">
-        <xsl:choose>
-          <xsl:when test="count(key('id',$rootid)) = 0">
-            <xsl:message terminate="yes">
-              <xsl:text>ID '</xsl:text>
-              <xsl:value-of select="$rootid"/>
-              <xsl:text>' not found in document.</xsl:text>
-            </xsl:message>
-          </xsl:when>
-          <xsl:otherwise>
-            <xsl:message>Formatting from <xsl:value-of select="$rootid"/></xsl:message>
-            <xsl:apply-templates select="key('id',$rootid)" mode="process.root"/>
-          </xsl:otherwise>
-        </xsl:choose>
-      </xsl:when>
-      <xsl:otherwise>
-        <xsl:if test="$collect.xref.targets = 'yes' or
-                      $collect.xref.targets = 'only'">
-          <xsl:apply-templates select="/" mode="collect.targets"/>
-        </xsl:if>
-        <xsl:if test="$collect.xref.targets != 'only'">
-          <xsl:apply-templates select="/" mode="process.root"/>
-        </xsl:if>
-      </xsl:otherwise>
-    </xsl:choose>
-  </xsl:if>
-
-
-  <xsl:if test="$collect.xref.targets != 'only'">
-    <xsl:call-template name="hhp"/>
-    <xsl:call-template name="hhc"/>
-    <xsl:if test="($rootid = '' and //processing-instruction('dbhh')) or
-                  ($rootid != '' and key('id',$rootid)//processing-instruction('dbhh'))">
-      <xsl:call-template name="hh-map"/>
-      <xsl:call-template name="hh-alias"/>
-    </xsl:if>
-    <xsl:if test="$htmlhelp.generate.index">
-      <xsl:call-template name="hhk"/>
-    </xsl:if>
-  </xsl:if>
-</xsl:otherwise>
-</xsl:choose>
-</xsl:template>
-
-<!-- ==================================================================== -->
-
-<xsl:template name="hhp">
-  <xsl:call-template name="write.text.chunk">
-    <xsl:with-param name="filename">
-      <xsl:if test="$manifest.in.base.dir != 0">
-        <xsl:value-of select="$chunk.base.dir"/>
-      </xsl:if>
-      <xsl:value-of select="$htmlhelp.hhp"/>
-    </xsl:with-param>
-    <xsl:with-param name="method" select="'text'"/>
-    <xsl:with-param name="content">
-      <xsl:call-template name="hhp-main"/>
-    </xsl:with-param>
-    <xsl:with-param name="encoding" select="$htmlhelp.encoding"/>
-    <xsl:with-param name="quiet" select="$chunk.quietly"/>
-  </xsl:call-template>
-</xsl:template>
-
-<!-- ==================================================================== -->
-<xsl:template name="hhp-main">
-
-  <xsl:variable name="raw.help.title">
-    <xsl:choose>
-      <xsl:when test="$htmlhelp.title = ''">
-        <xsl:choose>
-          <xsl:when test="$rootid != ''">
-            <xsl:apply-templates select="key('id',$rootid)" mode="title.markup"/>
-          </xsl:when>
-          <xsl:otherwise>
-            <xsl:apply-templates select="/*" mode="title.markup"/>
-          </xsl:otherwise>
-        </xsl:choose>
-      </xsl:when>
-      <xsl:otherwise>
-        <xsl:value-of select="$htmlhelp.title"/>
-      </xsl:otherwise>
-    </xsl:choose>
-  </xsl:variable>
-
-  <xsl:variable name="help.title" select="normalize-space($raw.help.title)"/>
-  
-<xsl:variable name="default.topic">
-  <xsl:choose>
-    <xsl:when test="$htmlhelp.default.topic != ''">
-      <xsl:value-of select="$htmlhelp.default.topic"/>
-    </xsl:when>
-    <xsl:otherwise>
-      <xsl:call-template name="make-relative-filename">
-        <xsl:with-param name="base.dir">
-          <xsl:if test="$manifest.in.base.dir = 0">
-            <xsl:value-of select="$chunk.base.dir"/>
-          </xsl:if>
-        </xsl:with-param>
-        <xsl:with-param name="base.name">
-          <xsl:choose>
-            <xsl:when test="$rootid != ''">
-              <xsl:apply-templates select="key('id',$rootid)" mode="chunk-filename"/>
-            </xsl:when>
-            <xsl:otherwise>
-              <xsl:apply-templates select="/" mode="chunk-filename"/>
-            </xsl:otherwise>
-          </xsl:choose>
-        </xsl:with-param>
-      </xsl:call-template>
-    </xsl:otherwise>
-  </xsl:choose>
-</xsl:variable>
-<xsl:variable name="xnavigation">
-  <xsl:text>0x</xsl:text>
-  <xsl:call-template name="toHex">
-    <xsl:with-param name="n" select="9504 + $htmlhelp.show.menu * 65536
-                                          + $htmlhelp.show.advanced.search * 131072
-                                          + $htmlhelp.show.favorities * 4096
-                                          + (1 - $htmlhelp.show.toolbar.text) * 64
-                                          + $htmlhelp.remember.window.position * 262144"/>
-  </xsl:call-template>
-</xsl:variable>
-<xsl:variable name="xbuttons">
-  <xsl:text>0x</xsl:text>
-  <xsl:call-template name="toHex">
-    <xsl:with-param name="n" select="0 + $htmlhelp.button.hideshow * 2
-                                       + $htmlhelp.button.back * 4
-                                       + $htmlhelp.button.forward * 8
-                                       + $htmlhelp.button.stop * 16
-                                       + $htmlhelp.button.refresh * 32
-                                       + $htmlhelp.button.home * 64
-                                       + $htmlhelp.button.options * 4096
-                                       + $htmlhelp.button.print * 8192
-                                       + $htmlhelp.button.locate * 2048
-                                       + $htmlhelp.button.jump1 * 262144
-                                       + $htmlhelp.button.jump2 * 524288
-                                       + $htmlhelp.button.next * 2097152
-                                       + $htmlhelp.button.prev * 4194304
-                                       + $htmlhelp.button.zoom * 1048576"/>
-  </xsl:call-template>
-</xsl:variable>
-<xsl:text>[OPTIONS]
-</xsl:text>
-<xsl:if test="$htmlhelp.generate.index">
-<xsl:text>Auto Index=Yes
-</xsl:text></xsl:if>
-<xsl:if test="$htmlhelp.hhc.binary != 0">
-<xsl:text>Binary TOC=Yes
-</xsl:text></xsl:if>
-<xsl:text>Compatibility=1.1 or later
-Compiled file=</xsl:text><xsl:value-of select="$htmlhelp.chm"/><xsl:text>
-Contents file=</xsl:text><xsl:value-of select="$htmlhelp.hhc"/><xsl:text>
-</xsl:text>
-<xsl:if test="$htmlhelp.hhp.window != ''">
-<xsl:text>Default Window=</xsl:text><xsl:value-of select="$htmlhelp.hhp.window"/><xsl:text>
-</xsl:text></xsl:if>
-<xsl:text>Default topic=</xsl:text><xsl:value-of select="$default.topic"/>
-<xsl:text>
-Display compile progress=</xsl:text>
-  <xsl:choose>
-    <xsl:when test="$htmlhelp.display.progress != 1">
-      <xsl:text>No</xsl:text>
-    </xsl:when>
-    <xsl:otherwise>
-      <xsl:text>Yes</xsl:text>
-    </xsl:otherwise>
-  </xsl:choose>
-<xsl:text>
-Full-text search=Yes
-</xsl:text>
-<xsl:if test="$htmlhelp.generate.index">
-<xsl:text>Index file=</xsl:text><xsl:value-of select="$htmlhelp.hhk"/><xsl:text>
-</xsl:text></xsl:if>
-<xsl:text>Language=</xsl:text>
-<xsl:for-each select="*">   <!-- Change context from / to root element -->
-  <xsl:call-template name="gentext.template">
-    <xsl:with-param name="context" select="'htmlhelp'"/>
-    <xsl:with-param name="name" select="'langcode'"/>
-  </xsl:call-template>
-</xsl:for-each>
-<xsl:text>
-Title=</xsl:text>
-  <xsl:value-of select="$help.title"/>
-<xsl:text>
-Enhanced decompilation=</xsl:text>
-  <xsl:choose>
-    <xsl:when test="$htmlhelp.enhanced.decompilation != 0">
-      <xsl:text>Yes</xsl:text>
-    </xsl:when>
-    <xsl:otherwise>
-      <xsl:text>No</xsl:text>
-    </xsl:otherwise>
-  </xsl:choose>
-
-<xsl:if test="$htmlhelp.hhp.window != ''">
-  <xsl:text>
-
-[WINDOWS]
-</xsl:text>
-<xsl:value-of select="$htmlhelp.hhp.window"/>
-<xsl:text>="</xsl:text>
-<xsl:value-of select="$help.title"/>
-<xsl:text>","</xsl:text><xsl:value-of select="$htmlhelp.hhc"/>
-<xsl:text>",</xsl:text>
-<xsl:if test="$htmlhelp.generate.index">
-  <xsl:text>"</xsl:text>
-  <xsl:value-of select="$htmlhelp.hhk"/>
-  <xsl:text>"</xsl:text>
-</xsl:if>
-<xsl:text>,"</xsl:text>
-<xsl:value-of select="$default.topic"/>
-<xsl:text>",</xsl:text>
-<xsl:text>"</xsl:text>
-<xsl:choose>
-  <xsl:when test="$htmlhelp.button.home != 0">
-    <xsl:value-of select="$htmlhelp.button.home.url"/>
-  </xsl:when>
-  <xsl:otherwise>
-    <xsl:value-of select="$default.topic"/>
-  </xsl:otherwise>
-</xsl:choose>
-<xsl:text>"</xsl:text>
-<xsl:text>,</xsl:text>
-<xsl:if test="$htmlhelp.button.jump1 != 0">
-  <xsl:text>"</xsl:text>
-  <xsl:value-of select="$htmlhelp.button.jump1.url"/>
-  <xsl:text>"</xsl:text>
-</xsl:if>
-<xsl:text>,</xsl:text>
-<xsl:if test="$htmlhelp.button.jump1 != 0">
-  <xsl:text>"</xsl:text>
-  <xsl:value-of select="$htmlhelp.button.jump1.title"/>
-  <xsl:text>"</xsl:text>
-</xsl:if>
-<xsl:text>,</xsl:text>
-<xsl:if test="$htmlhelp.button.jump2 != 0">
-  <xsl:text>"</xsl:text>
-  <xsl:value-of select="$htmlhelp.button.jump2.url"/>
-  <xsl:text>"</xsl:text>
-</xsl:if>
-<xsl:text>,</xsl:text>
-<xsl:if test="$htmlhelp.button.jump2 != 0">
-  <xsl:text>"</xsl:text>
-  <xsl:value-of select="$htmlhelp.button.jump2.title"/>
-  <xsl:text>"</xsl:text>
-</xsl:if>
-<xsl:text>,</xsl:text>
-<xsl:value-of select="$xnavigation"/>
-<xsl:text>,</xsl:text><xsl:value-of select="$htmlhelp.hhc.width"/><xsl:text>,</xsl:text>
-<xsl:value-of select="$xbuttons"/>
-<xsl:text>,</xsl:text><xsl:value-of select="$htmlhelp.window.geometry"/><xsl:text>,,,,,,,0
-</xsl:text>
-</xsl:if>
-
-<!-- 
-  Needs more investigation to generate propetly all fields 
-<xsl:text>search="</xsl:text>
-<xsl:value-of select="normalize-space(//title[1])"/>
-<xsl:text>","toc.hhc","index.hhk","</xsl:text>
-<xsl:value-of select="$root.filename"/>
-<xsl:text>.html","</xsl:text>
-<xsl:value-of select="$root.filename"/>
-<xsl:text>.html",,,,,</xsl:text>
-<xsl:value-of select="$xnavigation"/>
-<xsl:text>,</xsl:text>
-<xsl:value-of select="$htmlhelp.hhc.width"/>
-<xsl:text>,</xsl:text>
-<xsl:value-of select="$xbuttons"/>
-<xsl:text>,</xsl:text>
-<xsl:value-of select="$htmlhelp.window.geometry"/>
-<xsl:text>,,,,,2,,0
-</xsl:text>
--->
-
-<xsl:if test="$htmlhelp.hhp.windows">
-  <xsl:value-of select="$htmlhelp.hhp.windows"/>
-</xsl:if>
-<xsl:text>
-
-[FILES]
-</xsl:text>
-
-<xsl:choose>
-  <xsl:when test="$rootid != ''">
-    <xsl:apply-templates select="key('id',$rootid)" mode="enumerate-files"/>
-  </xsl:when>
-  <xsl:otherwise>
-    <xsl:apply-templates select="/" mode="enumerate-files"/>
-  </xsl:otherwise>
-</xsl:choose>
-
-<xsl:if test="$htmlhelp.enumerate.images">
-  <xsl:variable name="imagelist">
-    <xsl:choose>
-      <xsl:when test="$rootid != ''">
-        <xsl:apply-templates select="key('id',$rootid)" mode="enumerate-images"/>
-      </xsl:when>
-      <xsl:otherwise>
-        <xsl:apply-templates select="/" mode="enumerate-images"/>
-      </xsl:otherwise>
-    </xsl:choose>
-  </xsl:variable>
-  <xsl:choose>
-    <xsl:when test="$exsl.node.set.available != 0
-                    and function-available('set:distinct')">
-      <xsl:for-each select="set:distinct(exsl:node-set($imagelist)/filename)">
-        <xsl:value-of select="."/>
-        <xsl:text>&#10;</xsl:text>
-      </xsl:for-each>
-    </xsl:when>
-    <xsl:otherwise>
-      <xsl:value-of select="$imagelist"/>
-    </xsl:otherwise>
-  </xsl:choose>
-</xsl:if>
-
-<xsl:if test="($htmlhelp.force.map.and.alias != 0) or 
-              ($rootid = '' and //processing-instruction('dbhh')) or
-              ($rootid != '' and key('id',$rootid)//processing-instruction('dbhh'))">
-  <xsl:text>
-[ALIAS]
-#include </xsl:text><xsl:value-of select="$htmlhelp.alias.file"/><xsl:text>
-
-[MAP]
-#include </xsl:text><xsl:value-of select="$htmlhelp.map.file"/><xsl:text>
-</xsl:text>
-</xsl:if>
-
-<xsl:value-of select="$htmlhelp.hhp.tail"/>
-</xsl:template>
-
-<!-- ==================================================================== -->
-
-<xsl:template match="graphic|inlinegraphic[@format!='linespecific']" mode="enumerate-images">
-  <xsl:call-template name="write.filename.enumerate-images">
-    <xsl:with-param name="filename">
-      <xsl:call-template name="mediaobject.filename.enumerate-images">
-        <xsl:with-param name="object" select="."/>
-      </xsl:call-template>  
-    </xsl:with-param>
-  </xsl:call-template>
-</xsl:template>
-
-<xsl:template match="mediaobject|inlinemediaobject" mode="enumerate-images">
-  <xsl:call-template name="select.mediaobject.enumerate-images"/>
-</xsl:template>
-
-<xsl:template name="select.mediaobject.enumerate-images">
-  <xsl:param name="olist"
-             select="imageobject|imageobjectco
-                     |videoobject|audioobject|textobject"/>
-  <xsl:param name="count">1</xsl:param>
-
-  <xsl:if test="$count &lt;= count($olist)">
-    <xsl:variable name="object" select="$olist[position()=$count]"/>
-
-    <xsl:variable name="useobject">
-      <xsl:choose>
-        <!-- The phrase is never used -->
-        <xsl:when test="name($object)='textobject' and $object/phrase">
-          <xsl:text>0</xsl:text>
-        </xsl:when>
-        <!-- The first textobject is a reasonable fallback (but not for image in HH) -->
-        <xsl:when test="name($object)='textobject'">
-          <xsl:text>0</xsl:text>
-        </xsl:when>
-        <!-- If there's only one object, use it -->
-        <xsl:when test="$count = 1 and count($olist) = 1">
-          <xsl:text>1</xsl:text>
-        </xsl:when>
-        <!-- Otherwise, see if this one is a useable graphic -->
-        <xsl:otherwise>
-          <xsl:choose>
-            <!-- peek inside imageobjectco to simplify the test -->
-            <xsl:when test="local-name($object) = 'imageobjectco'">
-              <xsl:call-template name="is.acceptable.mediaobject">
-                <xsl:with-param name="object" select="$object/imageobject"/>
-              </xsl:call-template>
-            </xsl:when>
-            <xsl:otherwise>
-              <xsl:call-template name="is.acceptable.mediaobject">
-                <xsl:with-param name="object" select="$object"/>
-              </xsl:call-template>
-            </xsl:otherwise>
-          </xsl:choose>
-        </xsl:otherwise>
-      </xsl:choose>
-    </xsl:variable>
-
-    <xsl:choose>
-      <xsl:when test="$useobject='1' and $object[not(*/@format='linespecific')]">
-        <xsl:call-template name="write.filename.enumerate-images">
-          <xsl:with-param name="filename">
-            <xsl:call-template name="mediaobject.filename.enumerate-images">
-              <xsl:with-param name="object" select="$object"/>
-            </xsl:call-template>
-          </xsl:with-param>
-        </xsl:call-template>
-      </xsl:when>
-      <xsl:otherwise>
-        <xsl:call-template name="select.mediaobject.enumerate-images">
-          <xsl:with-param name="olist" select="$olist"/>
-          <xsl:with-param name="count" select="$count + 1"/>
-        </xsl:call-template>
-      </xsl:otherwise>
-    </xsl:choose>
-  </xsl:if>
-</xsl:template>
-
-<xsl:template name="mediaobject.filename.enumerate-images">
-  <xsl:param name="object"/>
-
-  <xsl:variable name="urifilename">
-    <xsl:call-template name="mediaobject.filename">
-      <xsl:with-param name="object" select="$object"/>
-    </xsl:call-template>
-  </xsl:variable>
-
-  <xsl:variable name="filename">
-    <xsl:choose>
-      <xsl:when test="starts-with($urifilename, 'file:/')">
-        <xsl:value-of select="substring-after($urifilename, 'file:/')"/>
-      </xsl:when>
-      <xsl:otherwise>
-        <xsl:value-of select="$urifilename"/>
-      </xsl:otherwise>
-    </xsl:choose>
-  </xsl:variable>
-
-  <xsl:value-of select="translate($filename, '/', '\')"/>
-
-</xsl:template>
-
-<xsl:template match="text()" mode="enumerate-images">
-</xsl:template>
-
-<xsl:template name="write.filename.enumerate-images">
-  <xsl:param name="filename"/>
-  <xsl:choose>
-    <xsl:when test="function-available('exsl:node-set') and function-available('set:distinct')">
-      <filename><xsl:value-of select="$filename"/></filename>
-    </xsl:when>
-    <xsl:otherwise>
-      <xsl:value-of select="$filename"/>
-      <xsl:text>&#10;</xsl:text>
-    </xsl:otherwise>
-  </xsl:choose>
-</xsl:template>
-
-<!-- ==================================================================== -->
-
-<!-- HHC and HHK files are processed by compiler line by line
-     and therefore are very sensitive to whitespaces (linefeeds for sure).  -->
-
-<xsl:template name="hhc">
-  <xsl:call-template name="write.chunk">
-    <xsl:with-param name="filename">
-      <xsl:if test="$manifest.in.base.dir != 0">
-        <xsl:value-of select="$chunk.base.dir"/>
-      </xsl:if>
-      <xsl:value-of select="$htmlhelp.hhc"/>
-    </xsl:with-param>
-    <xsl:with-param name="indent" select="'no'"/>
-    <xsl:with-param name="content">
-      <xsl:call-template name="hhc-main"/>
-    </xsl:with-param>
-    <xsl:with-param name="encoding" select="$htmlhelp.encoding"/>
-    <xsl:with-param name="quiet" select="$chunk.quietly"/>
-  </xsl:call-template>
-</xsl:template>
-
-<xsl:template name="hhc-main">
-<HTML>&lf;
- <HEAD></HEAD>&lf;
- <BODY>&lf;
-  <xsl:if test="$htmlhelp.hhc.folders.instead.books != 0">
-   <OBJECT type="text/site properties">&lf;
-     <param name="ImageType" value="Folder"/>&lf;
-   </OBJECT>&lf;
-  </xsl:if>
-  <xsl:variable name="content">
-    <xsl:choose>
-      <xsl:when test="$rootid != ''">
-        <xsl:apply-templates select="key('id',$rootid)" mode="hhc"/>
-      </xsl:when>
-      <xsl:otherwise>
-        <xsl:apply-templates select="/" mode="hhc"/>
-      </xsl:otherwise>
-    </xsl:choose>
-  </xsl:variable>
-
-  <xsl:choose>
-    <xsl:when test="$htmlhelp.hhc.show.root != 0">
-      <UL>&lf;
-        <xsl:copy-of select="$content"/>
-      </UL>&lf;
-    </xsl:when>
-    <xsl:otherwise>
-    <xsl:copy-of select="$content"/>
-    </xsl:otherwise>
-  </xsl:choose>
-
- </BODY>
-</HTML>
-</xsl:template>
-
-<xsl:template name="hhc.entry">
-  <xsl:param name="title">
-    <xsl:if test="$htmlhelp.autolabel=1">
-      <xsl:variable name="label.markup">
-        <xsl:apply-templates select="." mode="label.markup"/>
-      </xsl:variable>
-      <xsl:if test="normalize-space($label.markup)">
-        <xsl:value-of select="concat($label.markup,$autotoc.label.separator)"/>
-      </xsl:if>
-    </xsl:if>
-    <xsl:apply-templates select="." mode="title.markup"/>
-  </xsl:param>
-
-  <LI><OBJECT type="text/sitemap">&lf;
-    <param name="Name">
-      <xsl:attribute name="value">
-          <xsl:value-of select="normalize-space($title)"/>
-      </xsl:attribute>
-    </param>&lf;
-    <param name="Local">
-      <xsl:attribute name="value">
-          <xsl:call-template name="href.target.with.base.dir"/>
-      </xsl:attribute>
-    </param>
-  </OBJECT></LI>&lf;
-</xsl:template>
-
-<xsl:template match="set" mode="hhc">
-  <xsl:if test="$htmlhelp.hhc.show.root != 0">
-    <xsl:call-template name="hhc.entry"/>
-  </xsl:if>
-  <xsl:if test="book">
-    <xsl:variable name="toc.params">
-      <xsl:call-template name="find.path.params">
-        <xsl:with-param name="table" select="normalize-space($generate.toc)"/>
-      </xsl:call-template>
-    </xsl:variable>
-    <UL>
-      <xsl:if test="contains($toc.params, 'toc') and $htmlhelp.hhc.show.root = 0">
-      <LI><OBJECT type="text/sitemap">&lf;
-          <param name="Name">
-            <xsl:attribute name="value">
-            <xsl:call-template name="gentext">
-              <xsl:with-param name="key" select="'TableofContents'"/>
-            </xsl:call-template>
-            </xsl:attribute>
-          </param>&lf;
-          <param name="Local">
-            <xsl:attribute name="value">
-              <xsl:choose>
-                <xsl:when test="$chunk.tocs.and.lots != 0">
-                  <xsl:apply-templates select="." mode="recursive-chunk-filename">
-                    <xsl:with-param name="recursive" select="true()"/>
-                  </xsl:apply-templates>
-                  <xsl:text>-toc</xsl:text>
-                  <xsl:value-of select="$html.ext"/>
-                </xsl:when>
-                <xsl:otherwise>
-                  <xsl:call-template name="href.target.with.base.dir"/>
-                </xsl:otherwise>
-              </xsl:choose>
-            </xsl:attribute>
-          </param>
-      </OBJECT></LI>&lf;
-      </xsl:if>
-      <xsl:apply-templates select="book" mode="hhc"/>
-    </UL>&lf;
-  </xsl:if>
-</xsl:template>
-
-<xsl:template match="book" mode="hhc">
-  <xsl:if test="$htmlhelp.hhc.show.root != 0 or parent::*">
-    <xsl:call-template name="hhc.entry"/>
-  </xsl:if>
-  <xsl:if test="part|reference|preface|chapter|appendix|bibliography|article|colophon|glossary">
-    <xsl:variable name="toc.params">
-      <xsl:call-template name="find.path.params">
-        <xsl:with-param name="table" select="normalize-space($generate.toc)"/>
-      </xsl:call-template>
-    </xsl:variable>
-    <UL>
-      <xsl:if test="contains($toc.params, 'toc') and $htmlhelp.hhc.show.root = 0 and not(parent::*)">
-        <LI><OBJECT type="text/sitemap">&lf;
-            <param name="Name">
-              <xsl:attribute name="value">
-                <xsl:call-template name="gentext">
-                  <xsl:with-param name="key" select="'TableofContents'"/>
-                </xsl:call-template>
-              </xsl:attribute>
-            </param>&lf;
-            <param name="Local">
-              <xsl:attribute name="value">
-                <xsl:choose>
-                  <xsl:when test="$chunk.tocs.and.lots != 0">
-                    <xsl:apply-templates select="." mode="recursive-chunk-filename">
-                      <xsl:with-param name="recursive" select="true()"/>
-                    </xsl:apply-templates>
-                    <xsl:text>-toc</xsl:text>
-                    <xsl:value-of select="$html.ext"/>
-                  </xsl:when>
-                  <xsl:otherwise>
-                    <xsl:call-template name="href.target.with.base.dir"/>
-                  </xsl:otherwise>
-                </xsl:choose>
-              </xsl:attribute>
-            </param>
-        </OBJECT></LI>&lf;
-      </xsl:if>
-      <xsl:apply-templates select="part|reference|preface|chapter|bibliography|appendix|article|colophon|glossary"
-                           mode="hhc"/>
-    </UL>&lf;
-  </xsl:if>
-</xsl:template>
-
-<xsl:template match="part|reference|preface|chapter|bibliography|appendix|article|glossary"
-              mode="hhc">
-  <xsl:if test="$htmlhelp.hhc.show.root != 0 or parent::*">
-    <xsl:call-template name="hhc.entry"/>
-  </xsl:if>
-  <xsl:if test="article|reference|preface|chapter|appendix|refentry|section|sect1|bibliodiv">
-    <UL>&lf;
-      <xsl:apply-templates
-        select="article|reference|preface|chapter|appendix|refentry|section|sect1|bibliodiv"
-        mode="hhc"/>
-    </UL>
-  </xsl:if>
-</xsl:template>
-
-<xsl:template match="section" mode="hhc">
-  <xsl:if test="$htmlhelp.hhc.show.root != 0 or parent::*">
-    <xsl:call-template name="hhc.entry"/>
-  </xsl:if>
-  <xsl:if test="section[count(ancestor::section) &lt; $htmlhelp.hhc.section.depth]|refentry">
-    <UL>&lf;
-      <xsl:apply-templates select="section|refentry" mode="hhc"/>
-    </UL>
-  </xsl:if>
-</xsl:template>
-
-<xsl:template match="sect1" mode="hhc">
-  <xsl:if test="$htmlhelp.hhc.show.root != 0 or parent::*">
-    <xsl:call-template name="hhc.entry"/>
-  </xsl:if>
-  <xsl:if test="sect2[$htmlhelp.hhc.section.depth > 1]|refentry">
-    <UL>&lf;
-      <xsl:apply-templates select="sect2|refentry"
-                           mode="hhc"/>
-    </UL>
-  </xsl:if>
-</xsl:template>
-
-<xsl:template match="sect2" mode="hhc">
-  <xsl:if test="$htmlhelp.hhc.show.root != 0 or parent::*">
-    <xsl:call-template name="hhc.entry"/>
-  </xsl:if>
-  <xsl:if test="sect3[$htmlhelp.hhc.section.depth > 2]|refentry">
-    <UL>&lf;
-      <xsl:apply-templates select="sect3|refentry"
-                           mode="hhc"/>
-    </UL>
-  </xsl:if>
-</xsl:template>
-
-<xsl:template match="sect3" mode="hhc">
-  <xsl:if test="$htmlhelp.hhc.show.root != 0 or parent::*">
-    <xsl:call-template name="hhc.entry"/>
-  </xsl:if>
-  <xsl:if test="sect4[$htmlhelp.hhc.section.depth > 3]|refentry">
-    <UL>&lf;
-      <xsl:apply-templates select="sect4|refentry"
-                           mode="hhc"/>
-    </UL>
-  </xsl:if>
-</xsl:template>
-
-<xsl:template match="sect4" mode="hhc">
-  <xsl:if test="$htmlhelp.hhc.show.root != 0 or parent::*">
-    <xsl:call-template name="hhc.entry"/>
-  </xsl:if>
-  <xsl:if test="sect5[$htmlhelp.hhc.section.depth > 4]|refentry">
-    <UL>&lf;
-      <xsl:apply-templates select="sect5|refentry"
-                           mode="hhc"/>
-    </UL>
-  </xsl:if>
-</xsl:template>
-
-<xsl:template match="sect5|refentry|colophon|bibliodiv" mode="hhc">
-  <xsl:if test="$htmlhelp.hhc.show.root != 0 or parent::*">
-    <xsl:call-template name="hhc.entry"/>
-  </xsl:if>
-  <xsl:if test="refentry">
-    <UL>&lf;
-      <xsl:apply-templates select="refentry"
-                           mode="hhc"/>
-    </UL>
-  </xsl:if>
-</xsl:template>
-
-<!-- ==================================================================== -->
-
-<xsl:template match="indexterm">
-  <xsl:choose>
-    <xsl:when test="$htmlhelp.use.hhk = 0">
-  
-      <xsl:variable name="primary" select="normalize-space(primary)"/>
-      <xsl:variable name="secondary" select="normalize-space(secondary)"/>
-      <xsl:variable name="tertiary" select="normalize-space(tertiary)"/>
-      
-      <xsl:variable name="text">
-        <xsl:value-of select="$primary"/>
-        <xsl:if test="secondary">
-          <xsl:text>, </xsl:text>
-          <xsl:value-of select="$secondary"/>
-        </xsl:if>
-        <xsl:if test="tertiary">
-          <xsl:text>, </xsl:text>
-          <xsl:value-of select="$tertiary"/>
-        </xsl:if>
-      </xsl:variable>
-      
-      <xsl:if test="secondary">
-        <xsl:if test="not(//indexterm[normalize-space(primary)=$primary and not(secondary)])">
-          <xsl:call-template name="write.indexterm">
-            <xsl:with-param name="text" select="$primary"/>
-          </xsl:call-template>
-        </xsl:if>
-      </xsl:if>
-
-      <xsl:if test="tertiary">
-        <xsl:if test="not(//indexterm[normalize-space(primary)=$primary and 
-                                      normalize-space(secondary)=$secondary and not(tertiary)])">
-          <xsl:call-template name="write.indexterm">
-            <xsl:with-param name="text" select="concat($primary, ', ', $secondary)"/>
-          </xsl:call-template>
-        </xsl:if>
-      </xsl:if>
-      
-      <xsl:call-template name="write.indexterm">
-        <xsl:with-param name="text" select="$text"/>
-      </xsl:call-template>
-      
-    </xsl:when>
-    <xsl:otherwise>
-      <a>
-        <xsl:attribute name="name">
-          <xsl:call-template name="object.id"/>
-        </xsl:attribute>
-      </a>
-    </xsl:otherwise>
-    
-  </xsl:choose>
-</xsl:template>
-
-<xsl:template name="write.indexterm">
-  <xsl:param name="text"/>
-  <OBJECT type="application/x-oleobject"
-          classid="clsid:1e2a7bd0-dab9-11d0-b93a-00c04fc99f9e">
-    <param name="Keyword" value="{$text}"/>
-  </OBJECT>
-</xsl:template>
-
-<!-- ==================================================================== -->
-
-<xsl:template name="hhk">
-  <xsl:call-template name="write.chunk">
-    <xsl:with-param name="filename">
-      <xsl:if test="$manifest.in.base.dir != 0">
-        <xsl:value-of select="$chunk.base.dir"/>
-      </xsl:if>
-      <xsl:value-of select="$htmlhelp.hhk"/>
-    </xsl:with-param>
-    <xsl:with-param name="indent" select="'no'"/>
-    <xsl:with-param name="content"><xsl:text disable-output-escaping="yes"><![CDATA[<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
-<HTML>
-<HEAD>
-<meta name="GENERATOR" content="Microsoft&reg; HTML Help Workshop 4.1">
-<!-- Sitemap 1.0 -->
-</HEAD><BODY>
-<OBJECT type="text/site properties">
-</OBJECT>
-<UL>]]>
-</xsl:text>
-<xsl:if test="($htmlhelp.use.hhk != 0) and $htmlhelp.generate.index">
-  <xsl:choose>
-    <xsl:when test="$rootid != ''">
-      <xsl:apply-templates select="key('id',$rootid)" mode="hhk"/>
-    </xsl:when>
-    <xsl:otherwise>
-      <xsl:apply-templates select="/" mode="hhk"/>
-    </xsl:otherwise>
-  </xsl:choose>
-</xsl:if>
-<xsl:text disable-output-escaping="yes"><![CDATA[</UL>
-</BODY></HTML>]]>
-</xsl:text></xsl:with-param>
-    <xsl:with-param name="encoding" select="$htmlhelp.encoding"/>
-    <xsl:with-param name="quiet" select="$chunk.quietly"/>
-  </xsl:call-template>
-</xsl:template>
-
-<xsl:template match="indexterm[@class='endofrange']" mode="hhk"/>
-
-<xsl:template match="indexterm" mode="hhk">
-  <xsl:variable name="primary" select="normalize-space(primary)"/>
-  <xsl:variable name="secondary" select="normalize-space(secondary)"/>
-  <xsl:variable name="tertiary" select="normalize-space(tertiary)"/>
-
-  <xsl:call-template name="write.indexterm.hhk">
-    <xsl:with-param name="text" select="$primary"/>
-    <xsl:with-param name="seealso" select="seealso"/>
-  </xsl:call-template>
-
-  <xsl:if test="secondary">
-    <xsl:if test="not(//indexterm[normalize-space(primary)=$primary and not(secondary)])">
-      <xsl:call-template name="write.indexterm.hhk">
-        <!-- We must create fake entry when there is secondary without primary --> 
-        <xsl:with-param name="text" select="$primary"/>
-        <xsl:with-param name="seealso" select="$primary"/>
-      </xsl:call-template>
-    </xsl:if>
-    <UL>
-    <xsl:call-template name="write.indexterm.hhk">
-      <xsl:with-param name="text" select="$secondary"/>
-      <xsl:with-param name="seealso" select="secondary/seealso"/>
-    </xsl:call-template>
-    <xsl:if test="tertiary">
-      <UL>&lf;
-      <xsl:call-template name="write.indexterm.hhk">
-        <xsl:with-param name="text" select="$tertiary"/>
-        <xsl:with-param name="seealso" select="tertiary/seealso"/>
-      </xsl:call-template>
-      </UL>
-    </xsl:if>
-    </UL>
-  </xsl:if>
-
-</xsl:template>
-
-<xsl:template name="write.indexterm.hhk">
-  <xsl:param name="text"/>
-  <xsl:param name="seealso"/>
-
-  <LI> <OBJECT type="text/sitemap">&lf;
-    <param name="Name">
-      <xsl:attribute name="value">
-        <xsl:value-of select="$text"/>
-      </xsl:attribute>
-    </param>&lf;
-
-      <xsl:if test="not(seealso)">
-        <xsl:variable name="href">
-          <xsl:call-template name="href.target.with.base.dir"/>
-        </xsl:variable>
-        <xsl:variable name="title">
-          <xsl:call-template name="nearest.title">
-            <xsl:with-param name="object" select=".."/>
-          </xsl:call-template>
-        </xsl:variable>
-
-        <param name="Name">
-          <xsl:attribute name="value">
-          <xsl:value-of select="$title"/>
-          </xsl:attribute>
-        </param>&lf;
-        <param name="Local">
-          <xsl:attribute name="value">
-          <xsl:value-of select="$href"/>
-          </xsl:attribute>
-        </param>&lf;
-      </xsl:if>
-
-      <xsl:if test="seealso">
-        <param name="See Also">
-          <xsl:attribute name="value">
-          <xsl:value-of select="$seealso"/>
-          </xsl:attribute>
-        </param>&lf;
-      </xsl:if>
-      </OBJECT></LI>
-</xsl:template>
-
-<xsl:template match="text()" mode="hhk"/>
-
-<xsl:template name="nearest.title">
-  <xsl:param name="object"/>
-  <xsl:apply-templates select="$object/ancestor-or-self::*[title][1]" mode="title.markup"/>
-</xsl:template>
-
-<!-- ==================================================================== -->
-
-<xsl:template name="hh-map">
-  <xsl:call-template name="write.text.chunk">
-    <xsl:with-param name="filename">
-      <xsl:if test="$manifest.in.base.dir != 0">
-        <xsl:value-of select="$chunk.base.dir"/>
-      </xsl:if>
-      <xsl:value-of select="$htmlhelp.map.file"/>
-    </xsl:with-param>
-    <xsl:with-param name="method" select="'text'"/>
-    <xsl:with-param name="content">
-     <xsl:choose>
-       <xsl:when test="$rootid != ''">
-         <xsl:apply-templates select="key('id',$rootid)" mode="hh-map"/>
-       </xsl:when>
-       <xsl:otherwise>
-         <xsl:apply-templates select="/" mode="hh-map"/>
-       </xsl:otherwise>
-     </xsl:choose>
-    </xsl:with-param>
-    <xsl:with-param name="encoding" select="$htmlhelp.encoding"/>
-    <xsl:with-param name="quiet" select="$chunk.quietly"/>
-  </xsl:call-template>
-</xsl:template>
-
-<xsl:template match="processing-instruction('dbhh')" mode="hh-map">
-  <xsl:variable name="topicname">
-    <xsl:call-template name="pi-attribute">
-      <xsl:with-param name="pis"
-                      select="."/>
-      <xsl:with-param name="attribute" select="'topicname'"/>
-    </xsl:call-template>
-  </xsl:variable>
-  <xsl:variable name="topicid">
-    <xsl:call-template name="pi-attribute">
-      <xsl:with-param name="pis"
-                      select="."/>
-      <xsl:with-param name="attribute" select="'topicid'"/>
-    </xsl:call-template>
-  </xsl:variable>
-  <xsl:text>#define </xsl:text>
-  <xsl:value-of select="$topicname"/>
-  <xsl:text>&#9;</xsl:text>
-  <xsl:value-of select="$topicid"/>
-  <xsl:text>&#xA;</xsl:text>
-</xsl:template>
-
-<xsl:template match="text()" mode="hh-map"/>
-
-<!-- ==================================================================== -->
-
-<xsl:template name="hh-alias">
-  <xsl:call-template name="write.text.chunk">
-    <xsl:with-param name="filename">
-      <xsl:if test="$manifest.in.base.dir != 0">
-        <xsl:value-of select="$chunk.base.dir"/>
-      </xsl:if>
-      <xsl:value-of select="$htmlhelp.alias.file"/>
-    </xsl:with-param>
-    <xsl:with-param name="method" select="'text'"/>
-    <xsl:with-param name="content">
-     <xsl:choose>
-       <xsl:when test="$rootid != ''">
-         <xsl:apply-templates select="key('id',$rootid)" mode="hh-alias"/>
-       </xsl:when>
-       <xsl:otherwise>
-         <xsl:apply-templates select="/" mode="hh-alias"/>
-       </xsl:otherwise>
-     </xsl:choose>
-    </xsl:with-param>
-    <xsl:with-param name="encoding" select="$htmlhelp.encoding"/>
-    <xsl:with-param name="quiet" select="$chunk.quietly"/>
-  </xsl:call-template>
-</xsl:template>
-
-<xsl:template match="processing-instruction('dbhh')" mode="hh-alias">
-  <xsl:variable name="topicname">
-    <xsl:call-template name="pi-attribute">
-      <xsl:with-param name="pis"
-                      select="."/>
-      <xsl:with-param name="attribute" select="'topicname'"/>
-    </xsl:call-template>
-  </xsl:variable>
-  <xsl:variable name="href">
-    <xsl:call-template name="href.target.with.base.dir">
-      <xsl:with-param name="object" select=".."/>
-    </xsl:call-template>
-  </xsl:variable>
-  <xsl:value-of select="$topicname"/>
-  <xsl:text>=</xsl:text>
-  <!-- Some versions of HH doesn't like fragment identifires, but some does. -->
-  <!-- <xsl:value-of select="substring-before(concat($href, '#'), '#')"/> -->
-  <xsl:value-of select="$href"/>
-  <xsl:text>&#xA;</xsl:text>
-</xsl:template>
-
-<xsl:template match="text()" mode="hh-alias"/>
-
-<!-- ==================================================================== -->
-<!-- This code can be used to convert any number to hexadecimal format -->
-
-  <h:hex>
-    <d>0</d>
-    <d>1</d>
-    <d>2</d>
-    <d>3</d>
-    <d>4</d>
-    <d>5</d>
-    <d>6</d>
-    <d>7</d>
-    <d>8</d>
-    <d>9</d>
-    <d>A</d>
-    <d>B</d>
-    <d>C</d>
-    <d>D</d>
-    <d>E</d>
-    <d>F</d>
-  </h:hex>
-
-  <xsl:template name="toHex">
-    <xsl:param name="n" select="0"/>
-    <xsl:param name="digit" select="$n mod 16"/>
-    <xsl:param name="rest" select="floor($n div 16)"/>
-    <xsl:if test="$rest > 0">
-      <xsl:call-template name="toHex">
-        <xsl:with-param name="n" select="$rest"/>
-      </xsl:call-template>
-    </xsl:if>
-    <xsl:value-of select="document('')//h:hex/d[$digit+1]"/>
-  </xsl:template>
-
-<!-- ==================================================================== -->
-<!-- Modification to standard HTML stylesheets -->
-
-<!-- There are links from ToC pane to bibliodivs, so there must be anchor -->
-<xsl:template match="bibliodiv/title">
-  <h3 class="{name(.)}">
-    <xsl:call-template name="anchor">
-      <xsl:with-param name="node" select=".."/>
-      <xsl:with-param name="conditional" select="0"/>
-    </xsl:call-template>
-    <xsl:apply-templates/>
-  </h3>
-</xsl:template>
-
-</xsl:stylesheet>

+ 0 - 22
stylesheets/lfs-xsl/docbook-xsl-1.78.1/htmlhelp/htmlhelp.xsl

@@ -1,22 +0,0 @@
-<?xml version="1.0"?>
-<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
-                xmlns:doc="http://nwalsh.com/xsl/documentation/1.0"
-                xmlns:exsl="http://exslt.org/common"
-                xmlns:set="http://exslt.org/sets"
-		version="1.0"
-                exclude-result-prefixes="doc exsl set">
-
-<!-- ********************************************************************
-     $Id: htmlhelp.xsl 1676 2002-06-12 13:21:54Z kosek $
-     ******************************************************************** 
-
-     This file is used by htmlhelp.xsl if you want to generate source
-     files for HTML Help.  It is based on the XSL DocBook Stylesheet
-     distribution (especially on JavaHelp code) from Norman Walsh.
-
-     ******************************************************************** -->
-
-<xsl:import href="../html/chunk.xsl"/>
-<xsl:include href="htmlhelp-common.xsl"/>
-
-</xsl:stylesheet>

+ 0 - 1083
stylesheets/lfs-xsl/docbook-xsl-1.78.1/htmlhelp/profile-htmlhelp-common.xsl

@@ -1,1083 +0,0 @@
-<?xml version="1.0" encoding="US-ASCII"?>
-<!--This file was created automatically by xsl2profile-->
-<!--from the DocBook XSL stylesheets.-->
-<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" xmlns:doc="http://nwalsh.com/xsl/documentation/1.0" xmlns:exsl="http://exslt.org/common" xmlns:set="http://exslt.org/sets" xmlns:h="urn:x-hex" xmlns:ng="http://docbook.org/docbook-ng" xmlns:db="http://docbook.org/ns/docbook" xmlns:exslt="http://exslt.org/common" exslt:dummy="dummy" ng:dummy="dummy" db:dummy="dummy" extension-element-prefixes="exslt" version="1.0" exclude-result-prefixes="doc exsl set h db ng exslt">
-
-<!-- ********************************************************************
-     $Id: htmlhelp-common.xsl 9151 2011-11-12 00:16:19Z bobstayton $
-     ******************************************************************** -->
-
-<!-- ==================================================================== -->
-<!-- Customizations of standard HTML stylesheet parameters -->
-
-<!-- no navigation on pages by default, HTML Help provides its own navigation controls -->
-<xsl:param name="suppress.navigation" select="1"/>
-
-<!-- no separate HTML page with index, index is built inside CHM index pane -->
-<xsl:param name="generate.index" select="0"/>
-
-<!-- ==================================================================== -->
-
-<xsl:param name="htmlhelp.generate.index" select="//indexterm[1]|//db:indexterm[1]|//ng:indexterm[1]"/>
-  
-<!-- Set up HTML Help flag -->
-<xsl:variable name="htmlhelp.output" select="1"/>
-
-<!-- ==================================================================== -->
-
-<xslo:include xmlns:xslo="http://www.w3.org/1999/XSL/Transform" href="../profiling/profile-mode.xsl"/><xslo:variable xmlns:xslo="http://www.w3.org/1999/XSL/Transform" name="profiled-content"><xslo:choose><xslo:when test="*/self::ng:* or */self::db:*"><xslo:message>Note: namesp. cut : stripped namespace before processing</xslo:message><xslo:variable name="stripped-content"><xslo:apply-templates select="/" mode="stripNS"/></xslo:variable><xslo:message>Note: namesp. cut : processing stripped document</xslo:message><xslo:apply-templates select="exslt:node-set($stripped-content)" mode="profile"/></xslo:when><xslo:otherwise><xslo:apply-templates select="/" mode="profile"/></xslo:otherwise></xslo:choose></xslo:variable><xslo:variable xmlns:xslo="http://www.w3.org/1999/XSL/Transform" name="profiled-nodes" select="exslt:node-set($profiled-content)"/><xsl:template match="/">
-
-  <!-- * Get a title for current doc so that we let the user -->
-  <!-- * know what document we are processing at this point. -->
-  <xsl:variable name="doc.title">
-    <xsl:call-template name="get.doc.title"/>
-  </xsl:variable>
-  <xsl:choose>
-    <!-- Hack! If someone hands us a DocBook V5.x or DocBook NG document,
-         toss the namespace and continue.  Use the docbook5 namespaced
-         stylesheets for DocBook5 if you don't want to use this feature.-->
-    <xsl:when test="false()"/>
-    <xsl:otherwise>
-  <xsl:if test="$htmlhelp.only != 1">
-    <xsl:choose>
-      <xsl:when test="$rootid != ''">
-        <xsl:choose>
-          <xsl:when test="count($profiled-nodes//*[@id=$rootid or @xml:id=$rootid]) = 0">
-            <xsl:message terminate="yes">
-              <xsl:text>ID '</xsl:text>
-              <xsl:value-of select="$rootid"/>
-              <xsl:text>' not found in document.</xsl:text>
-            </xsl:message>
-          </xsl:when>
-          <xsl:otherwise>
-            <xsl:message>Formatting from <xsl:value-of select="$rootid"/></xsl:message>
-            <xsl:apply-templates select="$profiled-nodes//*[@id=$rootid or @xml:id=$rootid]" mode="process.root"/>
-          </xsl:otherwise>
-        </xsl:choose>
-      </xsl:when>
-      <xsl:otherwise>
-        <xsl:if test="$collect.xref.targets = 'yes' or                       $collect.xref.targets = 'only'">
-          <xsl:apply-templates select="$profiled-nodes" mode="collect.targets"/>
-        </xsl:if>
-        <xsl:if test="$collect.xref.targets != 'only'">
-          <xsl:apply-templates select="$profiled-nodes" mode="process.root"/>
-        </xsl:if>
-      </xsl:otherwise>
-    </xsl:choose>
-  </xsl:if>
-
-
-  <xsl:if test="$collect.xref.targets != 'only'">
-    <xsl:call-template name="hhp"/>
-    <xsl:call-template name="hhc"/>
-    <xsl:if test="($rootid = '' and //processing-instruction('dbhh')) or                   ($rootid != '' and $profiled-nodes//*[@id=$rootid or @xml:id=$rootid]//processing-instruction('dbhh'))">
-      <xsl:call-template name="hh-map"/>
-      <xsl:call-template name="hh-alias"/>
-    </xsl:if>
-    <xsl:if test="$htmlhelp.generate.index">
-      <xsl:call-template name="hhk"/>
-    </xsl:if>
-  </xsl:if>
-</xsl:otherwise>
-</xsl:choose>
-</xsl:template>
-
-<!-- ==================================================================== -->
-
-<xsl:template name="hhp">
-  <xsl:call-template name="write.text.chunk">
-    <xsl:with-param name="filename">
-      <xsl:if test="$manifest.in.base.dir != 0">
-        <xsl:value-of select="$chunk.base.dir"/>
-      </xsl:if>
-      <xsl:value-of select="$htmlhelp.hhp"/>
-    </xsl:with-param>
-    <xsl:with-param name="method" select="'text'"/>
-    <xsl:with-param name="content">
-      <xsl:call-template name="hhp-main"/>
-    </xsl:with-param>
-    <xsl:with-param name="encoding" select="$htmlhelp.encoding"/>
-    <xsl:with-param name="quiet" select="$chunk.quietly"/>
-  </xsl:call-template>
-</xsl:template>
-
-<!-- ==================================================================== -->
-<xsl:template name="hhp-main">
-
-  <xsl:variable name="raw.help.title">
-    <xsl:choose>
-      <xsl:when test="$htmlhelp.title = ''">
-        <xsl:choose>
-          <xsl:when test="$rootid != ''">
-            <xsl:apply-templates select="$profiled-nodes//*[@id=$rootid or @xml:id=$rootid]" mode="title.markup"/>
-          </xsl:when>
-          <xsl:otherwise>
-            <xsl:apply-templates select="$profiled-nodes/*" mode="title.markup"/>
-          </xsl:otherwise>
-        </xsl:choose>
-      </xsl:when>
-      <xsl:otherwise>
-        <xsl:value-of select="$htmlhelp.title"/>
-      </xsl:otherwise>
-    </xsl:choose>
-  </xsl:variable>
-
-  <xsl:variable name="help.title" select="normalize-space($raw.help.title)"/>
-  
-<xsl:variable name="default.topic">
-  <xsl:choose>
-    <xsl:when test="$htmlhelp.default.topic != ''">
-      <xsl:value-of select="$htmlhelp.default.topic"/>
-    </xsl:when>
-    <xsl:otherwise>
-      <xsl:call-template name="make-relative-filename">
-        <xsl:with-param name="base.dir">
-          <xsl:if test="$manifest.in.base.dir = 0">
-            <xsl:value-of select="$chunk.base.dir"/>
-          </xsl:if>
-        </xsl:with-param>
-        <xsl:with-param name="base.name">
-          <xsl:choose>
-            <xsl:when test="$rootid != ''">
-              <xsl:apply-templates select="$profiled-nodes//*[@id=$rootid or @xml:id=$rootid]" mode="chunk-filename"/>
-            </xsl:when>
-            <xsl:otherwise>
-              <xsl:apply-templates select="$profiled-nodes" mode="chunk-filename"/>
-            </xsl:otherwise>
-          </xsl:choose>
-        </xsl:with-param>
-      </xsl:call-template>
-    </xsl:otherwise>
-  </xsl:choose>
-</xsl:variable>
-<xsl:variable name="xnavigation">
-  <xsl:text>0x</xsl:text>
-  <xsl:call-template name="toHex">
-    <xsl:with-param name="n" select="9504 + $htmlhelp.show.menu * 65536                                           + $htmlhelp.show.advanced.search * 131072                                           + $htmlhelp.show.favorities * 4096                                           + (1 - $htmlhelp.show.toolbar.text) * 64                                           + $htmlhelp.remember.window.position * 262144"/>
-  </xsl:call-template>
-</xsl:variable>
-<xsl:variable name="xbuttons">
-  <xsl:text>0x</xsl:text>
-  <xsl:call-template name="toHex">
-    <xsl:with-param name="n" select="0 + $htmlhelp.button.hideshow * 2                                        + $htmlhelp.button.back * 4                                        + $htmlhelp.button.forward * 8                                        + $htmlhelp.button.stop * 16                                        + $htmlhelp.button.refresh * 32                                        + $htmlhelp.button.home * 64                                        + $htmlhelp.button.options * 4096                                        + $htmlhelp.button.print * 8192                                        + $htmlhelp.button.locate * 2048                                        + $htmlhelp.button.jump1 * 262144                                        + $htmlhelp.button.jump2 * 524288                                        + $htmlhelp.button.next * 2097152                                        + $htmlhelp.button.prev * 4194304                                        + $htmlhelp.button.zoom * 1048576"/>
-  </xsl:call-template>
-</xsl:variable>
-<xsl:text>[OPTIONS]
-</xsl:text>
-<xsl:if test="$htmlhelp.generate.index">
-<xsl:text>Auto Index=Yes
-</xsl:text></xsl:if>
-<xsl:if test="$htmlhelp.hhc.binary != 0">
-<xsl:text>Binary TOC=Yes
-</xsl:text></xsl:if>
-<xsl:text>Compatibility=1.1 or later
-Compiled file=</xsl:text><xsl:value-of select="$htmlhelp.chm"/><xsl:text>
-Contents file=</xsl:text><xsl:value-of select="$htmlhelp.hhc"/><xsl:text>
-</xsl:text>
-<xsl:if test="$htmlhelp.hhp.window != ''">
-<xsl:text>Default Window=</xsl:text><xsl:value-of select="$htmlhelp.hhp.window"/><xsl:text>
-</xsl:text></xsl:if>
-<xsl:text>Default topic=</xsl:text><xsl:value-of select="$default.topic"/>
-<xsl:text>
-Display compile progress=</xsl:text>
-  <xsl:choose>
-    <xsl:when test="$htmlhelp.display.progress != 1">
-      <xsl:text>No</xsl:text>
-    </xsl:when>
-    <xsl:otherwise>
-      <xsl:text>Yes</xsl:text>
-    </xsl:otherwise>
-  </xsl:choose>
-<xsl:text>
-Full-text search=Yes
-</xsl:text>
-<xsl:if test="$htmlhelp.generate.index">
-<xsl:text>Index file=</xsl:text><xsl:value-of select="$htmlhelp.hhk"/><xsl:text>
-</xsl:text></xsl:if>
-<xsl:text>Language=</xsl:text>
-<xsl:for-each select="*">   <!-- Change context from / to root element -->
-  <xsl:call-template name="gentext.template">
-    <xsl:with-param name="context" select="'htmlhelp'"/>
-    <xsl:with-param name="name" select="'langcode'"/>
-  </xsl:call-template>
-</xsl:for-each>
-<xsl:text>
-Title=</xsl:text>
-  <xsl:value-of select="$help.title"/>
-<xsl:text>
-Enhanced decompilation=</xsl:text>
-  <xsl:choose>
-    <xsl:when test="$htmlhelp.enhanced.decompilation != 0">
-      <xsl:text>Yes</xsl:text>
-    </xsl:when>
-    <xsl:otherwise>
-      <xsl:text>No</xsl:text>
-    </xsl:otherwise>
-  </xsl:choose>
-
-<xsl:if test="$htmlhelp.hhp.window != ''">
-  <xsl:text>
-
-[WINDOWS]
-</xsl:text>
-<xsl:value-of select="$htmlhelp.hhp.window"/>
-<xsl:text>="</xsl:text>
-<xsl:value-of select="$help.title"/>
-<xsl:text>","</xsl:text><xsl:value-of select="$htmlhelp.hhc"/>
-<xsl:text>",</xsl:text>
-<xsl:if test="$htmlhelp.generate.index">
-  <xsl:text>"</xsl:text>
-  <xsl:value-of select="$htmlhelp.hhk"/>
-  <xsl:text>"</xsl:text>
-</xsl:if>
-<xsl:text>,"</xsl:text>
-<xsl:value-of select="$default.topic"/>
-<xsl:text>",</xsl:text>
-<xsl:text>"</xsl:text>
-<xsl:choose>
-  <xsl:when test="$htmlhelp.button.home != 0">
-    <xsl:value-of select="$htmlhelp.button.home.url"/>
-  </xsl:when>
-  <xsl:otherwise>
-    <xsl:value-of select="$default.topic"/>
-  </xsl:otherwise>
-</xsl:choose>
-<xsl:text>"</xsl:text>
-<xsl:text>,</xsl:text>
-<xsl:if test="$htmlhelp.button.jump1 != 0">
-  <xsl:text>"</xsl:text>
-  <xsl:value-of select="$htmlhelp.button.jump1.url"/>
-  <xsl:text>"</xsl:text>
-</xsl:if>
-<xsl:text>,</xsl:text>
-<xsl:if test="$htmlhelp.button.jump1 != 0">
-  <xsl:text>"</xsl:text>
-  <xsl:value-of select="$htmlhelp.button.jump1.title"/>
-  <xsl:text>"</xsl:text>
-</xsl:if>
-<xsl:text>,</xsl:text>
-<xsl:if test="$htmlhelp.button.jump2 != 0">
-  <xsl:text>"</xsl:text>
-  <xsl:value-of select="$htmlhelp.button.jump2.url"/>
-  <xsl:text>"</xsl:text>
-</xsl:if>
-<xsl:text>,</xsl:text>
-<xsl:if test="$htmlhelp.button.jump2 != 0">
-  <xsl:text>"</xsl:text>
-  <xsl:value-of select="$htmlhelp.button.jump2.title"/>
-  <xsl:text>"</xsl:text>
-</xsl:if>
-<xsl:text>,</xsl:text>
-<xsl:value-of select="$xnavigation"/>
-<xsl:text>,</xsl:text><xsl:value-of select="$htmlhelp.hhc.width"/><xsl:text>,</xsl:text>
-<xsl:value-of select="$xbuttons"/>
-<xsl:text>,</xsl:text><xsl:value-of select="$htmlhelp.window.geometry"/><xsl:text>,,,,,,,0
-</xsl:text>
-</xsl:if>
-
-<!-- 
-  Needs more investigation to generate propetly all fields 
-<xsl:text>search="</xsl:text>
-<xsl:value-of select="normalize-space(//title[1])"/>
-<xsl:text>","toc.hhc","index.hhk","</xsl:text>
-<xsl:value-of select="$root.filename"/>
-<xsl:text>.html","</xsl:text>
-<xsl:value-of select="$root.filename"/>
-<xsl:text>.html",,,,,</xsl:text>
-<xsl:value-of select="$xnavigation"/>
-<xsl:text>,</xsl:text>
-<xsl:value-of select="$htmlhelp.hhc.width"/>
-<xsl:text>,</xsl:text>
-<xsl:value-of select="$xbuttons"/>
-<xsl:text>,</xsl:text>
-<xsl:value-of select="$htmlhelp.window.geometry"/>
-<xsl:text>,,,,,2,,0
-</xsl:text>
--->
-
-<xsl:if test="$htmlhelp.hhp.windows">
-  <xsl:value-of select="$htmlhelp.hhp.windows"/>
-</xsl:if>
-<xsl:text>
-
-[FILES]
-</xsl:text>
-
-<xsl:choose>
-  <xsl:when test="$rootid != ''">
-    <xsl:apply-templates select="$profiled-nodes//*[@id=$rootid or @xml:id=$rootid]" mode="enumerate-files"/>
-  </xsl:when>
-  <xsl:otherwise>
-    <xsl:apply-templates select="$profiled-nodes" mode="enumerate-files"/>
-  </xsl:otherwise>
-</xsl:choose>
-
-<xsl:if test="$htmlhelp.enumerate.images">
-  <xsl:variable name="imagelist">
-    <xsl:choose>
-      <xsl:when test="$rootid != ''">
-        <xsl:apply-templates select="$profiled-nodes//*[@id=$rootid or @xml:id=$rootid]" mode="enumerate-images"/>
-      </xsl:when>
-      <xsl:otherwise>
-        <xsl:apply-templates select="$profiled-nodes" mode="enumerate-images"/>
-      </xsl:otherwise>
-    </xsl:choose>
-  </xsl:variable>
-  <xsl:choose>
-    <xsl:when test="$exsl.node.set.available != 0                     and function-available('set:distinct')">
-      <xsl:for-each select="set:distinct(exsl:node-set($imagelist)/filename)">
-        <xsl:value-of select="."/>
-        <xsl:text>
-</xsl:text>
-      </xsl:for-each>
-    </xsl:when>
-    <xsl:otherwise>
-      <xsl:value-of select="$imagelist"/>
-    </xsl:otherwise>
-  </xsl:choose>
-</xsl:if>
-
-<xsl:if test="($htmlhelp.force.map.and.alias != 0) or                ($rootid = '' and //processing-instruction('dbhh')) or               ($rootid != '' and $profiled-nodes//*[@id=$rootid or @xml:id=$rootid]//processing-instruction('dbhh'))">
-  <xsl:text>
-[ALIAS]
-#include </xsl:text><xsl:value-of select="$htmlhelp.alias.file"/><xsl:text>
-
-[MAP]
-#include </xsl:text><xsl:value-of select="$htmlhelp.map.file"/><xsl:text>
-</xsl:text>
-</xsl:if>
-
-<xsl:value-of select="$htmlhelp.hhp.tail"/>
-</xsl:template>
-
-<!-- ==================================================================== -->
-
-<xsl:template match="graphic|inlinegraphic[@format!='linespecific']" mode="enumerate-images">
-  <xsl:call-template name="write.filename.enumerate-images">
-    <xsl:with-param name="filename">
-      <xsl:call-template name="mediaobject.filename.enumerate-images">
-        <xsl:with-param name="object" select="."/>
-      </xsl:call-template>  
-    </xsl:with-param>
-  </xsl:call-template>
-</xsl:template>
-
-<xsl:template match="mediaobject|inlinemediaobject" mode="enumerate-images">
-  <xsl:call-template name="select.mediaobject.enumerate-images"/>
-</xsl:template>
-
-<xsl:template name="select.mediaobject.enumerate-images">
-  <xsl:param name="olist" select="imageobject|imageobjectco                      |videoobject|audioobject|textobject"/>
-  <xsl:param name="count">1</xsl:param>
-
-  <xsl:if test="$count &lt;= count($olist)">
-    <xsl:variable name="object" select="$olist[position()=$count]"/>
-
-    <xsl:variable name="useobject">
-      <xsl:choose>
-        <!-- The phrase is never used -->
-        <xsl:when test="name($object)='textobject' and $object/phrase">
-          <xsl:text>0</xsl:text>
-        </xsl:when>
-        <!-- The first textobject is a reasonable fallback (but not for image in HH) -->
-        <xsl:when test="name($object)='textobject'">
-          <xsl:text>0</xsl:text>
-        </xsl:when>
-        <!-- If there's only one object, use it -->
-        <xsl:when test="$count = 1 and count($olist) = 1">
-          <xsl:text>1</xsl:text>
-        </xsl:when>
-        <!-- Otherwise, see if this one is a useable graphic -->
-        <xsl:otherwise>
-          <xsl:choose>
-            <!-- peek inside imageobjectco to simplify the test -->
-            <xsl:when test="local-name($object) = 'imageobjectco'">
-              <xsl:call-template name="is.acceptable.mediaobject">
-                <xsl:with-param name="object" select="$object/imageobject"/>
-              </xsl:call-template>
-            </xsl:when>
-            <xsl:otherwise>
-              <xsl:call-template name="is.acceptable.mediaobject">
-                <xsl:with-param name="object" select="$object"/>
-              </xsl:call-template>
-            </xsl:otherwise>
-          </xsl:choose>
-        </xsl:otherwise>
-      </xsl:choose>
-    </xsl:variable>
-
-    <xsl:choose>
-      <xsl:when test="$useobject='1' and $object[not(*/@format='linespecific')]">
-        <xsl:call-template name="write.filename.enumerate-images">
-          <xsl:with-param name="filename">
-            <xsl:call-template name="mediaobject.filename.enumerate-images">
-              <xsl:with-param name="object" select="$object"/>
-            </xsl:call-template>
-          </xsl:with-param>
-        </xsl:call-template>
-      </xsl:when>
-      <xsl:otherwise>
-        <xsl:call-template name="select.mediaobject.enumerate-images">
-          <xsl:with-param name="olist" select="$olist"/>
-          <xsl:with-param name="count" select="$count + 1"/>
-        </xsl:call-template>
-      </xsl:otherwise>
-    </xsl:choose>
-  </xsl:if>
-</xsl:template>
-
-<xsl:template name="mediaobject.filename.enumerate-images">
-  <xsl:param name="object"/>
-
-  <xsl:variable name="urifilename">
-    <xsl:call-template name="mediaobject.filename">
-      <xsl:with-param name="object" select="$object"/>
-    </xsl:call-template>
-  </xsl:variable>
-
-  <xsl:variable name="filename">
-    <xsl:choose>
-      <xsl:when test="starts-with($urifilename, 'file:/')">
-        <xsl:value-of select="substring-after($urifilename, 'file:/')"/>
-      </xsl:when>
-      <xsl:otherwise>
-        <xsl:value-of select="$urifilename"/>
-      </xsl:otherwise>
-    </xsl:choose>
-  </xsl:variable>
-
-  <xsl:value-of select="translate($filename, '/', '\')"/>
-
-</xsl:template>
-
-<xsl:template match="text()" mode="enumerate-images">
-</xsl:template>
-
-<xsl:template name="write.filename.enumerate-images">
-  <xsl:param name="filename"/>
-  <xsl:choose>
-    <xsl:when test="function-available('exsl:node-set') and function-available('set:distinct')">
-      <filename><xsl:value-of select="$filename"/></filename>
-    </xsl:when>
-    <xsl:otherwise>
-      <xsl:value-of select="$filename"/>
-      <xsl:text>
-</xsl:text>
-    </xsl:otherwise>
-  </xsl:choose>
-</xsl:template>
-
-<!-- ==================================================================== -->
-
-<!-- HHC and HHK files are processed by compiler line by line
-     and therefore are very sensitive to whitespaces (linefeeds for sure).  -->
-
-<xsl:template name="hhc">
-  <xsl:call-template name="write.chunk">
-    <xsl:with-param name="filename">
-      <xsl:if test="$manifest.in.base.dir != 0">
-        <xsl:value-of select="$chunk.base.dir"/>
-      </xsl:if>
-      <xsl:value-of select="$htmlhelp.hhc"/>
-    </xsl:with-param>
-    <xsl:with-param name="indent" select="'no'"/>
-    <xsl:with-param name="content">
-      <xsl:call-template name="hhc-main"/>
-    </xsl:with-param>
-    <xsl:with-param name="encoding" select="$htmlhelp.encoding"/>
-    <xsl:with-param name="quiet" select="$chunk.quietly"/>
-  </xsl:call-template>
-</xsl:template>
-
-<xsl:template name="hhc-main">
-<HTML><xsl:text>
-</xsl:text>
- <HEAD/><xsl:text>
-</xsl:text>
- <BODY><xsl:text>
-</xsl:text>
-  <xsl:if test="$htmlhelp.hhc.folders.instead.books != 0">
-   <OBJECT type="text/site properties"><xsl:text>
-</xsl:text>
-     <param name="ImageType" value="Folder"/><xsl:text>
-</xsl:text>
-   </OBJECT><xsl:text>
-</xsl:text>
-  </xsl:if>
-  <xsl:variable name="content">
-    <xsl:choose>
-      <xsl:when test="$rootid != ''">
-        <xsl:apply-templates select="$profiled-nodes//*[@id=$rootid or @xml:id=$rootid]" mode="hhc"/>
-      </xsl:when>
-      <xsl:otherwise>
-        <xsl:apply-templates select="$profiled-nodes" mode="hhc"/>
-      </xsl:otherwise>
-    </xsl:choose>
-  </xsl:variable>
-
-  <xsl:choose>
-    <xsl:when test="$htmlhelp.hhc.show.root != 0">
-      <UL><xsl:text>
-</xsl:text>
-        <xsl:copy-of select="$content"/>
-      </UL><xsl:text>
-</xsl:text>
-    </xsl:when>
-    <xsl:otherwise>
-    <xsl:copy-of select="$content"/>
-    </xsl:otherwise>
-  </xsl:choose>
-
- </BODY>
-</HTML>
-</xsl:template>
-
-<xsl:template name="hhc.entry">
-  <xsl:param name="title">
-    <xsl:if test="$htmlhelp.autolabel=1">
-      <xsl:variable name="label.markup">
-        <xsl:apply-templates select="." mode="label.markup"/>
-      </xsl:variable>
-      <xsl:if test="normalize-space($label.markup)">
-        <xsl:value-of select="concat($label.markup,$autotoc.label.separator)"/>
-      </xsl:if>
-    </xsl:if>
-    <xsl:apply-templates select="." mode="title.markup"/>
-  </xsl:param>
-
-  <LI><OBJECT type="text/sitemap"><xsl:text>
-</xsl:text>
-    <param name="Name">
-      <xsl:attribute name="value">
-          <xsl:value-of select="normalize-space($title)"/>
-      </xsl:attribute>
-    </param><xsl:text>
-</xsl:text>
-    <param name="Local">
-      <xsl:attribute name="value">
-          <xsl:call-template name="href.target.with.base.dir"/>
-      </xsl:attribute>
-    </param>
-  </OBJECT></LI><xsl:text>
-</xsl:text>
-</xsl:template>
-
-<xsl:template match="set" mode="hhc">
-  <xsl:if test="$htmlhelp.hhc.show.root != 0">
-    <xsl:call-template name="hhc.entry"/>
-  </xsl:if>
-  <xsl:if test="book">
-    <xsl:variable name="toc.params">
-      <xsl:call-template name="find.path.params">
-        <xsl:with-param name="table" select="normalize-space($generate.toc)"/>
-      </xsl:call-template>
-    </xsl:variable>
-    <UL>
-      <xsl:if test="contains($toc.params, 'toc') and $htmlhelp.hhc.show.root = 0">
-      <LI><OBJECT type="text/sitemap"><xsl:text>
-</xsl:text>
-          <param name="Name">
-            <xsl:attribute name="value">
-            <xsl:call-template name="gentext">
-              <xsl:with-param name="key" select="'TableofContents'"/>
-            </xsl:call-template>
-            </xsl:attribute>
-          </param><xsl:text>
-</xsl:text>
-          <param name="Local">
-            <xsl:attribute name="value">
-              <xsl:choose>
-                <xsl:when test="$chunk.tocs.and.lots != 0">
-                  <xsl:apply-templates select="." mode="recursive-chunk-filename">
-                    <xsl:with-param name="recursive" select="true()"/>
-                  </xsl:apply-templates>
-                  <xsl:text>-toc</xsl:text>
-                  <xsl:value-of select="$html.ext"/>
-                </xsl:when>
-                <xsl:otherwise>
-                  <xsl:call-template name="href.target.with.base.dir"/>
-                </xsl:otherwise>
-              </xsl:choose>
-            </xsl:attribute>
-          </param>
-      </OBJECT></LI><xsl:text>
-</xsl:text>
-      </xsl:if>
-      <xsl:apply-templates select="book" mode="hhc"/>
-    </UL><xsl:text>
-</xsl:text>
-  </xsl:if>
-</xsl:template>
-
-<xsl:template match="book" mode="hhc">
-  <xsl:if test="$htmlhelp.hhc.show.root != 0 or parent::*">
-    <xsl:call-template name="hhc.entry"/>
-  </xsl:if>
-  <xsl:if test="part|reference|preface|chapter|appendix|bibliography|article|colophon|glossary">
-    <xsl:variable name="toc.params">
-      <xsl:call-template name="find.path.params">
-        <xsl:with-param name="table" select="normalize-space($generate.toc)"/>
-      </xsl:call-template>
-    </xsl:variable>
-    <UL>
-      <xsl:if test="contains($toc.params, 'toc') and $htmlhelp.hhc.show.root = 0 and not(parent::*)">
-        <LI><OBJECT type="text/sitemap"><xsl:text>
-</xsl:text>
-            <param name="Name">
-              <xsl:attribute name="value">
-                <xsl:call-template name="gentext">
-                  <xsl:with-param name="key" select="'TableofContents'"/>
-                </xsl:call-template>
-              </xsl:attribute>
-            </param><xsl:text>
-</xsl:text>
-            <param name="Local">
-              <xsl:attribute name="value">
-                <xsl:choose>
-                  <xsl:when test="$chunk.tocs.and.lots != 0">
-                    <xsl:apply-templates select="." mode="recursive-chunk-filename">
-                      <xsl:with-param name="recursive" select="true()"/>
-                    </xsl:apply-templates>
-                    <xsl:text>-toc</xsl:text>
-                    <xsl:value-of select="$html.ext"/>
-                  </xsl:when>
-                  <xsl:otherwise>
-                    <xsl:call-template name="href.target.with.base.dir"/>
-                  </xsl:otherwise>
-                </xsl:choose>
-              </xsl:attribute>
-            </param>
-        </OBJECT></LI><xsl:text>
-</xsl:text>
-      </xsl:if>
-      <xsl:apply-templates select="part|reference|preface|chapter|bibliography|appendix|article|colophon|glossary" mode="hhc"/>
-    </UL><xsl:text>
-</xsl:text>
-  </xsl:if>
-</xsl:template>
-
-<xsl:template match="part|reference|preface|chapter|bibliography|appendix|article|glossary" mode="hhc">
-  <xsl:if test="$htmlhelp.hhc.show.root != 0 or parent::*">
-    <xsl:call-template name="hhc.entry"/>
-  </xsl:if>
-  <xsl:if test="article|reference|preface|chapter|appendix|refentry|section|sect1|bibliodiv">
-    <UL><xsl:text>
-</xsl:text>
-      <xsl:apply-templates select="article|reference|preface|chapter|appendix|refentry|section|sect1|bibliodiv" mode="hhc"/>
-    </UL>
-  </xsl:if>
-</xsl:template>
-
-<xsl:template match="section" mode="hhc">
-  <xsl:if test="$htmlhelp.hhc.show.root != 0 or parent::*">
-    <xsl:call-template name="hhc.entry"/>
-  </xsl:if>
-  <xsl:if test="section[count(ancestor::section) &lt; $htmlhelp.hhc.section.depth]|refentry">
-    <UL><xsl:text>
-</xsl:text>
-      <xsl:apply-templates select="section|refentry" mode="hhc"/>
-    </UL>
-  </xsl:if>
-</xsl:template>
-
-<xsl:template match="sect1" mode="hhc">
-  <xsl:if test="$htmlhelp.hhc.show.root != 0 or parent::*">
-    <xsl:call-template name="hhc.entry"/>
-  </xsl:if>
-  <xsl:if test="sect2[$htmlhelp.hhc.section.depth &gt; 1]|refentry">
-    <UL><xsl:text>
-</xsl:text>
-      <xsl:apply-templates select="sect2|refentry" mode="hhc"/>
-    </UL>
-  </xsl:if>
-</xsl:template>
-
-<xsl:template match="sect2" mode="hhc">
-  <xsl:if test="$htmlhelp.hhc.show.root != 0 or parent::*">
-    <xsl:call-template name="hhc.entry"/>
-  </xsl:if>
-  <xsl:if test="sect3[$htmlhelp.hhc.section.depth &gt; 2]|refentry">
-    <UL><xsl:text>
-</xsl:text>
-      <xsl:apply-templates select="sect3|refentry" mode="hhc"/>
-    </UL>
-  </xsl:if>
-</xsl:template>
-
-<xsl:template match="sect3" mode="hhc">
-  <xsl:if test="$htmlhelp.hhc.show.root != 0 or parent::*">
-    <xsl:call-template name="hhc.entry"/>
-  </xsl:if>
-  <xsl:if test="sect4[$htmlhelp.hhc.section.depth &gt; 3]|refentry">
-    <UL><xsl:text>
-</xsl:text>
-      <xsl:apply-templates select="sect4|refentry" mode="hhc"/>
-    </UL>
-  </xsl:if>
-</xsl:template>
-
-<xsl:template match="sect4" mode="hhc">
-  <xsl:if test="$htmlhelp.hhc.show.root != 0 or parent::*">
-    <xsl:call-template name="hhc.entry"/>
-  </xsl:if>
-  <xsl:if test="sect5[$htmlhelp.hhc.section.depth &gt; 4]|refentry">
-    <UL><xsl:text>
-</xsl:text>
-      <xsl:apply-templates select="sect5|refentry" mode="hhc"/>
-    </UL>
-  </xsl:if>
-</xsl:template>
-
-<xsl:template match="sect5|refentry|colophon|bibliodiv" mode="hhc">
-  <xsl:if test="$htmlhelp.hhc.show.root != 0 or parent::*">
-    <xsl:call-template name="hhc.entry"/>
-  </xsl:if>
-  <xsl:if test="refentry">
-    <UL><xsl:text>
-</xsl:text>
-      <xsl:apply-templates select="refentry" mode="hhc"/>
-    </UL>
-  </xsl:if>
-</xsl:template>
-
-<!-- ==================================================================== -->
-
-<xsl:template match="indexterm">
-  <xsl:choose>
-    <xsl:when test="$htmlhelp.use.hhk = 0">
-  
-      <xsl:variable name="primary" select="normalize-space(primary)"/>
-      <xsl:variable name="secondary" select="normalize-space(secondary)"/>
-      <xsl:variable name="tertiary" select="normalize-space(tertiary)"/>
-      
-      <xsl:variable name="text">
-        <xsl:value-of select="$primary"/>
-        <xsl:if test="secondary">
-          <xsl:text>, </xsl:text>
-          <xsl:value-of select="$secondary"/>
-        </xsl:if>
-        <xsl:if test="tertiary">
-          <xsl:text>, </xsl:text>
-          <xsl:value-of select="$tertiary"/>
-        </xsl:if>
-      </xsl:variable>
-      
-      <xsl:if test="secondary">
-        <xsl:if test="not(//indexterm[normalize-space(primary)=$primary and not(secondary)])">
-          <xsl:call-template name="write.indexterm">
-            <xsl:with-param name="text" select="$primary"/>
-          </xsl:call-template>
-        </xsl:if>
-      </xsl:if>
-
-      <xsl:if test="tertiary">
-        <xsl:if test="not(//indexterm[normalize-space(primary)=$primary and                                        normalize-space(secondary)=$secondary and not(tertiary)])">
-          <xsl:call-template name="write.indexterm">
-            <xsl:with-param name="text" select="concat($primary, ', ', $secondary)"/>
-          </xsl:call-template>
-        </xsl:if>
-      </xsl:if>
-      
-      <xsl:call-template name="write.indexterm">
-        <xsl:with-param name="text" select="$text"/>
-      </xsl:call-template>
-      
-    </xsl:when>
-    <xsl:otherwise>
-      <a>
-        <xsl:attribute name="name">
-          <xsl:call-template name="object.id"/>
-        </xsl:attribute>
-      </a>
-    </xsl:otherwise>
-    
-  </xsl:choose>
-</xsl:template>
-
-<xsl:template name="write.indexterm">
-  <xsl:param name="text"/>
-  <OBJECT type="application/x-oleobject" classid="clsid:1e2a7bd0-dab9-11d0-b93a-00c04fc99f9e">
-    <param name="Keyword" value="{$text}"/>
-  </OBJECT>
-</xsl:template>
-
-<!-- ==================================================================== -->
-
-<xsl:template name="hhk">
-  <xsl:call-template name="write.chunk">
-    <xsl:with-param name="filename">
-      <xsl:if test="$manifest.in.base.dir != 0">
-        <xsl:value-of select="$chunk.base.dir"/>
-      </xsl:if>
-      <xsl:value-of select="$htmlhelp.hhk"/>
-    </xsl:with-param>
-    <xsl:with-param name="indent" select="'no'"/>
-    <xsl:with-param name="content"><xsl:text disable-output-escaping="yes">&lt;!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"&gt;
-&lt;HTML&gt;
-&lt;HEAD&gt;
-&lt;meta name="GENERATOR" content="Microsoft&amp;reg; HTML Help Workshop 4.1"&gt;
-&lt;!-- Sitemap 1.0 --&gt;
-&lt;/HEAD&gt;&lt;BODY&gt;
-&lt;OBJECT type="text/site properties"&gt;
-&lt;/OBJECT&gt;
-&lt;UL&gt;
-</xsl:text>
-<xsl:if test="($htmlhelp.use.hhk != 0) and $htmlhelp.generate.index">
-  <xsl:choose>
-    <xsl:when test="$rootid != ''">
-      <xsl:apply-templates select="$profiled-nodes//*[@id=$rootid or @xml:id=$rootid]" mode="hhk"/>
-    </xsl:when>
-    <xsl:otherwise>
-      <xsl:apply-templates select="$profiled-nodes" mode="hhk"/>
-    </xsl:otherwise>
-  </xsl:choose>
-</xsl:if>
-<xsl:text disable-output-escaping="yes">&lt;/UL&gt;
-&lt;/BODY&gt;&lt;/HTML&gt;
-</xsl:text></xsl:with-param>
-    <xsl:with-param name="encoding" select="$htmlhelp.encoding"/>
-    <xsl:with-param name="quiet" select="$chunk.quietly"/>
-  </xsl:call-template>
-</xsl:template>
-
-<xsl:template match="indexterm[@class='endofrange']" mode="hhk"/>
-
-<xsl:template match="indexterm" mode="hhk">
-  <xsl:variable name="primary" select="normalize-space(primary)"/>
-  <xsl:variable name="secondary" select="normalize-space(secondary)"/>
-  <xsl:variable name="tertiary" select="normalize-space(tertiary)"/>
-
-  <xsl:call-template name="write.indexterm.hhk">
-    <xsl:with-param name="text" select="$primary"/>
-    <xsl:with-param name="seealso" select="seealso"/>
-  </xsl:call-template>
-
-  <xsl:if test="secondary">
-    <xsl:if test="not(//indexterm[normalize-space(primary)=$primary and not(secondary)])">
-      <xsl:call-template name="write.indexterm.hhk">
-        <!-- We must create fake entry when there is secondary without primary --> 
-        <xsl:with-param name="text" select="$primary"/>
-        <xsl:with-param name="seealso" select="$primary"/>
-      </xsl:call-template>
-    </xsl:if>
-    <UL>
-    <xsl:call-template name="write.indexterm.hhk">
-      <xsl:with-param name="text" select="$secondary"/>
-      <xsl:with-param name="seealso" select="secondary/seealso"/>
-    </xsl:call-template>
-    <xsl:if test="tertiary">
-      <UL><xsl:text>
-</xsl:text>
-      <xsl:call-template name="write.indexterm.hhk">
-        <xsl:with-param name="text" select="$tertiary"/>
-        <xsl:with-param name="seealso" select="tertiary/seealso"/>
-      </xsl:call-template>
-      </UL>
-    </xsl:if>
-    </UL>
-  </xsl:if>
-
-</xsl:template>
-
-<xsl:template name="write.indexterm.hhk">
-  <xsl:param name="text"/>
-  <xsl:param name="seealso"/>
-
-  <LI> <OBJECT type="text/sitemap"><xsl:text>
-</xsl:text>
-    <param name="Name">
-      <xsl:attribute name="value">
-        <xsl:value-of select="$text"/>
-      </xsl:attribute>
-    </param><xsl:text>
-</xsl:text>
-
-      <xsl:if test="not(seealso)">
-        <xsl:variable name="href">
-          <xsl:call-template name="href.target.with.base.dir"/>
-        </xsl:variable>
-        <xsl:variable name="title">
-          <xsl:call-template name="nearest.title">
-            <xsl:with-param name="object" select=".."/>
-          </xsl:call-template>
-        </xsl:variable>
-
-        <param name="Name">
-          <xsl:attribute name="value">
-          <xsl:value-of select="$title"/>
-          </xsl:attribute>
-        </param><xsl:text>
-</xsl:text>
-        <param name="Local">
-          <xsl:attribute name="value">
-          <xsl:value-of select="$href"/>
-          </xsl:attribute>
-        </param><xsl:text>
-</xsl:text>
-      </xsl:if>
-
-      <xsl:if test="seealso">
-        <param name="See Also">
-          <xsl:attribute name="value">
-          <xsl:value-of select="$seealso"/>
-          </xsl:attribute>
-        </param><xsl:text>
-</xsl:text>
-      </xsl:if>
-      </OBJECT></LI>
-</xsl:template>
-
-<xsl:template match="text()" mode="hhk"/>
-
-<xsl:template name="nearest.title">
-  <xsl:param name="object"/>
-  <xsl:apply-templates select="$object/ancestor-or-self::*[title][1]" mode="title.markup"/>
-</xsl:template>
-
-<!-- ==================================================================== -->
-
-<xsl:template name="hh-map">
-  <xsl:call-template name="write.text.chunk">
-    <xsl:with-param name="filename">
-      <xsl:if test="$manifest.in.base.dir != 0">
-        <xsl:value-of select="$chunk.base.dir"/>
-      </xsl:if>
-      <xsl:value-of select="$htmlhelp.map.file"/>
-    </xsl:with-param>
-    <xsl:with-param name="method" select="'text'"/>
-    <xsl:with-param name="content">
-     <xsl:choose>
-       <xsl:when test="$rootid != ''">
-         <xsl:apply-templates select="$profiled-nodes//*[@id=$rootid or @xml:id=$rootid]" mode="hh-map"/>
-       </xsl:when>
-       <xsl:otherwise>
-         <xsl:apply-templates select="$profiled-nodes" mode="hh-map"/>
-       </xsl:otherwise>
-     </xsl:choose>
-    </xsl:with-param>
-    <xsl:with-param name="encoding" select="$htmlhelp.encoding"/>
-    <xsl:with-param name="quiet" select="$chunk.quietly"/>
-  </xsl:call-template>
-</xsl:template>
-
-<xsl:template match="processing-instruction('dbhh')" mode="hh-map">
-  <xsl:variable name="topicname">
-    <xsl:call-template name="pi-attribute">
-      <xsl:with-param name="pis" select="."/>
-      <xsl:with-param name="attribute" select="'topicname'"/>
-    </xsl:call-template>
-  </xsl:variable>
-  <xsl:variable name="topicid">
-    <xsl:call-template name="pi-attribute">
-      <xsl:with-param name="pis" select="."/>
-      <xsl:with-param name="attribute" select="'topicid'"/>
-    </xsl:call-template>
-  </xsl:variable>
-  <xsl:text>#define </xsl:text>
-  <xsl:value-of select="$topicname"/>
-  <xsl:text>	</xsl:text>
-  <xsl:value-of select="$topicid"/>
-  <xsl:text>
-</xsl:text>
-</xsl:template>
-
-<xsl:template match="text()" mode="hh-map"/>
-
-<!-- ==================================================================== -->
-
-<xsl:template name="hh-alias">
-  <xsl:call-template name="write.text.chunk">
-    <xsl:with-param name="filename">
-      <xsl:if test="$manifest.in.base.dir != 0">
-        <xsl:value-of select="$chunk.base.dir"/>
-      </xsl:if>
-      <xsl:value-of select="$htmlhelp.alias.file"/>
-    </xsl:with-param>
-    <xsl:with-param name="method" select="'text'"/>
-    <xsl:with-param name="content">
-     <xsl:choose>
-       <xsl:when test="$rootid != ''">
-         <xsl:apply-templates select="$profiled-nodes//*[@id=$rootid or @xml:id=$rootid]" mode="hh-alias"/>
-       </xsl:when>
-       <xsl:otherwise>
-         <xsl:apply-templates select="$profiled-nodes" mode="hh-alias"/>
-       </xsl:otherwise>
-     </xsl:choose>
-    </xsl:with-param>
-    <xsl:with-param name="encoding" select="$htmlhelp.encoding"/>
-    <xsl:with-param name="quiet" select="$chunk.quietly"/>
-  </xsl:call-template>
-</xsl:template>
-
-<xsl:template match="processing-instruction('dbhh')" mode="hh-alias">
-  <xsl:variable name="topicname">
-    <xsl:call-template name="pi-attribute">
-      <xsl:with-param name="pis" select="."/>
-      <xsl:with-param name="attribute" select="'topicname'"/>
-    </xsl:call-template>
-  </xsl:variable>
-  <xsl:variable name="href">
-    <xsl:call-template name="href.target.with.base.dir">
-      <xsl:with-param name="object" select=".."/>
-    </xsl:call-template>
-  </xsl:variable>
-  <xsl:value-of select="$topicname"/>
-  <xsl:text>=</xsl:text>
-  <!-- Some versions of HH doesn't like fragment identifires, but some does. -->
-  <!-- <xsl:value-of select="substring-before(concat($href, '#'), '#')"/> -->
-  <xsl:value-of select="$href"/>
-  <xsl:text>
-</xsl:text>
-</xsl:template>
-
-<xsl:template match="text()" mode="hh-alias"/>
-
-<!-- ==================================================================== -->
-<!-- This code can be used to convert any number to hexadecimal format -->
-
-  <h:hex>
-    <d>0</d>
-    <d>1</d>
-    <d>2</d>
-    <d>3</d>
-    <d>4</d>
-    <d>5</d>
-    <d>6</d>
-    <d>7</d>
-    <d>8</d>
-    <d>9</d>
-    <d>A</d>
-    <d>B</d>
-    <d>C</d>
-    <d>D</d>
-    <d>E</d>
-    <d>F</d>
-  </h:hex>
-
-  <xsl:template name="toHex">
-    <xsl:param name="n" select="0"/>
-    <xsl:param name="digit" select="$n mod 16"/>
-    <xsl:param name="rest" select="floor($n div 16)"/>
-    <xsl:if test="$rest &gt; 0">
-      <xsl:call-template name="toHex">
-        <xsl:with-param name="n" select="$rest"/>
-      </xsl:call-template>
-    </xsl:if>
-    <xsl:value-of select="document('')//h:hex/d[$digit+1]"/>
-  </xsl:template>
-
-<!-- ==================================================================== -->
-<!-- Modification to standard HTML stylesheets -->
-
-<!-- There are links from ToC pane to bibliodivs, so there must be anchor -->
-<xsl:template match="bibliodiv/title">
-  <h3 class="{name(.)}">
-    <xsl:call-template name="anchor">
-      <xsl:with-param name="node" select=".."/>
-      <xsl:with-param name="conditional" select="0"/>
-    </xsl:call-template>
-    <xsl:apply-templates/>
-  </h3>
-</xsl:template>
-
-</xsl:stylesheet>

+ 0 - 22
stylesheets/lfs-xsl/docbook-xsl-1.78.1/htmlhelp/profile-htmlhelp.xsl

@@ -1,22 +0,0 @@
-<?xml version="1.0"?>
-<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
-                xmlns:doc="http://nwalsh.com/xsl/documentation/1.0"
-                xmlns:exsl="http://exslt.org/common"
-                xmlns:set="http://exslt.org/sets"
-		version="1.0"
-                exclude-result-prefixes="doc exsl set">
-
-<!-- ********************************************************************
-     $Id: profile-htmlhelp.xsl 1676 2002-06-12 13:21:54Z kosek $
-     ******************************************************************** 
-
-     This file is used by htmlhelp.xsl if you want to generate source
-     files for HTML Help.  It is based on the XSL DocBook Stylesheet
-     distribution (especially on JavaHelp code) from Norman Walsh.
-
-     ******************************************************************** -->
-
-<xsl:import href="../html/chunk.xsl"/>
-<xsl:include href="profile-htmlhelp-common.xsl"/>
-
-</xsl:stylesheet>

BIN
stylesheets/lfs-xsl/docbook-xsl-1.78.1/images/annot-close.png


BIN
stylesheets/lfs-xsl/docbook-xsl-1.78.1/images/annot-open.png


BIN
stylesheets/lfs-xsl/docbook-xsl-1.78.1/images/blank.png


BIN
stylesheets/lfs-xsl/docbook-xsl-1.78.1/images/callouts/1.gif


BIN
stylesheets/lfs-xsl/docbook-xsl-1.78.1/images/callouts/1.png


+ 0 - 15
stylesheets/lfs-xsl/docbook-xsl-1.78.1/images/callouts/1.svg

@@ -1,15 +0,0 @@
-<?xml version="1.0" encoding="utf-8"?>
-<!-- Generator: Adobe Illustrator 12.0.1, SVG Export Plug-In . SVG Version: 6.00 Build 51448)  -->
-<!DOCTYPE svg [
-	<!ENTITY ns_svg "http://www.w3.org/2000/svg">
-	<!ENTITY ns_xlink "http://www.w3.org/1999/xlink">
-]>
-<svg  version="1.0" id="Layer_1" xmlns="&ns_svg;" xmlns:xlink="&ns_xlink;" width="33" height="33" viewBox="0 0 33 33"
-	 style="overflow:visible;enable-background:new 0 0 33 33;" xml:space="preserve">
-<circle style="stroke:#000000;" cx="16.5" cy="16.5" r="16"/>
-<g>
-	<g style="enable-background:new    ;">
-		<path style="fill:#FFFFFF;" d="M10.428,10.411h0.56c3.78,0,4.788-1.96,4.872-3.444h3.22v19.88h-3.92V13.154h-4.732V10.411z"/>
-	</g>
-</g>
-</svg>

BIN
stylesheets/lfs-xsl/docbook-xsl-1.78.1/images/callouts/10.gif


BIN
stylesheets/lfs-xsl/docbook-xsl-1.78.1/images/callouts/10.png


Niektoré súbory nie sú zobrazené, pretože je v týchto rozdielových dátach zmenené mnoho súborov