aboutsummaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
-rw-r--r--DOCS/xml/BUGS9
-rw-r--r--DOCS/xml/Makefile76
-rw-r--r--DOCS/xml/Makefile.inc27
-rw-r--r--DOCS/xml/README66
-rw-r--r--DOCS/xml/README.maintainers38
-rw-r--r--DOCS/xml/default.css83
-rw-r--r--DOCS/xml/gen-html.xsl.sh27
-rw-r--r--DOCS/xml/html-common.xsl87
-rw-r--r--DOCS/xml/ldp.dsl365
9 files changed, 778 insertions, 0 deletions
diff --git a/DOCS/xml/BUGS b/DOCS/xml/BUGS
new file mode 100644
index 0000000000..7c53ea6492
--- /dev/null
+++ b/DOCS/xml/BUGS
@@ -0,0 +1,9 @@
+* Can't change output encoding...it's always ISO-8859-1. :-(
+ Should figure out a way to change it...
+
+ <xsl:output encoding="..."/> does not seem to work with xsltproc.
+
+ <xsl:param name="chunker.output.encoding" select="'...'"/> seems not to
+ work either.
+
+ Is it a limitation of xsltproc?
diff --git a/DOCS/xml/Makefile b/DOCS/xml/Makefile
new file mode 100644
index 0000000000..b6b8492552
--- /dev/null
+++ b/DOCS/xml/Makefile
@@ -0,0 +1,76 @@
+# Makefile for generating the HTML documentation
+
+#####[ Configuration ]##################################################
+
+# The xsltproc program.
+XSLTPROC = xsltproc
+
+# The xmllint program.
+XMLLINT = xmllint
+
+# A colon separated list of catalog entry files.
+# Without this properly set up, xmllint and xsltproc might be unable
+# to find the DTDs for the system identifiers specified in the XML files.
+# If the SGML_CATALOG_FILES environment variable is not set, list one
+# or more catalogs here.
+#
+# on debian (potato?) systems, maybe others
+#SGML_CATALOG_FILES ?= /etc/sgml/catalog
+#
+# on Mandrake (9.0?) systems, maybe others
+SGML_CATALOG_FILES ?= /usr/share/sgml/docbook/xml-dtd-4.1.2/xmlcatalog
+#SGML_CATALOG_FILES ?= /usr/share/apps/ksgmltools2/customization/en/catalog
+
+# Full path of the "chunker" DocBook XSL stylesheet used to generate
+# the HTML files.
+#
+# on debian (potato?)
+#CHUNK_XSL = /usr/share/sgml/docbook/stylesheet/xsl/nwalsh/html/chunk.xsl
+#
+# on Mandrake (9.0?) systems, maybe others
+CHUNK_XSL = /usr/share/sgml/docbook/yelp/docbook/html/chunk.xsl
+
+# List of subdirectories to be processed.
+SUBDIRS = en
+
+#####[ End of configuration ]###########################################
+
+export CHUNK_XSL SGML_CATALOG_FILES XMLLINT XSLTPROC
+
+.PHONY: no-target
+no-target:
+ @echo "What to make?"
+ @echo
+ @echo "Targets"
+ @echo "*******"
+ @echo "all : Build everything (same as build-html for now)."
+ @echo "build-html: Build HTML documentation."
+ @echo "clean-html: Purge the 'HTML' directory."
+ @echo "distclean : Remove ALL generated files."
+
+.PHONY: all
+all: build-html
+
+.PHONY: build-html
+build-html:
+ test -d HTML || mkdir HTML
+ for d in $(SUBDIRS); do\
+ test -f $$d/Makefile &&\
+ (test -d HTML/$$d || mkdir HTML/$$d) &&\
+ if $(MAKE) HTMLDIR=../../HTML/$$d -C $$d; then :; else exit 1; fi;\
+ done
+
+.PHONY: test
+test:
+ @if command -v $(XSLTPROC) >/dev/null; then :; else exit 1; fi
+ @if command -v $(XMLLINT) >/dev/null; then :; else exit 1; fi
+ @test -f $(CHUNK_XSL) || (echo "file not found: $(CHUNK_XSL)"; exit 1)
+ @echo "All tests passed."
+
+.PHONY: clean-html
+clean-html:
+ -rm -rf ../HTML
+
+.PHONY: distclean
+distclean: clean-html
+ -rm -f html.xsl
diff --git a/DOCS/xml/Makefile.inc b/DOCS/xml/Makefile.inc
new file mode 100644
index 0000000000..fa25262348
--- /dev/null
+++ b/DOCS/xml/Makefile.inc
@@ -0,0 +1,27 @@
+#
+# Makefile.inc for Makefiles in sub-directories.
+#
+
+export SGML_CATALOG_FILES
+
+# Use customized html.xsl file if exists...
+ifeq (html.xsl,$(wildcard html.xsl))
+HTML_XSL := html.xsl
+XSL_DEPS := $(HTML_XSL) ../html.xsl ../html-common.xsl
+else
+HTML_XSL := ../html.xsl
+XSL_DEPS := $(HTML_XSL) ../html-common.xsl
+endif
+
+# Fall back to the default HTML stylesheet if not specified.
+HTML_STYLESHEET ?= ../default.css
+
+# This is the main target...
+$(HTMLDIR)/index.html: documentation.xml $(XSL_DEPS)
+ -rm -f $(HTMLDIR)/*
+ $(XMLLINT) --noout --noent --postvalid --catalogs $<
+ $(XSLTPROC) --catalogs -o $(HTMLDIR)/ $(HTML_XSL) $<
+ cp $(HTML_STYLESHEET) $(HTMLDIR)/
+
+../html.xsl:
+ sh ../gen-html.xsl.sh $(CHUNK_XSL) > $@
diff --git a/DOCS/xml/README b/DOCS/xml/README
new file mode 100644
index 0000000000..13b53501dc
--- /dev/null
+++ b/DOCS/xml/README
@@ -0,0 +1,66 @@
+Tools required for building the documentation
+~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
+
+* DocBook 4.1.2 or later
+* The DocBook XML DTD (also known as DocBk XML)
+* DocBook XSL stylesheets -- version 1.50.0 or later is recommended.
+
+I am not quite sure which tools work, but I used the following
+ones successfully, so they are required:
+
+* xmllint (part of libxml2) is used for validation.
+* xsltproc (part of libxslt1) is used for transforming XML files into HTML
+ files. Version 1.0.18 or later is recommended.
+
+
+Building the documentation
+~~~~~~~~~~~~~~~~~~~~~~~~~~
+
+1) Before trying to build the documentation, run
+
+ make test
+
+ to see if everything is set up properly. If something goes wrong,
+ check the Configuration section of the toplevel Makefile and adjust
+ the variables.
+
+
+2) Now simply run
+
+ make all
+
+ to build the documentation.
+
+
+A few words about SGML catalog files
+~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
+
+As far as I know, the document type declaration in XML files requires
+both a public and a system identifier. For example:
+
+<!DOCTYPE book PUBLIC "-//OASIS//DTD DocBook XML V4.1.2//EN"
+ "/usr/share/sgml/docbook/dtd/xml/4.1.2/docbookx.dtd">
+
+where
+
+ "-//OASIS//DTD DocBook XML V4.1.2//EN"
+
+is the public, and
+
+ "/usr/share/sgml/docbook/dtd/xml/4.1.2/docbookx.dtd"
+
+is the system identifier.
+
+The problem is that the system identifier is most probably system-dependent.
+To avoid the need to manually fix the system identifiers before building the
+documentation, I've decided to use SGML catalogs. If you have your catalogs
+set up correctly, xmllint and xsltproc will use the them to find the DTDs
+based on the public identifiers.
+
+Note that this works only if public identifiers override system identifiers
+(i.e. the catalog file must contain 'OVERRIDE YES'). (I had no problem with
+these on my system, since the Debian people took care of everything. ;-))
+
+
+--
+Andras Mohari
diff --git a/DOCS/xml/README.maintainers b/DOCS/xml/README.maintainers
new file mode 100644
index 0000000000..56ec979fa2
--- /dev/null
+++ b/DOCS/xml/README.maintainers
@@ -0,0 +1,38 @@
+The documentation and its translations reside in subdirectories.
+When building the documentation, the toplevel Makefile goes into
+the subdirectories listed in the SUBDIRS variable and executes make
+in each of those directories to create the HTML documentation
+in subdirectories of the 'HTML' directory.
+
+IMPORTANT: Do NOT place sensitive files under 'HTML'!
+ It is for generated documentation only.
+ The whole directory tree is wiped out by the Makefile
+ when running 'make distclean' or 'make clean-html'.
+ Also, subdirectories are wiped out one by one before
+ creating the HTML files.
+
+Each subdirectory must have a Makefile. Its purpose is to include
+the toplevel Makefile.inc file (with the rules to build the docs)
+and add dependency information to the main target, $(HTMLDIR)/index.html.
+The main target usually depends on all the XML and XSL files in the
+subdirectory. (Note that the toplevel *.xsl files are added automatically
+by Makefile.inc, so you do not have to list them.)
+
+
+Adding new translations
+~~~~~~~~~~~~~~~~~~~~~~~
+
+1) Create a new subdirectory and copy the XML files there.
+2) Make sure to create a 'Makefile' for the translation -- you can
+ use 'en/Makefile' as an example.
+3) Set <book lang="XX"> to your language code if the DocBook XSL
+ stylesheets support it.
+4) If you want to use a customized XSL stylesheet, create one and name it
+ 'html.xsl'. And do not forget to import the toplevel XSL file:
+
+ <xsl:import href="../html.xsl"/>
+
+5) If you are using you own HTML stylesheet, edit your Makefile and set
+ the HTML_STYLESHEET variable to its name.
+
+That's all, in theory.
diff --git a/DOCS/xml/default.css b/DOCS/xml/default.css
new file mode 100644
index 0000000000..cc30679712
--- /dev/null
+++ b/DOCS/xml/default.css
@@ -0,0 +1,83 @@
+body {
+ color: black;
+ background: white;
+
+ font-family: Arial, Helvetica, sans-serif;
+/*
+ * It's a Bad Idea(tm) to use fixed font sizes.
+ * Uncomment it if you _really_ want
+ */
+ font-size: 14px;
+}
+
+div.table table, div.informaltable table {
+ background: #333366;
+ border-collapse: separate;
+ border: solid 1px #333366;
+ border-spacing: 1px;
+}
+
+div.table th, div.informaltable th {
+ color: white;
+ background: #4488cc;
+ border: 0px;
+ padding: 2px;
+}
+
+div.table td, div.informaltable td {
+ background: #fffff8;
+ border: 0px;
+ padding: 2px;
+}
+
+
+pre.screen {
+ padding: 4px;
+ background: #e0e0e0;
+}
+
+pre.programlisting {
+ padding: 4px;
+ background: #e0e8f0;
+}
+
+/*
+span.application {
+}
+*/
+
+span.keycap {
+ background: #ddd;
+ border: solid 1px #aaa;
+ white-space: nowrap;
+ font-family: Arial, Helvetica, sans-serif;
+}
+
+span.guimenu, span.guisubmenu, span.guimenuitem {
+ background: #dddddd;
+}
+
+tt.filename {
+ color: maroon;
+ white-space: nowrap;
+}
+
+tt.option {
+ color: #066;
+ white-space: nowrap;
+}
+
+div.example {
+ padding-left: 0.5em;
+ border-left: solid 2px black;
+}
+
+div.important .title, div.caution .title, div.warning .title {
+ color: #c00;
+}
+/*
+div.important, div.warning, div.caution {
+ padding-left: 0.5em;
+ border-left: solid 2px maroon;
+}
+*/
diff --git a/DOCS/xml/gen-html.xsl.sh b/DOCS/xml/gen-html.xsl.sh
new file mode 100644
index 0000000000..8e2704959c
--- /dev/null
+++ b/DOCS/xml/gen-html.xsl.sh
@@ -0,0 +1,27 @@
+#
+# Helper script to generate html.xsl.
+#
+
+if test $# -ne 1; then
+ echo "Usage: $0 <path to chunk.xsl>"
+ exit 1
+fi
+
+if test -f "$1"; then :; else
+ echo "$0: file not found: \"$1\""
+ exit 1
+fi
+
+cat << EOF
+<?xml version="1.0" encoding="ISO-8859-1"?>
+<!-- ***************************************************
+ This file is generated automatically. DO NOT EDIT.
+ *************************************************** -->
+<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
+ version="1.0">
+
+ <xsl:import href="$1"/>
+ <xsl:include href="html-common.xsl"/>
+
+</xsl:stylesheet>
+EOF
diff --git a/DOCS/xml/html-common.xsl b/DOCS/xml/html-common.xsl
new file mode 100644
index 0000000000..296416bdaa
--- /dev/null
+++ b/DOCS/xml/html-common.xsl
@@ -0,0 +1,87 @@
+<?xml version="1.0" encoding="ISO-8859-1"?>
+<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
+ version="1.0">
+
+<xsl:output method="html" indent="no"/>
+
+<!-- **************
+ Set parameters
+ ************** -->
+
+ <xsl:param name="toc.section.depth" select="'3'"/>
+
+ <xsl:param name="html.stylesheet" select="'default.css'"/>
+ <xsl:param name="html.stylesheet.type" select="'text/css'"/>
+
+ <xsl:param name="html.cleanup" select="'1'"/>
+ <xsl:param name="make.valid.html" select="'1'"/>
+ <xsl:param name="make.single.year.ranges" select="'1'"/>
+ <xsl:param name="make.year.ranges" select="'1'"/>
+
+ <!-- Use ID value for generated filenames -->
+ <xsl:param name="use.id.as.filename" select="'1'"/>
+
+ <!-- Depth to which sections are chunked -->
+ <xsl:param name="chunk.section.depth" select="'1'"/>
+
+ <!-- Create a chunk for the 1st top-level section too -->
+ <xsl:param name="chunk.first.sections" select="'1'"/>
+
+ <xsl:param name="admon.graphics" select="'0'"/>
+ <xsl:param name="navig.graphics" select="'0'"/>
+ <xsl:param name="navig.showtitles" select="'1'"/>
+
+ <!-- Label sections too (eg. 2.1, 2.1.1) -->
+ <xsl:param name="section.autolabel" select="'1'"/>
+ <xsl:param name="section.label.includes.component.label" select="'1'"/>
+
+ <!-- Use informal procedures; no need to number them -->
+ <xsl:param name="formal.procedures" select="'0'"/>
+
+ <xsl:param name="generate.toc">
+ appendix toc
+ article toc
+ book toc
+ chapter toc
+ part toc
+ preface toc
+ qandadiv toc
+ qandaset toc
+ reference toc
+ section toc
+ set toc
+ </xsl:param>
+
+<!-- *********
+ Templates
+ ********* -->
+
+ <xsl:template match="application">
+ <span class="application"><xsl:apply-templates/></span>
+ </xsl:template>
+
+ <xsl:template match="option">
+ <tt class="option"><xsl:apply-templates/></tt>
+ </xsl:template>
+
+ <xsl:template match="filename">
+ <tt class="filename"><xsl:apply-templates/></tt>
+ </xsl:template>
+
+ <xsl:template match="keycap">
+ <span class="keycap"><b><xsl:apply-templates/></b></span>
+ </xsl:template>
+
+ <xsl:template match="guimenu">
+ <span class="guimenu"><xsl:apply-templates/></span>
+ </xsl:template>
+
+ <xsl:template match="guisubmenu">
+ <span class="guisubmenu"><xsl:apply-templates/></span>
+ </xsl:template>
+
+ <xsl:template match="guimenuitem">
+ <span class="guimenuitem"><xsl:apply-templates/></span>
+ </xsl:template>
+
+</xsl:stylesheet>
diff --git a/DOCS/xml/ldp.dsl b/DOCS/xml/ldp.dsl
new file mode 100644
index 0000000000..d3f5927c4c
--- /dev/null
+++ b/DOCS/xml/ldp.dsl
@@ -0,0 +1,365 @@
+<!DOCTYPE style-sheet PUBLIC
+ "-//James Clark//DTD DSSSL Style Sheet//EN" [
+<!ENTITY % html "IGNORE">
+<![%html;[
+<!ENTITY % print "IGNORE">
+<!ENTITY docbook.dsl PUBLIC
+ "-//Norman Walsh//DOCUMENT DocBook HTML Stylesheet//EN"
+ CDATA dsssl>
+]]>
+<!ENTITY % print "INCLUDE">
+<![%print;[
+<!ENTITY docbook.dsl PUBLIC
+ "-//Norman Walsh//DOCUMENT DocBook Print Stylesheet//EN"
+ CDATA dsssl>
+]]>
+]>
+
+<style-sheet>
+
+;; ------------------------------------------------------------------------
+;; ldp.dsl - LDP Customized DSSSL Stylesheet
+;; v1.11, 2003-02-03
+;; Copyright (C) 2000-2003
+;;
+;; This program is free software; you can redistribute it and/or modify
+;; it under the terms of the GNU General Public License as published by
+;; the Free Software Foundation; either version 2 of the License, or
+;; (at your option) any later version.
+;;
+;; This program is distributed in the hope that it will be useful,
+;; but WITHOUT ANY WARRANTY; without even the implied warranty of
+;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+;; GNU General Public License for more details.
+;;
+;; You should have received a copy of the GNU General Public License
+;; along with this program; if not, write to the Free Software
+;; Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
+;; ------------------------------------------------------------------------
+
+<style-specification id="print" use="docbook">
+<style-specification-body>
+
+;; customize the print stylesheet
+
+(declare-characteristic preserve-sdata?
+ ;; this is necessary because right now jadetex does not understand
+ ;; symbolic entities, whereas things work well with numeric entities.
+ "UNREGISTERED::James Clark//Characteristic::preserve-sdata?"
+ #f)
+
+(define %generate-article-toc%
+ ;; Should a Table of Contents be produced for Articles?
+ #t)
+
+(define (toc-depth nd)
+ 4)
+
+(define %generate-article-titlepage-on-separate-page%
+ ;; Should the article title page be on a separate page?
+ #t)
+
+(define %section-autolabel%
+ ;; Are sections enumerated?
+ #t)
+
+(define %footnote-ulinks%
+ ;; Generate footnotes for ULinks?
+ #f)
+
+(define %bop-footnotes%
+ ;; Make "bottom-of-page" footnotes?
+ #f)
+
+(define %body-start-indent%
+ ;; Default indent of body text
+ 0pi)
+
+(define %para-indent-firstpara%
+ ;; First line start-indent for the first paragraph
+ 0pt)
+
+(define %para-indent%
+ ;; First line start-indent for paragraphs (other than the first)
+ 0pt)
+
+(define %block-start-indent%
+ ;; Extra start-indent for block-elements
+ 0pt)
+
+(define formal-object-float
+ ;; Do formal objects float?
+ #t)
+
+(define %hyphenation%
+ ;; Allow automatic hyphenation?
+ #t)
+
+(define %admon-graphics%
+ ;; Use graphics in admonitions?
+ #f)
+
+(define %default-quadding%
+ ;; Full justification.
+ 'justify)
+
+(define (book-titlepage-verso-elements)
+ ;;added publisher, releaseinfo to the default list
+ (list (normalize "title")
+ (normalize "subtitle")
+ (normalize "corpauthor")
+ (normalize "authorgroup")
+ (normalize "author")
+ (normalize "publisher")
+ (normalize "releaseinfo")
+ (normalize "editor")
+ (normalize "edition")
+ (normalize "pubdate")
+ (normalize "copyright")
+ (normalize "abstract")
+ (normalize "legalnotice")
+ (normalize "revhistory")))
+
+</style-specification-body>
+</style-specification>
+
+
+<!--
+;; customize the html stylesheet; parts borrowed from
+;; Cygnus at http://sourceware.cygnus.com/ (cygnus-both.dsl)
+-->
+
+<style-specification id="html" use="docbook">
+<style-specification-body>
+
+(declare-characteristic preserve-sdata?
+ ;; this is necessary because right now jadetex does not understand
+ ;; symbolic entities, whereas things work well with numeric entities.
+ "UNREGISTERED::James Clark//Characteristic::preserve-sdata?"
+ #f)
+
+(declare-flow-object-class element
+ ;; for redhat
+ "UNREGISTERED::James Clark//Flow Object Class::element")
+
+(define %generate-legalnotice-link%
+ ;; put the legal notice in a separate file
+ #t)
+
+(define %admon-graphics-path%
+ ;; use graphics in admonitions, set their
+ "../images/")
+
+(define %admon-graphics%
+ #t)
+
+(define %funcsynopsis-decoration%
+ ;; make funcsynopsis look pretty
+ #t)
+
+(define %html-ext%
+ ;; when producing HTML files, use this extension
+ ".html")
+
+(define %generate-book-toc%
+ ;; Should a Table of Contents be produced for books?
+ #t)
+
+(define %generate-article-toc%
+ ;; Should a Table of Contents be produced for articles?
+ #t)
+
+(define %generate-part-toc%
+ ;; Should a Table of Contents be produced for parts?
+ #t)
+
+(define %generate-book-titlepage%
+ ;; produce a title page for books
+ #t)
+
+(define %generate-article-titlepage%
+ ;; produce a title page for articles
+ #t)
+
+(define (chunk-skip-first-element-list)
+ ;; forces the Table of Contents on separate page
+ '())
+
+(define (list-element-list)
+ ;; fixes bug in Table of Contents generation
+ '())
+
+(define %root-filename%
+ ;; The filename of the root HTML document (e.g, "index").
+ "index")
+
+(define %shade-verbatim%
+ ;; verbatim sections will be shaded if t(rue)
+ #t)
+
+(define %use-id-as-filename%
+ ;; Use ID attributes as name for component HTML files?
+ #t)
+
+(define %graphic-extensions%
+ ;; graphic extensions allowed
+ '("gif" "png" "jpg" "jpeg" "tif" "tiff" "eps" "epsf" ))
+
+(define %graphic-default-extension%
+ "gif")
+
+(define %section-autolabel%
+ ;; For enumerated sections (1.1, 1.1.1, 1.2, etc.)
+ #t)
+
+(define (toc-depth nd)
+ ;; more depth (2 levels) to toc; instead of flat hierarchy
+ 2)
+
+(element emphasis
+ ;; make role=strong equate to bold for emphasis tag
+ (if (equal? (attribute-string "role") "strong")
+ (make element gi: "STRONG" (process-children))
+ (make element gi: "EM" (process-children))))
+
+(define (book-titlepage-recto-elements)
+ ;; elements on a book's titlepage
+ (list (normalize "title")
+ (normalize "subtitle")
+ (normalize "graphic")
+ (normalize "mediaobject")
+ (normalize "corpauthor")
+ (normalize "authorgroup")
+ (normalize "author")
+ (normalize "othercredit")
+ (normalize "edition")
+ (normalize "releaseinfo")
+ (normalize "publisher")
+ (normalize "editor")
+ (normalize "copyright")
+ (normalize "pubdate")
+ (normalize "revhistory")
+ (normalize "abstract")
+ (normalize "legalnotice")))
+
+(define (article-titlepage-recto-elements)
+ ;; elements on an article's titlepage
+ (list (normalize "title")
+ (normalize "subtitle")
+ (normalize "authorgroup")
+ (normalize "author")
+ (normalize "othercredit")
+ (normalize "releaseinfo")
+ (normalize "copyright")
+ (normalize "pubdate")
+ (normalize "revhistory")
+ (normalize "abstract")
+ (normalize "legalnotice")))
+
+(define (process-contrib #!optional (sosofo (process-children)))
+ ;; print out with othercredit information; for translators, etc.
+ (make sequence
+ (make element gi: "SPAN"
+ attributes: (list (list "CLASS" (gi)))
+ (process-children))))
+
+(define (process-othercredit #!optional (sosofo (process-children)))
+ ;; print out othercredit information; for translators, etc.
+ (let ((author-name (author-string))
+ (author-contrib (select-elements (children (current-node))
+ (normalize "contrib"))))
+ (make element gi: "P"
+ attributes: (list (list "CLASS" (gi)))
+ (make element gi: "B"
+ (literal author-name)
+ (literal " - "))
+ (process-node-list author-contrib))))
+
+(mode article-titlepage-recto-mode
+ (element contrib (process-contrib))
+ (element othercredit (process-othercredit))
+)
+
+(mode book-titlepage-recto-mode
+ (element contrib (process-contrib))
+ (element othercredit (process-othercredit))
+)
+
+(define (article-title nd)
+ (let* ((artchild (children nd))
+ (artheader (select-elements artchild (normalize "artheader")))
+ (artinfo (select-elements artchild (normalize "articleinfo")))
+ (ahdr (if (node-list-empty? artheader)
+ artinfo
+ artheader))
+ (ahtitles (select-elements (children ahdr)
+ (normalize "title")))
+ (artitles (select-elements artchild (normalize "title")))
+ (titles (if (node-list-empty? artitles)
+ ahtitles
+ artitles)))
+ (if (node-list-empty? titles)
+ ""
+ (node-list-first titles))))
+
+(mode subtitle-mode
+ ;; do not print subtitle on subsequent pages
+ (element subtitle (empty-sosofo)))
+
+;; Redefinition of $verbatim-display$
+;; Origin: dbverb.dsl
+;; Different foreground and background colors for verbatim elements
+;; Author: Philippe Martin (feloy@free.fr) 2001-04-07
+
+(define ($verbatim-display$ indent line-numbers?)
+ (let ((verbatim-element (gi))
+ (content (make element gi: "PRE"
+ attributes: (list
+ (list "CLASS" (gi)))
+ (if (or indent line-numbers?)
+ ($verbatim-line-by-line$ indent line-numbers?)
+ (process-children)))))
+ (if %shade-verbatim%
+ (make element gi: "TABLE"
+ attributes: (shade-verbatim-attr-element verbatim-element)
+ (make element gi: "TR"
+ (make element gi: "TD"
+ (make element gi: "FONT"
+ attributes: (list
+ (list "COLOR" (car (shade-verbatim-element-colors
+ verbatim-element))))
+ content))))
+ content)))
+
+;;
+;; Customize this function
+;; to change the foreground and background colors
+;; of the different verbatim elements
+;; Return (list "foreground color" "background color")
+;;
+(define (shade-verbatim-element-colors element)
+ (case element
+ (("SYNOPSIS") (list "#000000" "#6495ED"))
+ ;; ...
+ ;; Add your verbatim elements here
+ ;; ...
+ (else (list "#000000" "#E0E0E0"))))
+
+(define (shade-verbatim-attr-element element)
+ (list
+ (list "BORDER"
+ (cond
+ ((equal? element (normalize "SCREEN")) "1")
+ (else "0")))
+ (list "BGCOLOR" (car (cdr (shade-verbatim-element-colors element))))
+ (list "WIDTH" ($table-width$))))
+
+;; End of $verbatim-display$ redefinition
+
+</style-specification-body>
+</style-specification>
+
+<external-specification id="docbook" document="docbook.dsl">
+
+</style-sheet>
+