You are viewing a plain text version of this content. The canonical link for it is here.
Posted to derby-commits@db.apache.org by fu...@apache.org on 2006/08/31 01:48:35 UTC
svn commit: r438714 - in /db/derby/docs/trunk: build.xml
lib/dita2fo-shell.xsl lib/fo2html.xsl src/pt_BR/build.xml
Author: fuzzylogic
Date: Wed Aug 30 16:48:35 2006
New Revision: 438714
URL: http://svn.apache.org/viewvc?rev=438714&view=rev
Log:
DERBY-502: Fix titles in HTML and HTML Book manuals.
Modified:
db/derby/docs/trunk/build.xml
db/derby/docs/trunk/lib/dita2fo-shell.xsl
db/derby/docs/trunk/lib/fo2html.xsl
db/derby/docs/trunk/src/pt_BR/build.xml
Modified: db/derby/docs/trunk/build.xml
URL: http://svn.apache.org/viewvc/db/derby/docs/trunk/build.xml?rev=438714&r1=438713&r2=438714&view=diff
==============================================================================
--- db/derby/docs/trunk/build.xml (original)
+++ db/derby/docs/trunk/build.xml Wed Aug 30 16:48:35 2006
@@ -66,6 +66,7 @@
<antcall target="html.dita">
<param name="manual.name" value="workingwithderby"/>
<param name="manual.ditamap" value="WorkingWithDerby.ditamap"/>
+ <param name="manual.title" value="Working with Derby"/>
</antcall>
</target>
@@ -73,6 +74,7 @@
<antcall target="html.dita">
<param name="manual.name" value="getstart"/>
<param name="manual.ditamap" value="getstartderby.ditamap"/>
+ <param name="manual.title" value="Getting Started with Derby"/>
</antcall>
</target>
@@ -80,6 +82,7 @@
<antcall target="html.dita">
<param name="manual.name" value="tools"/>
<param name="manual.ditamap" value="derbytools.ditamap"/>
+ <param name="manual.title" value="Derby Tools and Utilities Guide"/>
</antcall>
</target>
@@ -87,6 +90,7 @@
<antcall target="html.dita">
<param name="manual.name" value="adminguide"/>
<param name="manual.ditamap" value="derbyadmin.ditamap"/>
+ <param name="manual.title" value="Derby Server and Administration Guide"/>
</antcall>
</target>
@@ -94,6 +98,7 @@
<antcall target="html.dita">
<param name="manual.name" value="devguide"/>
<param name="manual.ditamap" value="derbydev.ditamap"/>
+ <param name="manual.title" value="Derby Developer's Guide"/>
</antcall>
</target>
@@ -101,6 +106,7 @@
<antcall target="html.dita">
<param name="manual.name" value="ref"/>
<param name="manual.ditamap" value="refderby.ditamap"/>
+ <param name="manual.title" value="Derby Reference Manual"/>
</antcall>
</target>
@@ -108,6 +114,7 @@
<antcall target="html.dita">
<param name="manual.name" value="tuning"/>
<param name="manual.ditamap" value="tuningderby.ditamap"/>
+ <param name="manual.title" value="Tuning Derby"/>
</antcall>
</target>
@@ -119,6 +126,11 @@
<copy todir="${basedir}/out/${manual.name}temp">
<fileset dir="${dita.dir}/resource"
includes="index.html"/>
+ <filterchain>
+ <tokenfilter>
+ <replaceregex pattern="Web Sample" replace="${manual.title}"/>
+ </tokenfilter>
+ </filterchain>
</copy>
<ant dir="${dita.dir}" antfile="conductor.xml" target="dita2xhtml" inheritAll="true">
Modified: db/derby/docs/trunk/lib/dita2fo-shell.xsl
URL: http://svn.apache.org/viewvc/db/derby/docs/trunk/lib/dita2fo-shell.xsl?rev=438714&r1=438713&r2=438714&view=diff
==============================================================================
--- db/derby/docs/trunk/lib/dita2fo-shell.xsl (original)
+++ db/derby/docs/trunk/lib/dita2fo-shell.xsl Wed Aug 30 16:48:35 2006
@@ -146,6 +146,9 @@
<xsl:template name="front-covers">
<!-- generate an "outside front cover" page (right side) (sheet 1) -->
<fo:page-sequence master-reference="cover">
+ <fo:title>
+ <xsl:value-of select="//*[contains(@class,' topic/prodinfo ')]/*[contains(@class,' topic/prodname ')]"/>
+ </fo:title>
<!--Jeff added this here -->
<fo:static-content flow-name="xsl-region-after">
@@ -428,7 +431,7 @@
<fo:basic-link internal-destination="{string(@id)}">
<xsl:value-of select="*/title"/>
<fo:leader leader-pattern="dots"/>
- <fo:page-number-citation ref-id="{generate-id()}"/>
+ <fo:page-number-citation ref-id="{generate-id(@id)}"/>
</fo:basic-link>
</fo:block>
<xsl:call-template name="get-tce5-section"/>
@@ -441,7 +444,7 @@
<fo:basic-link internal-destination="{string(@id)}">
<xsl:value-of select="*/title"/>
<fo:leader leader-pattern="dots"/>
- <fo:page-number-citation ref-id="{generate-id()}"/>
+ <fo:page-number-citation ref-id="{generate-id(@id)}"/>
</fo:basic-link>
</fo:block>
<!--xsl:call-template name="get-tce6-section"/-->
Modified: db/derby/docs/trunk/lib/fo2html.xsl
URL: http://svn.apache.org/viewvc/db/derby/docs/trunk/lib/fo2html.xsl?rev=438714&r1=438713&r2=438714&view=diff
==============================================================================
--- db/derby/docs/trunk/lib/fo2html.xsl (original)
+++ db/derby/docs/trunk/lib/fo2html.xsl Wed Aug 30 16:48:35 2006
@@ -1,784 +1,784 @@
-<?xml version='1.0' encoding='ISO-8859-1'?>
-
-<!-- =============================================================== -->
-<!-- -->
-<!-- Convert XSL FO (as in REC 2001-10-15) to HTML -->
-<!-- -->
-<!-- © RenderX 2000-2001 -->
-<!-- Permission to copy and modify is granted, provided this notice -->
-<!-- is included in all copies and/or derived work. -->
-<!-- -->
-<!-- Author: Nikolai Grigoriev, grig@renderx.com -->
-<!-- -->
-<!-- =============================================================== -->
-
-
-<!DOCTYPE xsl:stylesheet [
- <!ENTITY anchor "<xsl:apply-templates select='@id' xmlns:xsl='http://www.w3.org/1999/XSL/Transform'/>">
- <!ENTITY add-style "<xsl:call-template name='add-style-attribute' xmlns:xsl='http://www.w3.org/1999/XSL/Transform'/>">
-]>
-
-<xsl:stylesheet version="1.0"
- xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
- xmlns:fo="http://www.w3.org/1999/XSL/Format"
- exclude-result-prefixes="fo">
-
-<xsl:output method="html"
- version="4.0"
- encoding="utf-8"
- doctype-public="-//W3C//DTD HTML 4.0 Transitional//EN"
- indent="no"/>
-
-<!-- =============================================================== -->
-<!-- Root. Create the bone and call templates for each page sequence -->
-<!-- =============================================================== -->
-
-<xsl:template match="fo:root">
- <html>
- <head>
- <title>
- <xsl:choose>
- <xsl:when test="descendant::fo:title[1]">
- <xsl:value-of select="fo:title"/>
- </xsl:when>
- <xsl:otherwise>XSL FO Document</xsl:otherwise>
- </xsl:choose>
- </title>
- <META http-equiv="Content-Style-Type" content="text/css"/>
- <style type="text/css">
- a { color: black; border: none; text-decoration: none; }
- img { border: none; }
- </style>
- </head>
-
- <body bgcolor="white" marginwidth="6" marginheight="6" leftmargin="6" topmargin="6">
- <xsl:apply-templates select="fo:page-sequence"/>
- </body>
- </html>
-
-</xsl:template>
-
-<!-- =============================================================== -->
-<!-- fo:page-sequence. Draws a header before and a footer after. -->
-<!-- Sidebars are skipped: there's no way to rotate the text in HTML -->
-<!-- and horizontal text in the sidebars eats up too much space. -->
-<!-- =============================================================== -->
-
-<xsl:template match="fo:page-sequence">
-
- <xsl:variable name="current-master"><xsl:value-of select="@master-reference"/></xsl:variable>
-
- <!-- One page master will be used for the whole page sequence -->
- <xsl:variable name="page-master-name">
- <xsl:choose>
- <xsl:when test="../fo:layout-master-set/fo:simple-page-master[@master-name=$current-master]">
- <!-- specified master is a page master: use it -->
- <xsl:value-of select="$current-master"/>
- </xsl:when>
- <xsl:otherwise>
- <!-- specified master is a page sequence master: -->
- <!-- find master name for the first page -->
- <xsl:apply-templates select="../fo:layout-master-set/fo:page-sequence-master[@master-name=$current-master]"/>
- </xsl:otherwise>
- </xsl:choose>
- </xsl:variable>
-
- <!-- Load the page master into a variable. No problem if it's null; should work the same ;-) -->
- <xsl:variable name="page-master" select="../fo:layout-master-set/fo:simple-page-master[@master-name=$page-master-name]"/>
-
-
- <!-- Start real drawing -->
- <br/> <!-- make an offset before each page sequence -->
-
- <!-- Header -->
- <xsl:variable name="header-region" select="$page-master/fo:region-before"/>
- <xsl:apply-templates select="fo:static-content[@flow-name = $header-region/@region-name
- or (@flow-name='xsl-region-before' and not($header-region/@region-name))]">
- <xsl:with-param name="region" select="$header-region"/>
- </xsl:apply-templates>
-
- <!-- Body -->
- <xsl:apply-templates select="fo:flow">
- <xsl:with-param name="region" select="$page-master/fo:region-body"/>
- </xsl:apply-templates>
-
- <!-- Footer -->
- <xsl:variable name="footer-region" select="$page-master/fo:region-after"/>
- <xsl:apply-templates select="fo:static-content[@flow-name = $footer-region/@region-name
- or (@flow-name='xsl-region-after' and not($footer-region/@region-name))]">
- <xsl:with-param name="region" select="$footer-region"/>
- </xsl:apply-templates>
-
- <br/> <!-- make an offset after each page sequence -->
-
-</xsl:template>
-
-<!-- =============================================================== -->
-<!-- fo:block -->
-<!-- =============================================================== -->
-
-<xsl:template match="fo:block">
- &anchor;<div>&add-style;<xsl:apply-templates mode="check-for-pre"/></div>
-</xsl:template>
-
-<!-- =============================================================== -->
-<!-- fo:inline-sequence -->
-<!-- =============================================================== -->
-
-<xsl:template match="fo:inline | fo:wrapper">
- &anchor;<span>&add-style;<xsl:apply-templates/></span>
-</xsl:template>
-
-<!-- =============================================================== -->
-<!-- fo:list-block -->
-<!-- =============================================================== -->
-
-<xsl:template match="fo:list-block">
- <xsl:variable name="label-separation">
- <xsl:choose>
- <xsl:when test="@provisional-label-separation">
- <xsl:apply-templates select="@provisional-label-separation"
- mode="convert-to-pixels"/>
- </xsl:when>
- <xsl:otherwise>8</xsl:otherwise>
- </xsl:choose>
- </xsl:variable>
-
- <xsl:variable name="body-offset">
- <xsl:choose>
- <xsl:when test="@provisional-distance-between-starts">
- <xsl:apply-templates select="@provisional-distance-between-starts"
- mode="convert-to-pixels"/>
- </xsl:when>
- <xsl:otherwise>32</xsl:otherwise>
- </xsl:choose>
- </xsl:variable>
-
- <div>&add-style;
- &anchor;
- <table width="100%">
- <xsl:apply-templates select="fo:list-item | fo:list-item-label">
- <xsl:with-param name="label-width"
- select="$body-offset - $label-separation"/>
- <xsl:with-param name="gap-width"
- select="$label-separation"/>
- </xsl:apply-templates>
- </table>
- </div>
-
-</xsl:template>
-
-<!-- =============================================================== -->
-<!-- fo:list-item -->
-<!-- =============================================================== -->
-
-<xsl:template match="fo:list-item">
- <xsl:param name="label-width"/>
- <xsl:param name="gap-width"/>
-
- <tr>&add-style;
- <xsl:apply-templates select="fo:list-item-label" mode="draw-cell">
- <xsl:with-param name="width" select="$label-width"/>
- </xsl:apply-templates>
- <xsl:if test="$gap-width > 0">
- <td width="{$gap-width}"> </td>
- </xsl:if>
-
- <xsl:apply-templates select="fo:list-item-body" mode="draw-cell"/>
- </tr>
-</xsl:template>
-
-<!-- =============================================================== -->
-<!-- fo:list-item-label - itemless lists -->
-<!-- =============================================================== -->
-
-<xsl:template match="fo:list-block/fo:list-item-label">
- <xsl:param name="label-width"/>
- <xsl:param name="gap-width"/>
-
- <tr>
- <xsl:apply-templates select="." mode="draw-cell">
- <xsl:with-param name="width" select="$label-width"/>
- </xsl:apply-templates>
- <xsl:if test="$gap-width > 0">
- <td width="{$gap-width}"> </td>
- </xsl:if>
-
- <xsl:apply-templates select="following-sibling::fo:list-item-body[1]" mode="draw-cell"/>
- </tr>
-</xsl:template>
-
-
-<!-- =============================================================== -->
-<!-- fo:list-item-body - itemless lists -->
-<!-- =============================================================== -->
-
-<xsl:template match="fo:list-item-label | fo:list-item-body" mode="draw-cell">
- <xsl:param name="width" select="'auto'"/>
- <td valign="top">&add-style;&anchor;
- <xsl:if test="$width != 'auto'">
- <xsl:attribute name="width">
- <xsl:value-of select="$width"/>
- </xsl:attribute>
- </xsl:if>
-
- <xsl:apply-templates mode="check-for-pre"/>
- </td>
-</xsl:template>
-
-
-<!-- =============================================================== -->
-<!-- fo:table and its components -->
-<!-- =============================================================== -->
-
-<xsl:template match="fo:table">
- &anchor;
- <table>&add-style;
- <xsl:if test="not(@display-align)">
- <xsl:attribute name="valign">top</xsl:attribute>
- </xsl:if>
-
- <xsl:apply-templates/>
- </table>
-</xsl:template>
-
-<xsl:template match="fo:table-header">
- <thead>&add-style;
- <xsl:apply-templates/>
- </thead>
-</xsl:template>
-
-<xsl:template match="fo:table-footer">
- <tfoot>&add-style;
- <xsl:apply-templates/>
- </tfoot>
-</xsl:template>
-
-<xsl:template match="fo:table-body">
- <tbody>&add-style;
- <xsl:apply-templates/>
- </tbody>
-</xsl:template>
-
-<xsl:template match="fo:table-row">
- <tr>&add-style;
- <xsl:apply-templates mode="display"/>
- </tr>
-</xsl:template>
-
-<xsl:template match="fo:table-cell" mode="display">
- <td>&add-style;
- <xsl:if test="not(@display-align)">
- <xsl:attribute name="valign">top</xsl:attribute>
- </xsl:if>
- <xsl:apply-templates select="@*" mode="get-table-attributes"/>
- <xsl:apply-templates mode="check-for-pre"/>
- </td>
-</xsl:template>
-
-<xsl:template match="fo:table-cell" priority="-1"/>
-
-<!-- This template accounts for "rowless" tables -->
-<xsl:template priority="1"
- match="fo:table-cell[not(parent::fo:table-row)]
- [not(preceding-sibling::fo:table-cell) or @starts-row='true'
- or preceding-sibling::fo:table-cell[1][@ends-row='true']]">
- <tr>
- <xsl:call-template name="enumerate-rowless-cells"/>
- </tr>
-</xsl:template>
-
-<xsl:template name="enumerate-rowless-cells">
- <xsl:apply-templates select="." mode="display"/>
- <xsl:if test="not(@ends-row='true')">
- <xsl:for-each select="following-sibling::fo:table-cell[1]
- [not(@starts-row='true')]">
- <xsl:call-template name="enumerate-rowless-cells"/>
- </xsl:for-each>
- </xsl:if>
-</xsl:template>
-
-
-<!-- =============================================================== -->
-<!-- fo:inline-graphic -->
-<!-- =============================================================== -->
-
-<xsl:template match="fo:external-graphic">
- <xsl:variable name="cleaned-url">
- <xsl:apply-templates select="@src" mode="unbracket-url"/>
- </xsl:variable>
- &anchor;<img src="{$cleaned-url}"><xsl:apply-templates select="@height|@width|@*[starts-with(name(),'border')]"/></img>
-</xsl:template>
-
-<!-- =============================================================== -->
-<!-- fo:basic-link -->
-<!-- =============================================================== -->
-
-<xsl:template match="fo:basic-link[@external-destination]">
-
- <xsl:variable name="cleaned-url">
- <xsl:apply-templates select="@external-destination" mode="unbracket-url"/>
- </xsl:variable>
-
- &anchor;<a href="{$cleaned-url}">&add-style;<xsl:apply-templates/></a>
-</xsl:template>
-
-<xsl:template match="fo:basic-link[@internal-destination]">
-
- <xsl:variable name="citation-id" select="fo:page-number-citation/@ref-id"/>
-
- &anchor;<a href="#{$citation-id}">&add-style;<xsl:apply-templates/></a>
-</xsl:template>
-
-
-<!-- =============================================================== -->
-<!-- fo:marker/fo:retrieve-marker -->
-<!-- =============================================================== -->
-
-<xsl:template match="fo:marker"/>
-<xsl:template match="fo:marker" mode="retrieve-marker">
- <xsl:apply-templates/>
-</xsl:template>
-
-<xsl:template match="fo:retrieve-marker">
-
- <xsl:variable name="class-name" select="@retrieve-class-name"/>
- <xsl:variable name="matching-markers"
- select="ancestor::fo:page-sequence/descendant::fo:marker[@marker-class-name=$class-name]"/>
-
- <xsl:choose>
- <xsl:when test="@retrieve-position='last-starting-within-page'
- or @retrieve-position='last-ending-within-page'">
- <xsl:apply-templates select="$matching-markers[position()=last()]" mode="retrieve-marker"/>
- </xsl:when>
- <xsl:otherwise>
- <xsl:apply-templates select="$matching-markers[1]" mode="retrieve-marker"/>
- </xsl:otherwise>
- </xsl:choose>
-
-</xsl:template>
-
-
-
-
-
-<!-- *************************************************************** -->
-<!-- Treatment of attributes that are either identical to their CSS1 -->
-<!-- counterparts, of find an equivalent expression there -->
-
-<!-- =============================================================== -->
-<!-- Default rule: copy CSS1 attributes and suppress all other -->
-<!-- =============================================================== -->
-
-<xsl:template match="@*" priority="-2" mode="collect-style-attributes"/>
-
-<xsl:template match="@color |
- @background |
- @background-color |
- @background-image |
- @background-position |
- @background-repeat |
- @padding |
- @padding-top |
- @padding-bottom |
- @padding-right |
- @padding-left |
- @margin |
- @margin-top |
- @margin-bottom |
- @margin-right |
- @margin-left |
- @border |
- @border-top |
- @border-bottom |
- @border-right |
- @border-left |
- @border-width |
- @border-top-width |
- @border-bottom-width |
- @border-right-width |
- @border-left-width |
- @border-color |
- @border-top-color |
- @border-bottom-color |
- @border-right-color |
- @border-left-color |
- @border-style |
- @border-top-style |
- @border-bottom-style |
- @border-right-style |
- @border-left-style |
- @letter-spacing |
- @word-spacing |
- @line-height |
- @font |
- @font-family |
- @font-size |
- @font-weight |
- @font-style |
- @font-variant |
- @vertical-align |
- @text-decoration |
- @text-indent |
- @text-transform"
- mode="collect-style-attributes">
- <xsl:value-of select="name()"/>
- <xsl:text>: </xsl:text>
- <xsl:value-of select="."/>
- <xsl:text>; </xsl:text>
-</xsl:template>
-
-<!-- =============================================================== -->
-<!-- Some attributes deserve special treatment -->
-
-<xsl:template match="@text-align" mode="collect-style-attributes">
- <xsl:text>text-align: </xsl:text>
- <xsl:choose>
- <xsl:when test=".='start' or .='inside'">left</xsl:when>
- <xsl:when test=".='end' or .='outside'">right</xsl:when>
- <xsl:otherwise><xsl:value-of select="."/></xsl:otherwise>
- </xsl:choose>
- <xsl:text>; </xsl:text>
-</xsl:template>
-
-<!-- =============================================================== -->
-<!-- Handling writing-mode in borders, padding, and margins -->
-<!-- This version presumes lr-tb writing mode only. -->
-
-<xsl:template match="@space-before.optimum |
- @space-before [not (../@space-before.optimum)] |
- @space-before.minimum [not (../@space-before.optimum) and not (../@space-before)] |
- @space-before.maximum [not (../@space-before.optimum) and not (../@space-before) and not (../@space-before.minimum)] |
- @space-after.optimum |
- @space-after [not (../@space-after.optimum)] |
- @space-after.minimum [not (../@space-after.optimum) and not (../@space-after)] |
- @space-after.maximum [not (../@space-after.optimum) and not (../@space-after) and not (../@space-after.minimum)] |
- @space-start.optimum |
- @space-start [not (../@space-start.optimum)] |
- @space-start.minimum [not (../@space-start.optimum) and not (../@space-start)] |
- @space-start.maximum [not (../@space-start.optimum) and not (../@space-start) and not (../@space-start.minimum)] |
- @space-end.optimum |
- @space-end [not (../@space-end.optimum)] |
- @space-end.minimum [not (../@space-end.optimum) and not (../@space-end)] |
- @space-end.maximum [not (../@space-end.optimum) and not (../@space-end) and not (../@space-end.minimum)] |
- @start-indent[not(parent::fo:list-item-body)] |
- @end-indent[not(parent::fo:list-item-label)] |
- @padding-before |
- @padding-before.length |
- @margin-before |
- @border-before |
- @border-before-width |
- @border-before-width.length |
- @border-before-color |
- @border-before-style |
- @padding-after |
- @padding-after.length |
- @margin-after |
- @border-after |
- @border-after-width |
- @border-after-width.length |
- @border-after-color |
- @border-after-style |
- @padding-start |
- @padding-start.length |
- @margin-start |
- @border-start |
- @border-start-width |
- @border-start-width.length |
- @border-start-color |
- @border-start-style |
- @padding-end |
- @padding-end.length |
- @margin-end |
- @border-end |
- @border-end-width |
- @border-end-width.length |
- @border-end-color |
- @border-end-style"
- mode="collect-style-attributes">
-
- <xsl:variable name="property">
- <xsl:choose>
- <xsl:when test="starts-with(name(), 'border')">border</xsl:when>
- <xsl:when test="starts-with(name(), 'padding')">padding</xsl:when>
- <xsl:when test="starts-with(name(), 'margin')">margin</xsl:when>
- <xsl:when test="starts-with(name(), 'space')">margin</xsl:when>
- <xsl:when test="contains(name(), '-indent')">margin</xsl:when>
- </xsl:choose>
- </xsl:variable>
-
- <xsl:variable name="side">
- <xsl:choose>
- <xsl:when test="contains(name(), '-before') or contains(name(), '-top')">-top</xsl:when>
- <xsl:when test="contains(name(), '-after') or contains(name(), '-bottom')">-bottom</xsl:when>
- <xsl:when test="contains(name(), '-start') or starts-with(name(), 'start-') or contains(name(), '-left')">-left</xsl:when>
- <xsl:when test="contains(name(), '-end') or starts-with(name(), 'end-') or contains(name(), '-right')">-right</xsl:when>
- </xsl:choose>
- </xsl:variable>
-
- <xsl:variable name="parameter">
- <xsl:choose>
- <xsl:when test="contains(name(), '-width')">-width</xsl:when>
- <xsl:when test="contains(name(), '-color')">-color</xsl:when>
- <xsl:when test="contains(name(), '-style')">-style</xsl:when>
- </xsl:choose>
- </xsl:variable>
-
- <xsl:value-of select="concat($property, $side, $parameter)"/>
- <xsl:text>: </xsl:text>
- <xsl:value-of select="."/>
- <xsl:text>; </xsl:text>
-</xsl:template>
-
-<xsl:template match="*" mode="check-for-pre" priority="-1">
- <xsl:apply-templates select="."/>
-</xsl:template>
-
-<xsl:template match="*[@white-space-collapse='false'
- or @linefeed-treatment='preserve'
- or @wrap-option='no-wrap'
- or @white-space='pre']"
- mode="check-for-pre">
- <pre><xsl:apply-templates select="."/></pre>
-</xsl:template>
-
-<!-- =============================================================== -->
-<!-- Recalculate a length to pixels. 1 in = 96 px, 1 em = 1 pc; -->
-<!-- this gives reasonable results for 800x600 and 1024x768 screens -->
-<!-- =============================================================== -->
-
-<xsl:template match="@*" mode="convert-to-pixels">
- <xsl:variable name="scaling-factor">
- <xsl:choose>
- <xsl:when test="contains (., 'pt')">1.33</xsl:when>
- <xsl:when test="contains (., 'px')">1</xsl:when>
- <xsl:when test="contains (., 'pc')">16</xsl:when>
- <xsl:when test="contains (., 'in')">96</xsl:when>
- <xsl:when test="contains (., 'cm')">37.8</xsl:when>
- <xsl:when test="contains (., 'mm')">3.78</xsl:when>
- <xsl:when test="contains (., 'em')">16</xsl:when> <!-- guess: 1em = 12pt -->
- <xsl:otherwise>1</xsl:otherwise>
- </xsl:choose>
- </xsl:variable>
-
- <xsl:variable name="numeric-value"
- select="translate (., '-0123456789.ptxcinme', '-0123456789.')"/>
- <xsl:value-of select="$numeric-value * $scaling-factor"/>
-</xsl:template>
-
-<!-- =============================================================== -->
-<!-- Remove brackets & quotes around URLs -->
-<!-- =============================================================== -->
-
-<xsl:template match="@*" mode="unbracket-url">
- <xsl:variable name="href" select="normalize-space(.)"/>
-
- <xsl:choose>
- <xsl:when test="(starts-with($href, 'url(') or starts-with($href, 'url ('))
- and substring ($href, string-length($href)) = ')'">
- <!-- Remove 'url' from the beginning -->
- <xsl:variable name="bracketed"
- select="normalize-space(substring($href, 4))"/>
- <!-- Remove brackets -->
- <xsl:variable name="quoted"
- select="normalize-space(substring($bracketed, 2, string-length ($bracketed) - 2 ))"/>
-
- <xsl:variable name="q" select="'"'"/>
- <xsl:variable name="a" select='"'"'/>
- <!-- Remove optional quotes -->
- <xsl:choose>
- <xsl:when test="( substring($quoted, 1, 1) = $q and
- substring($quoted, string-length($quoted), 1) = $q )
- or ( substring($quoted, 1, 1) = $a and
- substring($quoted, string-length($quoted), 1) = $a )">
- <xsl:value-of select="substring($quoted, 2, string-length($quoted) - 2)"/>
- </xsl:when>
- <xsl:otherwise><xsl:value-of select="$quoted"/></xsl:otherwise>
- </xsl:choose>
- </xsl:when>
- <xsl:otherwise><xsl:value-of select="."/></xsl:otherwise>
- </xsl:choose>
-</xsl:template>
-
-<!-- =============================================================== -->
-<!-- Page number - replace by a bullet -->
-<!-- =============================================================== -->
-
-<xsl:template match="fo:page-number | fo:page-number-citation">
- <span>&add-style;<xsl:text>•</xsl:text></span>
-</xsl:template>
-
-<!-- =============================================================== -->
-<!-- Leader - replace by a space -->
-<!-- =============================================================== -->
-
-<xsl:template match="fo:leader">
- <xsl:text>     </xsl:text>
-</xsl:template>
-
-
-
-<!-- =============================================================== -->
-<!-- Static content - add a <hr/> before or after it -->
-<!-- =============================================================== -->
-
-<xsl:template match="fo:flow | fo:static-content">
- <xsl:param name="region"/>
-
- <div>&add-style;&anchor;
- <xsl:apply-templates select="$region"/>
- <xsl:apply-templates/>
- <xsl:if test=".//fo:footnote">
- <br/><hr/>
- <xsl:apply-templates select=".//fo:footnote" mode="after-text"/>
- </xsl:if>
- </div>
-</xsl:template>
-
-<!-- =============================================================== -->
-<!-- Footnotes -->
-<!-- =============================================================== -->
-
-<xsl:template match="fo:footnote">
- <xsl:apply-templates select="fo:inline"/>
-</xsl:template>
-
-<xsl:template match="fo:footnote" mode="after-text">
- <div>&add-style;&anchor;
- <xsl:apply-templates select="fo:footnote-body"/>
- </div>
-</xsl:template>
-
-<!-- =============================================================== -->
-<!-- Copy all CSS1-compatible attributes to "style" property -->
-<!-- =============================================================== -->
-
-<xsl:template name="add-style-attribute">
- <xsl:param name="orientation" select="0"/>
- <xsl:variable name="style">
- <xsl:apply-templates select="@*" mode="collect-style-attributes"/>
- </xsl:variable>
-
- <xsl:if test="string-length($style) > 0">
- <xsl:attribute name="style"><xsl:value-of select="normalize-space($style)"/></xsl:attribute>
- </xsl:if>
-</xsl:template>
-
-<!-- =============================================================== -->
-<!-- Create an anchor -->
-<!-- =============================================================== -->
-
-<xsl:template match="@id"><a name="{.}"/></xsl:template>
-
-<!-- =============================================================== -->
-<!-- Table cell geometry -->
-<!-- =============================================================== -->
-
-<xsl:template match="@*" mode="get-table-attributes" priority="-1"/>
-
-<xsl:template match="@number-columns-spanned"
- mode="get-table-attributes">
- <xsl:attribute name="colspan"><xsl:value-of select="."/></xsl:attribute>
-</xsl:template>
-
-<xsl:template match="@number-rows-spanned"
- mode="get-table-attributes">
- <xsl:attribute name="rowspan"><xsl:value-of select="."/></xsl:attribute>
-</xsl:template>
-
-
-
-<!-- =============================================================== -->
-<!-- Page layout: determine master name for the first page -->
-<!-- =============================================================== -->
-
-<xsl:template match="fo:page-sequence-master">
- <xsl:apply-templates select="*[1]"/>
-</xsl:template>
-
-<xsl:template match="fo:single-page-master-reference
- | fo:repeatable-page-master-reference">
- <xsl:value-of select="@master-reference"/>
-</xsl:template>
-
-<xsl:template match="fo:repeatable-page-master-alternatives">
- <xsl:choose>
- <xsl:when test="fo:conditional-page-master-reference[@page-position='first']">
- <xsl:value-of select="fo:conditional-page-master-reference[@page-position='first'][1]/@master-reference"/>
- </xsl:when>
- <xsl:when test="fo:conditional-page-master-reference[@odd-or-even='odd' and not (@blank-or-not-blank='blank')]">
- <xsl:value-of select="fo:conditional-page-master-reference[@odd-or-even='odd' and not (@blank-or-not-blank='blank')][1]/@master-reference"/>
- </xsl:when>
- <xsl:when test="fo:conditional-page-master-reference[not(@odd-or-even='even') and not (@blank-or-not-blank='blank')]">
- <xsl:value-of select="fo:conditional-page-master-reference[not(@odd-or-even='even') and not (@blank-or-not-blank='blank')][1]/@master-reference"/>
- </xsl:when>
- <xsl:otherwise> <!-- cannot guess; take the first -->
- <xsl:value-of select="fo:conditional-page-master-reference[1]/@master-reference"/>
- </xsl:otherwise>
- </xsl:choose>
-</xsl:template>
-
-
-<!-- =============================================================== -->
-<!-- Header/footer properties -->
-<!-- =============================================================== -->
-
-
-<xsl:template match="@extent">
- <xsl:attribute name="width"><xsl:apply-templates select="." mode="convert-to-pixels"/></xsl:attribute>
-</xsl:template>
-
-<xsl:template match="@width | @height">
- <xsl:attribute name="{name()}"><xsl:apply-templates select="." mode="convert-to-pixels"/></xsl:attribute>
-</xsl:template>
-
-<xsl:template match="fo:region-before | fo:region-after">
- <xsl:call-template name="get-area-attributes"/>
-
- <!-- For header and footer, we suppress margins and padding -->
- <xsl:variable name="style">
- <xsl:apply-templates
- select="@*[not (starts-with (name(), 'margin')
- or starts-with (name(), 'space')
- or starts-with (name(), 'padding'))]"
- mode="collect-style-attributes">
- <xsl:with-param name="orientation" select="@reference-orientation"/>
- </xsl:apply-templates>
- </xsl:variable>
-
- <xsl:if test="string-length($style) > 0">
- <xsl:attribute name="style"><xsl:value-of select="normalize-space($style)"/></xsl:attribute>
- </xsl:if>
-
-</xsl:template>
-
-<xsl:template match="fo:region-body">
- <xsl:call-template name="get-area-attributes"/>
-
- <!-- For region-body, we suppress margin attributes -->
- <xsl:variable name="style">
- <xsl:apply-templates
- select="@*[not (starts-with (name(), 'margin')
- or starts-with (name(), 'space'))]"
- mode="collect-style-attributes">
- <xsl:with-param name="orientation" select="@reference-orientation"/>
- </xsl:apply-templates>
- </xsl:variable>
-
- <xsl:if test="string-length($style) > 0">
- <xsl:attribute name="style"><xsl:value-of select="normalize-space($style)"/></xsl:attribute>
- </xsl:if>
-</xsl:template>
-
-<xsl:template match="fo:region-start | fo:region-end"/>
-
-<xsl:template name="get-area-attributes">
- <xsl:attribute name="valign">
- <xsl:choose>
- <xsl:when test="@display-align"><xsl:value-of select="@display-align"/></xsl:when>
- <xsl:otherwise>top</xsl:otherwise>
- </xsl:choose>
- </xsl:attribute>
-</xsl:template>
-
-</xsl:stylesheet>
+<?xml version='1.0' encoding='ISO-8859-1'?>
+
+<!-- =============================================================== -->
+<!-- -->
+<!-- Convert XSL FO (as in REC 2001-10-15) to HTML -->
+<!-- -->
+<!-- © RenderX 2000-2001 -->
+<!-- Permission to copy and modify is granted, provided this notice -->
+<!-- is included in all copies and/or derived work. -->
+<!-- -->
+<!-- Author: Nikolai Grigoriev, grig@renderx.com -->
+<!-- -->
+<!-- =============================================================== -->
+
+
+<!DOCTYPE xsl:stylesheet [
+ <!ENTITY anchor "<xsl:apply-templates select='@id' xmlns:xsl='http://www.w3.org/1999/XSL/Transform'/>">
+ <!ENTITY add-style "<xsl:call-template name='add-style-attribute' xmlns:xsl='http://www.w3.org/1999/XSL/Transform'/>">
+]>
+
+<xsl:stylesheet version="1.0"
+ xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
+ xmlns:fo="http://www.w3.org/1999/XSL/Format"
+ exclude-result-prefixes="fo">
+
+<xsl:output method="html"
+ version="4.0"
+ encoding="utf-8"
+ doctype-public="-//W3C//DTD HTML 4.0 Transitional//EN"
+ indent="no"/>
+
+<!-- =============================================================== -->
+<!-- Root. Create the bone and call templates for each page sequence -->
+<!-- =============================================================== -->
+
+<xsl:template match="fo:root">
+ <html>
+ <head>
+ <title>
+ <xsl:choose>
+ <xsl:when test="descendant::fo:title[1]">
+ <xsl:value-of select="descendant::fo:title[1]"/>
+ </xsl:when>
+ <xsl:otherwise>XSL FO Document</xsl:otherwise>
+ </xsl:choose>
+ </title>
+ <META http-equiv="Content-Style-Type" content="text/css"/>
+ <style type="text/css">
+ a { color: black; border: none; text-decoration: none; }
+ img { border: none; }
+ </style>
+ </head>
+
+ <body bgcolor="white" marginwidth="6" marginheight="6" leftmargin="6" topmargin="6">
+ <xsl:apply-templates select="fo:page-sequence"/>
+ </body>
+ </html>
+
+</xsl:template>
+
+<!-- =============================================================== -->
+<!-- fo:page-sequence. Draws a header before and a footer after. -->
+<!-- Sidebars are skipped: there's no way to rotate the text in HTML -->
+<!-- and horizontal text in the sidebars eats up too much space. -->
+<!-- =============================================================== -->
+
+<xsl:template match="fo:page-sequence">
+
+ <xsl:variable name="current-master"><xsl:value-of select="@master-reference"/></xsl:variable>
+
+ <!-- One page master will be used for the whole page sequence -->
+ <xsl:variable name="page-master-name">
+ <xsl:choose>
+ <xsl:when test="../fo:layout-master-set/fo:simple-page-master[@master-name=$current-master]">
+ <!-- specified master is a page master: use it -->
+ <xsl:value-of select="$current-master"/>
+ </xsl:when>
+ <xsl:otherwise>
+ <!-- specified master is a page sequence master: -->
+ <!-- find master name for the first page -->
+ <xsl:apply-templates select="../fo:layout-master-set/fo:page-sequence-master[@master-name=$current-master]"/>
+ </xsl:otherwise>
+ </xsl:choose>
+ </xsl:variable>
+
+ <!-- Load the page master into a variable. No problem if it's null; should work the same ;-) -->
+ <xsl:variable name="page-master" select="../fo:layout-master-set/fo:simple-page-master[@master-name=$page-master-name]"/>
+
+
+ <!-- Start real drawing -->
+ <br/> <!-- make an offset before each page sequence -->
+
+ <!-- Header -->
+ <xsl:variable name="header-region" select="$page-master/fo:region-before"/>
+ <xsl:apply-templates select="fo:static-content[@flow-name = $header-region/@region-name
+ or (@flow-name='xsl-region-before' and not($header-region/@region-name))]">
+ <xsl:with-param name="region" select="$header-region"/>
+ </xsl:apply-templates>
+
+ <!-- Body -->
+ <xsl:apply-templates select="fo:flow">
+ <xsl:with-param name="region" select="$page-master/fo:region-body"/>
+ </xsl:apply-templates>
+
+ <!-- Footer -->
+ <xsl:variable name="footer-region" select="$page-master/fo:region-after"/>
+ <xsl:apply-templates select="fo:static-content[@flow-name = $footer-region/@region-name
+ or (@flow-name='xsl-region-after' and not($footer-region/@region-name))]">
+ <xsl:with-param name="region" select="$footer-region"/>
+ </xsl:apply-templates>
+
+ <br/> <!-- make an offset after each page sequence -->
+
+</xsl:template>
+
+<!-- =============================================================== -->
+<!-- fo:block -->
+<!-- =============================================================== -->
+
+<xsl:template match="fo:block">
+ &anchor;<div>&add-style;<xsl:apply-templates mode="check-for-pre"/></div>
+</xsl:template>
+
+<!-- =============================================================== -->
+<!-- fo:inline-sequence -->
+<!-- =============================================================== -->
+
+<xsl:template match="fo:inline | fo:wrapper">
+ &anchor;<span>&add-style;<xsl:apply-templates/></span>
+</xsl:template>
+
+<!-- =============================================================== -->
+<!-- fo:list-block -->
+<!-- =============================================================== -->
+
+<xsl:template match="fo:list-block">
+ <xsl:variable name="label-separation">
+ <xsl:choose>
+ <xsl:when test="@provisional-label-separation">
+ <xsl:apply-templates select="@provisional-label-separation"
+ mode="convert-to-pixels"/>
+ </xsl:when>
+ <xsl:otherwise>8</xsl:otherwise>
+ </xsl:choose>
+ </xsl:variable>
+
+ <xsl:variable name="body-offset">
+ <xsl:choose>
+ <xsl:when test="@provisional-distance-between-starts">
+ <xsl:apply-templates select="@provisional-distance-between-starts"
+ mode="convert-to-pixels"/>
+ </xsl:when>
+ <xsl:otherwise>32</xsl:otherwise>
+ </xsl:choose>
+ </xsl:variable>
+
+ <div>&add-style;
+ &anchor;
+ <table width="100%">
+ <xsl:apply-templates select="fo:list-item | fo:list-item-label">
+ <xsl:with-param name="label-width"
+ select="$body-offset - $label-separation"/>
+ <xsl:with-param name="gap-width"
+ select="$label-separation"/>
+ </xsl:apply-templates>
+ </table>
+ </div>
+
+</xsl:template>
+
+<!-- =============================================================== -->
+<!-- fo:list-item -->
+<!-- =============================================================== -->
+
+<xsl:template match="fo:list-item">
+ <xsl:param name="label-width"/>
+ <xsl:param name="gap-width"/>
+
+ <tr>&add-style;
+ <xsl:apply-templates select="fo:list-item-label" mode="draw-cell">
+ <xsl:with-param name="width" select="$label-width"/>
+ </xsl:apply-templates>
+ <xsl:if test="$gap-width > 0">
+ <td width="{$gap-width}"> </td>
+ </xsl:if>
+
+ <xsl:apply-templates select="fo:list-item-body" mode="draw-cell"/>
+ </tr>
+</xsl:template>
+
+<!-- =============================================================== -->
+<!-- fo:list-item-label - itemless lists -->
+<!-- =============================================================== -->
+
+<xsl:template match="fo:list-block/fo:list-item-label">
+ <xsl:param name="label-width"/>
+ <xsl:param name="gap-width"/>
+
+ <tr>
+ <xsl:apply-templates select="." mode="draw-cell">
+ <xsl:with-param name="width" select="$label-width"/>
+ </xsl:apply-templates>
+ <xsl:if test="$gap-width > 0">
+ <td width="{$gap-width}"> </td>
+ </xsl:if>
+
+ <xsl:apply-templates select="following-sibling::fo:list-item-body[1]" mode="draw-cell"/>
+ </tr>
+</xsl:template>
+
+
+<!-- =============================================================== -->
+<!-- fo:list-item-body - itemless lists -->
+<!-- =============================================================== -->
+
+<xsl:template match="fo:list-item-label | fo:list-item-body" mode="draw-cell">
+ <xsl:param name="width" select="'auto'"/>
+ <td valign="top">&add-style;&anchor;
+ <xsl:if test="$width != 'auto'">
+ <xsl:attribute name="width">
+ <xsl:value-of select="$width"/>
+ </xsl:attribute>
+ </xsl:if>
+
+ <xsl:apply-templates mode="check-for-pre"/>
+ </td>
+</xsl:template>
+
+
+<!-- =============================================================== -->
+<!-- fo:table and its components -->
+<!-- =============================================================== -->
+
+<xsl:template match="fo:table">
+ &anchor;
+ <table>&add-style;
+ <xsl:if test="not(@display-align)">
+ <xsl:attribute name="valign">top</xsl:attribute>
+ </xsl:if>
+
+ <xsl:apply-templates/>
+ </table>
+</xsl:template>
+
+<xsl:template match="fo:table-header">
+ <thead>&add-style;
+ <xsl:apply-templates/>
+ </thead>
+</xsl:template>
+
+<xsl:template match="fo:table-footer">
+ <tfoot>&add-style;
+ <xsl:apply-templates/>
+ </tfoot>
+</xsl:template>
+
+<xsl:template match="fo:table-body">
+ <tbody>&add-style;
+ <xsl:apply-templates/>
+ </tbody>
+</xsl:template>
+
+<xsl:template match="fo:table-row">
+ <tr>&add-style;
+ <xsl:apply-templates mode="display"/>
+ </tr>
+</xsl:template>
+
+<xsl:template match="fo:table-cell" mode="display">
+ <td>&add-style;
+ <xsl:if test="not(@display-align)">
+ <xsl:attribute name="valign">top</xsl:attribute>
+ </xsl:if>
+ <xsl:apply-templates select="@*" mode="get-table-attributes"/>
+ <xsl:apply-templates mode="check-for-pre"/>
+ </td>
+</xsl:template>
+
+<xsl:template match="fo:table-cell" priority="-1"/>
+
+<!-- This template accounts for "rowless" tables -->
+<xsl:template priority="1"
+ match="fo:table-cell[not(parent::fo:table-row)]
+ [not(preceding-sibling::fo:table-cell) or @starts-row='true'
+ or preceding-sibling::fo:table-cell[1][@ends-row='true']]">
+ <tr>
+ <xsl:call-template name="enumerate-rowless-cells"/>
+ </tr>
+</xsl:template>
+
+<xsl:template name="enumerate-rowless-cells">
+ <xsl:apply-templates select="." mode="display"/>
+ <xsl:if test="not(@ends-row='true')">
+ <xsl:for-each select="following-sibling::fo:table-cell[1]
+ [not(@starts-row='true')]">
+ <xsl:call-template name="enumerate-rowless-cells"/>
+ </xsl:for-each>
+ </xsl:if>
+</xsl:template>
+
+
+<!-- =============================================================== -->
+<!-- fo:inline-graphic -->
+<!-- =============================================================== -->
+
+<xsl:template match="fo:external-graphic">
+ <xsl:variable name="cleaned-url">
+ <xsl:apply-templates select="@src" mode="unbracket-url"/>
+ </xsl:variable>
+ &anchor;<img src="{$cleaned-url}"><xsl:apply-templates select="@height|@width|@*[starts-with(name(),'border')]"/></img>
+</xsl:template>
+
+<!-- =============================================================== -->
+<!-- fo:basic-link -->
+<!-- =============================================================== -->
+
+<xsl:template match="fo:basic-link[@external-destination]">
+
+ <xsl:variable name="cleaned-url">
+ <xsl:apply-templates select="@external-destination" mode="unbracket-url"/>
+ </xsl:variable>
+
+ &anchor;<a href="{$cleaned-url}">&add-style;<xsl:apply-templates/></a>
+</xsl:template>
+
+<xsl:template match="fo:basic-link[@internal-destination]">
+
+ <xsl:variable name="citation-id" select="fo:page-number-citation/@ref-id"/>
+
+ &anchor;<a href="#{$citation-id}">&add-style;<xsl:apply-templates/></a>
+</xsl:template>
+
+
+<!-- =============================================================== -->
+<!-- fo:marker/fo:retrieve-marker -->
+<!-- =============================================================== -->
+
+<xsl:template match="fo:marker"/>
+<xsl:template match="fo:marker" mode="retrieve-marker">
+ <xsl:apply-templates/>
+</xsl:template>
+
+<xsl:template match="fo:retrieve-marker">
+
+ <xsl:variable name="class-name" select="@retrieve-class-name"/>
+ <xsl:variable name="matching-markers"
+ select="ancestor::fo:page-sequence/descendant::fo:marker[@marker-class-name=$class-name]"/>
+
+ <xsl:choose>
+ <xsl:when test="@retrieve-position='last-starting-within-page'
+ or @retrieve-position='last-ending-within-page'">
+ <xsl:apply-templates select="$matching-markers[position()=last()]" mode="retrieve-marker"/>
+ </xsl:when>
+ <xsl:otherwise>
+ <xsl:apply-templates select="$matching-markers[1]" mode="retrieve-marker"/>
+ </xsl:otherwise>
+ </xsl:choose>
+
+</xsl:template>
+
+
+
+
+
+<!-- *************************************************************** -->
+<!-- Treatment of attributes that are either identical to their CSS1 -->
+<!-- counterparts, of find an equivalent expression there -->
+
+<!-- =============================================================== -->
+<!-- Default rule: copy CSS1 attributes and suppress all other -->
+<!-- =============================================================== -->
+
+<xsl:template match="@*" priority="-2" mode="collect-style-attributes"/>
+
+<xsl:template match="@color |
+ @background |
+ @background-color |
+ @background-image |
+ @background-position |
+ @background-repeat |
+ @padding |
+ @padding-top |
+ @padding-bottom |
+ @padding-right |
+ @padding-left |
+ @margin |
+ @margin-top |
+ @margin-bottom |
+ @margin-right |
+ @margin-left |
+ @border |
+ @border-top |
+ @border-bottom |
+ @border-right |
+ @border-left |
+ @border-width |
+ @border-top-width |
+ @border-bottom-width |
+ @border-right-width |
+ @border-left-width |
+ @border-color |
+ @border-top-color |
+ @border-bottom-color |
+ @border-right-color |
+ @border-left-color |
+ @border-style |
+ @border-top-style |
+ @border-bottom-style |
+ @border-right-style |
+ @border-left-style |
+ @letter-spacing |
+ @word-spacing |
+ @line-height |
+ @font |
+ @font-family |
+ @font-size |
+ @font-weight |
+ @font-style |
+ @font-variant |
+ @vertical-align |
+ @text-decoration |
+ @text-indent |
+ @text-transform"
+ mode="collect-style-attributes">
+ <xsl:value-of select="name()"/>
+ <xsl:text>: </xsl:text>
+ <xsl:value-of select="."/>
+ <xsl:text>; </xsl:text>
+</xsl:template>
+
+<!-- =============================================================== -->
+<!-- Some attributes deserve special treatment -->
+
+<xsl:template match="@text-align" mode="collect-style-attributes">
+ <xsl:text>text-align: </xsl:text>
+ <xsl:choose>
+ <xsl:when test=".='start' or .='inside'">left</xsl:when>
+ <xsl:when test=".='end' or .='outside'">right</xsl:when>
+ <xsl:otherwise><xsl:value-of select="."/></xsl:otherwise>
+ </xsl:choose>
+ <xsl:text>; </xsl:text>
+</xsl:template>
+
+<!-- =============================================================== -->
+<!-- Handling writing-mode in borders, padding, and margins -->
+<!-- This version presumes lr-tb writing mode only. -->
+
+<xsl:template match="@space-before.optimum |
+ @space-before [not (../@space-before.optimum)] |
+ @space-before.minimum [not (../@space-before.optimum) and not (../@space-before)] |
+ @space-before.maximum [not (../@space-before.optimum) and not (../@space-before) and not (../@space-before.minimum)] |
+ @space-after.optimum |
+ @space-after [not (../@space-after.optimum)] |
+ @space-after.minimum [not (../@space-after.optimum) and not (../@space-after)] |
+ @space-after.maximum [not (../@space-after.optimum) and not (../@space-after) and not (../@space-after.minimum)] |
+ @space-start.optimum |
+ @space-start [not (../@space-start.optimum)] |
+ @space-start.minimum [not (../@space-start.optimum) and not (../@space-start)] |
+ @space-start.maximum [not (../@space-start.optimum) and not (../@space-start) and not (../@space-start.minimum)] |
+ @space-end.optimum |
+ @space-end [not (../@space-end.optimum)] |
+ @space-end.minimum [not (../@space-end.optimum) and not (../@space-end)] |
+ @space-end.maximum [not (../@space-end.optimum) and not (../@space-end) and not (../@space-end.minimum)] |
+ @start-indent[not(parent::fo:list-item-body)] |
+ @end-indent[not(parent::fo:list-item-label)] |
+ @padding-before |
+ @padding-before.length |
+ @margin-before |
+ @border-before |
+ @border-before-width |
+ @border-before-width.length |
+ @border-before-color |
+ @border-before-style |
+ @padding-after |
+ @padding-after.length |
+ @margin-after |
+ @border-after |
+ @border-after-width |
+ @border-after-width.length |
+ @border-after-color |
+ @border-after-style |
+ @padding-start |
+ @padding-start.length |
+ @margin-start |
+ @border-start |
+ @border-start-width |
+ @border-start-width.length |
+ @border-start-color |
+ @border-start-style |
+ @padding-end |
+ @padding-end.length |
+ @margin-end |
+ @border-end |
+ @border-end-width |
+ @border-end-width.length |
+ @border-end-color |
+ @border-end-style"
+ mode="collect-style-attributes">
+
+ <xsl:variable name="property">
+ <xsl:choose>
+ <xsl:when test="starts-with(name(), 'border')">border</xsl:when>
+ <xsl:when test="starts-with(name(), 'padding')">padding</xsl:when>
+ <xsl:when test="starts-with(name(), 'margin')">margin</xsl:when>
+ <xsl:when test="starts-with(name(), 'space')">margin</xsl:when>
+ <xsl:when test="contains(name(), '-indent')">margin</xsl:when>
+ </xsl:choose>
+ </xsl:variable>
+
+ <xsl:variable name="side">
+ <xsl:choose>
+ <xsl:when test="contains(name(), '-before') or contains(name(), '-top')">-top</xsl:when>
+ <xsl:when test="contains(name(), '-after') or contains(name(), '-bottom')">-bottom</xsl:when>
+ <xsl:when test="contains(name(), '-start') or starts-with(name(), 'start-') or contains(name(), '-left')">-left</xsl:when>
+ <xsl:when test="contains(name(), '-end') or starts-with(name(), 'end-') or contains(name(), '-right')">-right</xsl:when>
+ </xsl:choose>
+ </xsl:variable>
+
+ <xsl:variable name="parameter">
+ <xsl:choose>
+ <xsl:when test="contains(name(), '-width')">-width</xsl:when>
+ <xsl:when test="contains(name(), '-color')">-color</xsl:when>
+ <xsl:when test="contains(name(), '-style')">-style</xsl:when>
+ </xsl:choose>
+ </xsl:variable>
+
+ <xsl:value-of select="concat($property, $side, $parameter)"/>
+ <xsl:text>: </xsl:text>
+ <xsl:value-of select="."/>
+ <xsl:text>; </xsl:text>
+</xsl:template>
+
+<xsl:template match="*" mode="check-for-pre" priority="-1">
+ <xsl:apply-templates select="."/>
+</xsl:template>
+
+<xsl:template match="*[@white-space-collapse='false'
+ or @linefeed-treatment='preserve'
+ or @wrap-option='no-wrap'
+ or @white-space='pre']"
+ mode="check-for-pre">
+ <pre><xsl:apply-templates select="."/></pre>
+</xsl:template>
+
+<!-- =============================================================== -->
+<!-- Recalculate a length to pixels. 1 in = 96 px, 1 em = 1 pc; -->
+<!-- this gives reasonable results for 800x600 and 1024x768 screens -->
+<!-- =============================================================== -->
+
+<xsl:template match="@*" mode="convert-to-pixels">
+ <xsl:variable name="scaling-factor">
+ <xsl:choose>
+ <xsl:when test="contains (., 'pt')">1.33</xsl:when>
+ <xsl:when test="contains (., 'px')">1</xsl:when>
+ <xsl:when test="contains (., 'pc')">16</xsl:when>
+ <xsl:when test="contains (., 'in')">96</xsl:when>
+ <xsl:when test="contains (., 'cm')">37.8</xsl:when>
+ <xsl:when test="contains (., 'mm')">3.78</xsl:when>
+ <xsl:when test="contains (., 'em')">16</xsl:when> <!-- guess: 1em = 12pt -->
+ <xsl:otherwise>1</xsl:otherwise>
+ </xsl:choose>
+ </xsl:variable>
+
+ <xsl:variable name="numeric-value"
+ select="translate (., '-0123456789.ptxcinme', '-0123456789.')"/>
+ <xsl:value-of select="$numeric-value * $scaling-factor"/>
+</xsl:template>
+
+<!-- =============================================================== -->
+<!-- Remove brackets & quotes around URLs -->
+<!-- =============================================================== -->
+
+<xsl:template match="@*" mode="unbracket-url">
+ <xsl:variable name="href" select="normalize-space(.)"/>
+
+ <xsl:choose>
+ <xsl:when test="(starts-with($href, 'url(') or starts-with($href, 'url ('))
+ and substring ($href, string-length($href)) = ')'">
+ <!-- Remove 'url' from the beginning -->
+ <xsl:variable name="bracketed"
+ select="normalize-space(substring($href, 4))"/>
+ <!-- Remove brackets -->
+ <xsl:variable name="quoted"
+ select="normalize-space(substring($bracketed, 2, string-length ($bracketed) - 2 ))"/>
+
+ <xsl:variable name="q" select="'"'"/>
+ <xsl:variable name="a" select='"'"'/>
+ <!-- Remove optional quotes -->
+ <xsl:choose>
+ <xsl:when test="( substring($quoted, 1, 1) = $q and
+ substring($quoted, string-length($quoted), 1) = $q )
+ or ( substring($quoted, 1, 1) = $a and
+ substring($quoted, string-length($quoted), 1) = $a )">
+ <xsl:value-of select="substring($quoted, 2, string-length($quoted) - 2)"/>
+ </xsl:when>
+ <xsl:otherwise><xsl:value-of select="$quoted"/></xsl:otherwise>
+ </xsl:choose>
+ </xsl:when>
+ <xsl:otherwise><xsl:value-of select="."/></xsl:otherwise>
+ </xsl:choose>
+</xsl:template>
+
+<!-- =============================================================== -->
+<!-- Page number - replace by a bullet -->
+<!-- =============================================================== -->
+
+<xsl:template match="fo:page-number | fo:page-number-citation">
+ <span>&add-style;<xsl:text>•</xsl:text></span>
+</xsl:template>
+
+<!-- =============================================================== -->
+<!-- Leader - replace by a space -->
+<!-- =============================================================== -->
+
+<xsl:template match="fo:leader">
+ <xsl:text>     </xsl:text>
+</xsl:template>
+
+
+
+<!-- =============================================================== -->
+<!-- Static content - add a <hr/> before or after it -->
+<!-- =============================================================== -->
+
+<xsl:template match="fo:flow | fo:static-content">
+ <xsl:param name="region"/>
+
+ <div>&add-style;&anchor;
+ <xsl:apply-templates select="$region"/>
+ <xsl:apply-templates/>
+ <xsl:if test=".//fo:footnote">
+ <br/><hr/>
+ <xsl:apply-templates select=".//fo:footnote" mode="after-text"/>
+ </xsl:if>
+ </div>
+</xsl:template>
+
+<!-- =============================================================== -->
+<!-- Footnotes -->
+<!-- =============================================================== -->
+
+<xsl:template match="fo:footnote">
+ <xsl:apply-templates select="fo:inline"/>
+</xsl:template>
+
+<xsl:template match="fo:footnote" mode="after-text">
+ <div>&add-style;&anchor;
+ <xsl:apply-templates select="fo:footnote-body"/>
+ </div>
+</xsl:template>
+
+<!-- =============================================================== -->
+<!-- Copy all CSS1-compatible attributes to "style" property -->
+<!-- =============================================================== -->
+
+<xsl:template name="add-style-attribute">
+ <xsl:param name="orientation" select="0"/>
+ <xsl:variable name="style">
+ <xsl:apply-templates select="@*" mode="collect-style-attributes"/>
+ </xsl:variable>
+
+ <xsl:if test="string-length($style) > 0">
+ <xsl:attribute name="style"><xsl:value-of select="normalize-space($style)"/></xsl:attribute>
+ </xsl:if>
+</xsl:template>
+
+<!-- =============================================================== -->
+<!-- Create an anchor -->
+<!-- =============================================================== -->
+
+<xsl:template match="@id"><a name="{.}"/></xsl:template>
+
+<!-- =============================================================== -->
+<!-- Table cell geometry -->
+<!-- =============================================================== -->
+
+<xsl:template match="@*" mode="get-table-attributes" priority="-1"/>
+
+<xsl:template match="@number-columns-spanned"
+ mode="get-table-attributes">
+ <xsl:attribute name="colspan"><xsl:value-of select="."/></xsl:attribute>
+</xsl:template>
+
+<xsl:template match="@number-rows-spanned"
+ mode="get-table-attributes">
+ <xsl:attribute name="rowspan"><xsl:value-of select="."/></xsl:attribute>
+</xsl:template>
+
+
+
+<!-- =============================================================== -->
+<!-- Page layout: determine master name for the first page -->
+<!-- =============================================================== -->
+
+<xsl:template match="fo:page-sequence-master">
+ <xsl:apply-templates select="*[1]"/>
+</xsl:template>
+
+<xsl:template match="fo:single-page-master-reference
+ | fo:repeatable-page-master-reference">
+ <xsl:value-of select="@master-reference"/>
+</xsl:template>
+
+<xsl:template match="fo:repeatable-page-master-alternatives">
+ <xsl:choose>
+ <xsl:when test="fo:conditional-page-master-reference[@page-position='first']">
+ <xsl:value-of select="fo:conditional-page-master-reference[@page-position='first'][1]/@master-reference"/>
+ </xsl:when>
+ <xsl:when test="fo:conditional-page-master-reference[@odd-or-even='odd' and not (@blank-or-not-blank='blank')]">
+ <xsl:value-of select="fo:conditional-page-master-reference[@odd-or-even='odd' and not (@blank-or-not-blank='blank')][1]/@master-reference"/>
+ </xsl:when>
+ <xsl:when test="fo:conditional-page-master-reference[not(@odd-or-even='even') and not (@blank-or-not-blank='blank')]">
+ <xsl:value-of select="fo:conditional-page-master-reference[not(@odd-or-even='even') and not (@blank-or-not-blank='blank')][1]/@master-reference"/>
+ </xsl:when>
+ <xsl:otherwise> <!-- cannot guess; take the first -->
+ <xsl:value-of select="fo:conditional-page-master-reference[1]/@master-reference"/>
+ </xsl:otherwise>
+ </xsl:choose>
+</xsl:template>
+
+
+<!-- =============================================================== -->
+<!-- Header/footer properties -->
+<!-- =============================================================== -->
+
+
+<xsl:template match="@extent">
+ <xsl:attribute name="width"><xsl:apply-templates select="." mode="convert-to-pixels"/></xsl:attribute>
+</xsl:template>
+
+<xsl:template match="@width | @height">
+ <xsl:attribute name="{name()}"><xsl:apply-templates select="." mode="convert-to-pixels"/></xsl:attribute>
+</xsl:template>
+
+<xsl:template match="fo:region-before | fo:region-after">
+ <xsl:call-template name="get-area-attributes"/>
+
+ <!-- For header and footer, we suppress margins and padding -->
+ <xsl:variable name="style">
+ <xsl:apply-templates
+ select="@*[not (starts-with (name(), 'margin')
+ or starts-with (name(), 'space')
+ or starts-with (name(), 'padding'))]"
+ mode="collect-style-attributes">
+ <xsl:with-param name="orientation" select="@reference-orientation"/>
+ </xsl:apply-templates>
+ </xsl:variable>
+
+ <xsl:if test="string-length($style) > 0">
+ <xsl:attribute name="style"><xsl:value-of select="normalize-space($style)"/></xsl:attribute>
+ </xsl:if>
+
+</xsl:template>
+
+<xsl:template match="fo:region-body">
+ <xsl:call-template name="get-area-attributes"/>
+
+ <!-- For region-body, we suppress margin attributes -->
+ <xsl:variable name="style">
+ <xsl:apply-templates
+ select="@*[not (starts-with (name(), 'margin')
+ or starts-with (name(), 'space'))]"
+ mode="collect-style-attributes">
+ <xsl:with-param name="orientation" select="@reference-orientation"/>
+ </xsl:apply-templates>
+ </xsl:variable>
+
+ <xsl:if test="string-length($style) > 0">
+ <xsl:attribute name="style"><xsl:value-of select="normalize-space($style)"/></xsl:attribute>
+ </xsl:if>
+</xsl:template>
+
+<xsl:template match="fo:region-start | fo:region-end"/>
+
+<xsl:template name="get-area-attributes">
+ <xsl:attribute name="valign">
+ <xsl:choose>
+ <xsl:when test="@display-align"><xsl:value-of select="@display-align"/></xsl:when>
+ <xsl:otherwise>top</xsl:otherwise>
+ </xsl:choose>
+ </xsl:attribute>
+</xsl:template>
+
+</xsl:stylesheet>
Modified: db/derby/docs/trunk/src/pt_BR/build.xml
URL: http://svn.apache.org/viewvc/db/derby/docs/trunk/src/pt_BR/build.xml?rev=438714&r1=438713&r2=438714&view=diff
==============================================================================
--- db/derby/docs/trunk/src/pt_BR/build.xml (original)
+++ db/derby/docs/trunk/src/pt_BR/build.xml Wed Aug 30 16:48:35 2006
@@ -27,10 +27,17 @@
<echo message="For output in all formats, run "ant pt_BR""/>
</target>
+ <target name="pt_BR.adminguide">
+ <antcall target="pt_BR.adminguide.html"/>
+ <antcall target="pt_BR.adminguide.monohtml"/>
+ </target>
+
+
<target name="pt_BR.adminguide.html">
<ant dir="../.." target="html.dita">
<property name="manual.name" value="pt_BR/adminguide"/>
<property name="manual.ditamap" value="derbyadmin.ditamap"/>
+ <property name="manual.title" value="Derby"/>
</ant>
</target>
@@ -50,7 +57,6 @@
<target name="pt_BR.getstart">
<antcall target="pt_BR.getstart.html"/>
- <antcall target="pt_BR.getstart.pdf"/>
<antcall target="pt_BR.getstart.monohtml"/>
</target>
@@ -58,6 +64,7 @@
<ant dir="../.." target="html.dita">
<property name="manual.name" value="pt_BR/getstart"/>
<property name="manual.ditamap" value="getstartderby.ditamap"/>
+ <property name="manual.title" value="Derby"/>
</ant>
</target>
@@ -77,7 +84,6 @@
<target name="pt_BR.ref">
<antcall target="pt_BR.ref.html"/>
- <antcall target="pt_BR.ref.pdf"/>
<antcall target="pt_BR.ref.monohtml"/>
</target>
@@ -85,6 +91,7 @@
<ant dir="../.." target="html.dita">
<property name="manual.name" value="pt_BR/ref"/>
<property name="manual.ditamap" value="refderby.ditamap"/>
+ <property name="manual.title" value="Derby"/>
</ant>
</target>