com.nwalsh.saxon6
Class Verbatim

java.lang.Object
  |
  +--com.nwalsh.saxon6.Verbatim

public class Verbatim
extends java.lang.Object

Saxon extensions supporting DocBook verbatim environments

$Id: Verbatim.java,v 1.3 2000/11/28 23:12:52 ndw Exp $

Copyright (C) 2000 Norman Walsh.

This class provides a Saxon implementation of two features that would be impractical to implement directly in XSLT: line numbering and callouts.

Line Numbering

The numberLines method takes a result tree fragment (assumed to contain the contents of a formatted verbatim element in DocBook: programlisting, screen, address, literallayout, or synopsis) and returns a result tree fragment decorated with line numbers.

Callouts

The insertCallouts method takes an areaspec and a result tree fragment (assumed to contain the contents of a formatted verbatim element in DocBook: programlisting, screen, address, literallayout, or synopsis) and returns a result tree fragment decorated with callouts.

Change Log:

1.0

Initial release.


Constructor Summary
Verbatim()
          Constructor for Verbatim
 
Method Summary
static com.icl.saxon.expr.FragmentValue insertCallouts(com.icl.saxon.Context context, com.icl.saxon.expr.NodeSetIntent areaspecNodeSet, com.icl.saxon.expr.FragmentValue rtf)
          Insert text callouts into a verbatim environment.
static com.icl.saxon.expr.FragmentValue numberLines(com.icl.saxon.Context context, com.icl.saxon.expr.FragmentValue rtf)
          Number lines in a verbatim environment
 
Methods inherited from class java.lang.Object
equals, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 

Constructor Detail

Verbatim

public Verbatim()

Constructor for Verbatim

All of the methods are static, so the constructor does nothing.

Method Detail

numberLines

public static com.icl.saxon.expr.FragmentValue numberLines(com.icl.saxon.Context context,
                                                           com.icl.saxon.expr.FragmentValue rtf)

Number lines in a verbatim environment

The extension function expects the following variables to be available in the calling context: $linenumbering.everyNth, $linenumbering.width, $linenumbering.separator, and $stylesheet.result.type.

This method adds line numbers to a result tree fragment. Each newline that occurs in a text node is assumed to start a new line. The first line is always numbered, every subsequent 'everyNth' line is numbered (so if everyNth=5, lines 1, 5, 10, 15, etc. will be numbered. If there are fewer than everyNth lines in the environment, every line is numbered.

Every line number will be right justified in a string 'width' characters long. If the line number of the last line in the environment is too long to fit in the specified width, the width is automatically increased to the smallest value that can hold the number of the last line. (In other words, if you specify the value 2 and attempt to enumerate the lines of an environment that is 100 lines long, the value 3 will automatically be used for every line in the environment.)

The 'separator' string is inserted between the line number and the original program listing. Lines that aren't numbered are preceded by a 'width' blank string and the separator.

If inline markup extends across line breaks, markup changes are required. All the open elements are closed before the line break and "reopened" afterwards. The reopened elements will have the same attributes as the originals, except that 'name' and 'id' attributes are not duplicated if the stylesheet.result.type is "html" and 'id' attributes will not be duplicated if the result type is "fo".

Parameters:
rtf - The result tree fragment of the verbatim environment.
Returns:
The modified result tree fragment.

insertCallouts

public static com.icl.saxon.expr.FragmentValue insertCallouts(com.icl.saxon.Context context,
                                                              com.icl.saxon.expr.NodeSetIntent areaspecNodeSet,
                                                              com.icl.saxon.expr.FragmentValue rtf)

Insert text callouts into a verbatim environment.

This method examines the areaset and area elements in the supplied areaspec and decorates the supplied result tree fragment with appropriate callout markers.

If a label attribute is supplied on an area, its content will be used for the label, otherwise the callout number will be used, surrounded by parenthesis. Callout numbers may also be represented as graphics. Callouts are numbered in document order. All of the areas in an areaset get the same number.

Only the linecolumn and linerange units are supported. If no unit is specifed, linecolumn is assumed. If only a line is specified, the callout decoration appears in the defaultColumn. Lines will be padded with blanks to reach the necessary column, but callouts that are located beyond the last line of the verbatim environment will be ignored.

Callouts are inserted before the character at the line/column where they are to occur.

If graphical callouts are used, and the callout number is less than or equal to the $callout.graphics.number.limit, the following image will be generated for HTML:

 <img src="$callout.graphics.path/999$callout.graphics.ext"
         alt="conumber">
 
If the $stylesheet.result.type is 'fo', the following image will be generated:
 <fo:external-graphic src="$callout.graphics.path/999$callout.graphics.ext"/>
 

If the callout number exceeds $callout.graphics.number.limit, the callout will be the callout number surrounded by parenthesis.

Parameters:
context - The stylesheet context.
areaspecNodeSet - The source node set that contains the areaspec.
rtf - The result tree fragment of the verbatim environment.
Returns:
The modified result tree fragment.