diff options
Diffstat (limited to 'src/engine/SCons/Tool/docbook/docbook-xsl-1.76.1/slides/keynote/xsltsl/node.xsl')
-rw-r--r-- | src/engine/SCons/Tool/docbook/docbook-xsl-1.76.1/slides/keynote/xsltsl/node.xsl | 229 |
1 files changed, 229 insertions, 0 deletions
diff --git a/src/engine/SCons/Tool/docbook/docbook-xsl-1.76.1/slides/keynote/xsltsl/node.xsl b/src/engine/SCons/Tool/docbook/docbook-xsl-1.76.1/slides/keynote/xsltsl/node.xsl new file mode 100644 index 0000000..bf4fd7f --- /dev/null +++ b/src/engine/SCons/Tool/docbook/docbook-xsl-1.76.1/slides/keynote/xsltsl/node.xsl @@ -0,0 +1,229 @@ +<?xml version="1.0"?> + +<xsl:stylesheet version="1.0" + xmlns:xsl="http://www.w3.org/1999/XSL/Transform" + xmlns:doc="http://xsltsl.org/xsl/documentation/1.0" + xmlns:node="http://xsltsl.org/node" + extension-element-prefixes="doc node"> + + <doc:reference xmlns=""> + <referenceinfo> + <releaseinfo role="meta"> + $Id: node.xsl 3991 2004-11-10 06:51:55Z balls $ + </releaseinfo> + <author> + <surname>Ball</surname> + <firstname>Steve</firstname> + </author> + <copyright> + <year>2001</year> + <holder>Steve Ball</holder> + </copyright> + </referenceinfo> + + <title>Node Templates</title> + + <partintro> + <section> + <title>Introduction</title> + + <para>This stylesheet module provides functions for reporting on or manipulating nodes and nodesets.</para> + + </section> + </partintro> + + </doc:reference> + + <doc:template name="node:xpath" xmlns=""> + <refpurpose>Returns an XPath location path</refpurpose> + + <refdescription> + <para>This template returns an XPath location path that uniquely identifies the given node within the document.</para> + </refdescription> + + <refparameter> + <variablelist> + <varlistentry> + <term>node</term> + <listitem> + <para>The node to create an XPath for. If this parameter is given as a nodeset, then the first node in the nodeset is used.</para> + </listitem> + </varlistentry> + </variablelist> + </refparameter> + + <refreturn> + <para>Returns an XPath location path as a string.</para> + </refreturn> + </doc:template> + + <xsl:template name="node:xpath"> + <xsl:param name="node" select="."/> + + <xsl:choose> + + <xsl:when test="$node"> + + <xsl:for-each select="$node[1]/ancestor-or-self::*"> + <xsl:text/>/<xsl:value-of select="name()"/> + <xsl:text/>[<xsl:value-of select="count(preceding-sibling::*[name() = name(current())]) + 1"/>]<xsl:text/> + </xsl:for-each> + + <xsl:choose> + + <xsl:when test="$node[1]/self::comment()"> + <xsl:text>/comment()</xsl:text> + <xsl:text/>[<xsl:value-of select="count($node[1]/preceding-sibling::comment()) + 1" />]<xsl:text/> + </xsl:when> + + <xsl:when test="$node[1]/self::processing-instruction()"> + <xsl:text>/processing-instruction()</xsl:text> + <xsl:text/>[<xsl:value-of select="count($node[1]/preceding-sibling::processing-instruction()) + 1" />]<xsl:text/> + </xsl:when> + + <xsl:when test="$node[1]/self::text()"> + <xsl:text>/text()</xsl:text> + <xsl:text/>[<xsl:value-of select="count($node[1]/preceding-sibling::text()) + 1" />]<xsl:text/> + </xsl:when> + + <xsl:when test="not($node[1]/..)"> + <xsl:text>/</xsl:text> + </xsl:when> + + <xsl:when test="count($node[1]/../namespace::* | $node[1]) = count($node[1]/../namespace::*)"> + <xsl:text/>/namespace::<xsl:value-of select="name($node[1])" /> + </xsl:when> + + <xsl:when test="count($node[1]/../@* | $node[1]) = count($node[1]/../@*)"> + <xsl:text/>/@<xsl:value-of select="name($node[1])" /> + </xsl:when> + + </xsl:choose> + </xsl:when> + + <xsl:otherwise> + <xsl:text>/..</xsl:text> + </xsl:otherwise> + + </xsl:choose> + + </xsl:template> + + <doc:template name="node:type" xmlns=""> + <refpurpose>Return node type</refpurpose> + + <refdescription> + <para>Returns the type of a node as a string.</para> + </refdescription> + + <refparameter> + <variablelist> + <varlistentry> + <term>node</term> + <listitem> + <para>The node to get the type for. If this parameter is given as a nodeset, then the first node in the nodeset is used.</para> + </listitem> + </varlistentry> + </variablelist> + </refparameter> + + <refreturn> + <para>Returns node type as a string. Values returned are:</para> + <variablelist> + <varlistentry> + <term>Element</term> + <listitem> + <para><literal>element</literal></para> + </listitem> + </varlistentry> + <varlistentry> + <term>Text Node</term> + <listitem> + <para><literal>text</literal></para> + </listitem> + </varlistentry> + <varlistentry> + <term>Comment</term> + <listitem> + <para><literal>comment</literal></para> + </listitem> + </varlistentry> + <varlistentry> + <term>Processing Instruction</term> + <listitem> + <para><literal>processing instruction</literal></para> + </listitem> + </varlistentry> + </variablelist> + </refreturn> + </doc:template> + + <xsl:template name="node:type"> + <xsl:param name="node" select="."/> + + <xsl:choose> + <xsl:when test="not($node)"/> + <xsl:when test="$node[1]/self::*"> + <xsl:text>element</xsl:text> + </xsl:when> + <xsl:when test="$node[1]/self::text()"> + <xsl:text>text</xsl:text> + </xsl:when> + <xsl:when test="$node[1]/self::comment()"> + <xsl:text>comment</xsl:text> + </xsl:when> + <xsl:when test="$node[1]/self::processing-instruction()"> + <xsl:text>processing instruction</xsl:text> + </xsl:when> + <xsl:when test="not($node[1]/parent::*)"> + <xsl:text>root</xsl:text> + </xsl:when> + <xsl:when test="count($node[1] | $node[1]/../namespace::*) = count($node[1]/../namespace::*)"> + <xsl:text>namespace</xsl:text> + </xsl:when> + <xsl:when test="count($node[1] | $node[1]/../@*) = count($node[1]/../@*)"> + <xsl:text>attribute</xsl:text> + </xsl:when> + </xsl:choose> + </xsl:template> + + <doc:template name="node:copy" xmlns=""> + <refpurpose>Copy Nodes</refpurpose> + + <refdescription> + <para>Makes a copy of the given nodes, including attributes and descendants.</para> + </refdescription> + + <refparameter> + <variablelist> + <varlistentry> + <term>nodes</term> + <listitem> + <para>The nodes to copy.</para> + </listitem> + </varlistentry> + </variablelist> + </refparameter> + + <refreturn> + <para>Returns the copied nodes as a result tree fragment.</para> + </refreturn> + </doc:template> + + <xsl:template name='node:copy'> + <xsl:param name='nodes' select='.'/> + + <xsl:for-each select='$nodes'> + <xsl:copy> + <xsl:for-each select='@*'> + <xsl:copy/> + </xsl:for-each> + + <xsl:for-each select='node()'> + <xsl:call-template name='node:copy'/> + </xsl:for-each> + </xsl:copy> + </xsl:for-each> + </xsl:template> +</xsl:stylesheet> + |