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