Michael Smith [Sun, 24 Jul 2005 14:10:31 +0000 (14:10 +0000)]
Fixed handling of lists with titles. Also reworked handling of
space around lists. (Closes #1243003 and 1241371).
Among other things, this change "normalizes" line space before and
after verbatims. For most cases, the stylesheet now attempts to
ensure each verbatim is preceded and followed by exactly one line
of space.
Michael Smith [Wed, 13 Jul 2005 17:03:08 +0000 (17:03 +0000)]
Removed unnecessary .LP requests that were being generated after
lists. I don't know why those were there, but they have apparently
been in since the code was first added to the repository.
Michael Smith [Wed, 13 Jul 2005 03:57:50 +0000 (03:57 +0000)]
Prevent hyphenation of computer inlines, filenames, and URLs.
(Closes #1124391; thanks to Ryan Hofschneider for reporting).
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, varname -- but probably need to add more) and for
filenames, and for URLs from Ulink.
It can be (re)enabled using the man.hyphenate.computer.inlines,
man.hyphenate.filenames, and man.hyphenate.urls params.
Michael Smith [Mon, 11 Jul 2005 10:29:58 +0000 (10:29 +0000)]
Implemented out-of-line handling of URLs for links (Ulinks).
(Closes #1234711 and #1233909)
For display of links, this implementation gives users three choices:
1. Number & list links. Each link is numbered and a numbered
list of all links is added to the end of the document.
or
2. Only list links. Links are not numbered, but an (unnumbered)
list of links is added to the end of the document.
or
3. Suppress links. Don't number links and don't add any list of
links to the end of the document
Users can also choose whether links should be underlined.
Default is "the works" -- list, number, and underline links. The
man.links.* parameters can be used to change the defaults.
The default heading for the link list is REFERENCES. That can be
changed using the man.links.list.heading param.
There is a performance hit for listing and numbering links. But it
is not an unreasonable one.
The code currently only checks for Ulinks. It can be updated later
(possibly) to deal with DocBook NG linking. But come to think of
it, DocBook NG links get converted by the strip-ns template. So
DocBook NG users will just need to run that first. Or, if I can
ever manage to get the single-pass conversion process to work with
manpages, it will get done automatically.
Michael Smith [Sun, 10 Jul 2005 16:39:04 +0000 (16:39 +0000)]
Ulink handling -- fixed performance issue (per-Refentry sets of
Ulinks are now assembled once per document and stored in a
global variable).
It now takes roughly on the order of 15 to 20 percent longer to
process a doc with links numbered than it does to process it with
links unnumbered. Which may sound like a lot, but with a doc that
has 100+ links, on my machine, that still amounts to less than a
one-second difference (only about 0.7 seconds).
Bob Stayton [Sun, 10 Jul 2005 08:14:08 +0000 (08:14 +0000)]
Added support for specifying number format for auto labels for
chapter, appendix, part, preface from patch #1234737
to satsify feature request #1178038.
Michael Smith [Sat, 9 Jul 2005 10:07:58 +0000 (10:07 +0000)]
Checkpointing further ulink changes. All visible links are now
displayed in the link list, and numbered. But it performance
leaves something to be desired. And not working properly for case
where document contains multiple Refentry.
Michael Smith [Sat, 9 Jul 2005 09:00:14 +0000 (09:00 +0000)]
Checkpointing. Now link list contains unique URLs (removes dupes),
but needs more work -- some URLs are getting suppressed that
shouldn't be; one symptom of that is that numbering is thrown off.
Michael Smith [Wed, 6 Jul 2005 05:16:18 +0000 (05:16 +0000)]
(internal) Added support for TDG hyperlinking with <tag> (instead
of just <sgmltag>. Also added support for ignoring <tag>s and
<sgmltag>s that have a "namespace" attribute whose value contains
"http://docbook.sf.net/" or "http://docbook.sourceforge.net/"
(that is, those don't get turned into TDG hyperlinks).
(Note: This change has no effect on the behavior of the DocBook XSL
stylesheets; it only affects the build used to create the actual)
DocBook XSL releases.)
Michael Smith [Tue, 5 Jul 2005 09:19:17 +0000 (09:19 +0000)]
Implemented capability for users to customize "refentry metadata
gathering" by specifying XPath expressions to use as "info
profiles" for gathering the data, and, in some cases, to suppress
parts of the data collected.
Michael Smith [Tue, 5 Jul 2005 03:49:25 +0000 (03:49 +0000)]
Added the following substitutions:
<!-- * non-breaking space
<substitution oldstring=" " newstring="\ "/>
<!-- * copyright sign
<substitution oldstring="©" newstring="\(co"/>
<!-- * registered sign
<substitution oldstring="®" newstring="\(rg"/>
<!-- * left double quote
<substitution oldstring="“" newstring="\(lq"/>
<!-- * right double quote
<substitution oldstring="”" newstring="\(rq"/>
<!-- * left single quote
<substitution oldstring="‘" newstring="\(oq"/>
<!-- * right single quote
<substitution oldstring="’" newstring="\(cq"/>
The reason is that those are all characters that the DocBook XSL
stylesheets themselves generate under certain circumstances; so
dealing with them in man.string.subst.map ensures they will always
be replaced, even if man.charmap.enabled is zero.
Michael Smith [Tue, 5 Jul 2005 02:49:13 +0000 (02:49 +0000)]
Did some reorganizing.
- Moved prepare.manpage.contents template out of general.xsl file
and into other.xsl; general.xsl templates are now all templates
that are called multiple times for each refentry, while
templates in other.xsl are called only once per each refentry.
- Removed get.metadata template; refentry metadata gathering is
now done by common/refentry.xsl in a way that is independent of
the final output format; so the common/refentry.xsl templates
can be called not just by manpages stylesheets, but by
stylesheets for any other output format
- Added a write.man.file template. This is basically just a
wrapper around the write.text.chunk template; it takes "name"
and "section" params, assembles those into a filename, then
passes that filename to write.text.chunk