source: trunk/Distribution/XSL/slides/keynote/xsltsl/node.xsl

Last change on this file was 2, checked in by jkacer, 18 years ago

Added all DocBook Framework stuff:

  • DocBook DTD
  • Transformation software FOP 0.20.5 and Saxon 6
  • XSL styles
  • Rexx scripts

Also added some WarpIN-related stuff for creation of WarpIN installation packages.
This state corresponds to version 1.0.0 from November 2005, just slightly modified to carry versioning information (Rexx scripts).

File size: 6.3 KB
Line 
1<?xml version="1.0"?>
2
3<xsl:stylesheet version="1.0"
4 xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
5 xmlns:doc="http://xsltsl.org/xsl/documentation/1.0"
6 xmlns:node="http://xsltsl.org/node"
7 extension-element-prefixes="doc node">
8
9 <doc:reference xmlns="">
10 <referenceinfo>
11 <releaseinfo role="meta">
12 $Id: node.xsl,v 1.1 2004/11/10 06:51:55 balls Exp $
13 </releaseinfo>
14 <author>
15 <surname>Ball</surname>
16 <firstname>Steve</firstname>
17 </author>
18 <copyright>
19 <year>2001</year>
20 <holder>Steve Ball</holder>
21 </copyright>
22 </referenceinfo>
23
24 <title>Node Templates</title>
25
26 <partintro>
27 <section>
28 <title>Introduction</title>
29
30 <para>This stylesheet module provides functions for reporting on or manipulating nodes and nodesets.</para>
31
32 </section>
33 </partintro>
34
35 </doc:reference>
36
37 <doc:template name="node:xpath" xmlns="">
38 <refpurpose>Returns an XPath location path</refpurpose>
39
40 <refdescription>
41 <para>This template returns an XPath location path that uniquely identifies the given node within the document.</para>
42 </refdescription>
43
44 <refparameter>
45 <variablelist>
46 <varlistentry>
47 <term>node</term>
48 <listitem>
49 <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>
50 </listitem>
51 </varlistentry>
52 </variablelist>
53 </refparameter>
54
55 <refreturn>
56 <para>Returns an XPath location path as a string.</para>
57 </refreturn>
58 </doc:template>
59
60 <xsl:template name="node:xpath">
61 <xsl:param name="node" select="."/>
62
63 <xsl:choose>
64
65 <xsl:when test="$node">
66
67 <xsl:for-each select="$node[1]/ancestor-or-self::*">
68 <xsl:text/>/<xsl:value-of select="name()"/>
69 <xsl:text/>[<xsl:value-of select="count(preceding-sibling::*[name() = name(current())]) + 1"/>]<xsl:text/>
70 </xsl:for-each>
71
72 <xsl:choose>
73
74 <xsl:when test="$node[1]/self::comment()">
75 <xsl:text>/comment()</xsl:text>
76 <xsl:text/>[<xsl:value-of select="count($node[1]/preceding-sibling::comment()) + 1" />]<xsl:text/>
77 </xsl:when>
78
79 <xsl:when test="$node[1]/self::processing-instruction()">
80 <xsl:text>/processing-instruction()</xsl:text>
81 <xsl:text/>[<xsl:value-of select="count($node[1]/preceding-sibling::processing-instruction()) + 1" />]<xsl:text/>
82 </xsl:when>
83
84 <xsl:when test="$node[1]/self::text()">
85 <xsl:text>/text()</xsl:text>
86 <xsl:text/>[<xsl:value-of select="count($node[1]/preceding-sibling::text()) + 1" />]<xsl:text/>
87 </xsl:when>
88
89 <xsl:when test="not($node[1]/..)">
90 <xsl:text>/</xsl:text>
91 </xsl:when>
92
93 <xsl:when test="count($node[1]/../namespace::* | $node[1]) = count($node[1]/../namespace::*)">
94 <xsl:text/>/namespace::<xsl:value-of select="name($node[1])" />
95 </xsl:when>
96
97 <xsl:when test="count($node[1]/../@* | $node[1]) = count($node[1]/../@*)">
98 <xsl:text/>/@<xsl:value-of select="name($node[1])" />
99 </xsl:when>
100
101 </xsl:choose>
102 </xsl:when>
103
104 <xsl:otherwise>
105 <xsl:text>/..</xsl:text>
106 </xsl:otherwise>
107
108 </xsl:choose>
109
110 </xsl:template>
111
112 <doc:template name="node:type" xmlns="">
113 <refpurpose>Return node type</refpurpose>
114
115 <refdescription>
116 <para>Returns the type of a node as a string.</para>
117 </refdescription>
118
119 <refparameter>
120 <variablelist>
121 <varlistentry>
122 <term>node</term>
123 <listitem>
124 <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>
125 </listitem>
126 </varlistentry>
127 </variablelist>
128 </refparameter>
129
130 <refreturn>
131 <para>Returns node type as a string. Values returned are:</para>
132 <variablelist>
133 <varlistentry>
134 <term>Element</term>
135 <listitem>
136 <para><literal>element</literal></para>
137 </listitem>
138 </varlistentry>
139 <varlistentry>
140 <term>Text Node</term>
141 <listitem>
142 <para><literal>text</literal></para>
143 </listitem>
144 </varlistentry>
145 <varlistentry>
146 <term>Comment</term>
147 <listitem>
148 <para><literal>comment</literal></para>
149 </listitem>
150 </varlistentry>
151 <varlistentry>
152 <term>Processing Instruction</term>
153 <listitem>
154 <para><literal>processing instruction</literal></para>
155 </listitem>
156 </varlistentry>
157 </variablelist>
158 </refreturn>
159 </doc:template>
160
161 <xsl:template name="node:type">
162 <xsl:param name="node" select="."/>
163
164 <xsl:choose>
165 <xsl:when test="not($node)"/>
166 <xsl:when test="$node[1]/self::*">
167 <xsl:text>element</xsl:text>
168 </xsl:when>
169 <xsl:when test="$node[1]/self::text()">
170 <xsl:text>text</xsl:text>
171 </xsl:when>
172 <xsl:when test="$node[1]/self::comment()">
173 <xsl:text>comment</xsl:text>
174 </xsl:when>
175 <xsl:when test="$node[1]/self::processing-instruction()">
176 <xsl:text>processing instruction</xsl:text>
177 </xsl:when>
178 <xsl:when test="not($node[1]/parent::*)">
179 <xsl:text>root</xsl:text>
180 </xsl:when>
181 <xsl:when test="count($node[1] | $node[1]/../namespace::*) = count($node[1]/../namespace::*)">
182 <xsl:text>namespace</xsl:text>
183 </xsl:when>
184 <xsl:when test="count($node[1] | $node[1]/../@*) = count($node[1]/../@*)">
185 <xsl:text>attribute</xsl:text>
186 </xsl:when>
187 </xsl:choose>
188 </xsl:template>
189
190 <doc:template name="node:copy" xmlns="">
191 <refpurpose>Copy Nodes</refpurpose>
192
193 <refdescription>
194 <para>Makes a copy of the given nodes, including attributes and descendants.</para>
195 </refdescription>
196
197 <refparameter>
198 <variablelist>
199 <varlistentry>
200 <term>nodes</term>
201 <listitem>
202 <para>The nodes to copy.</para>
203 </listitem>
204 </varlistentry>
205 </variablelist>
206 </refparameter>
207
208 <refreturn>
209 <para>Returns the copied nodes as a result tree fragment.</para>
210 </refreturn>
211 </doc:template>
212
213 <xsl:template name='node:copy'>
214 <xsl:param name='nodes' select='.'/>
215
216 <xsl:for-each select='$nodes'>
217 <xsl:copy>
218 <xsl:for-each select='@*'>
219 <xsl:copy/>
220 </xsl:for-each>
221
222 <xsl:for-each select='node()'>
223 <xsl:call-template name='node:copy'/>
224 </xsl:for-each>
225 </xsl:copy>
226 </xsl:for-each>
227 </xsl:template>
228</xsl:stylesheet>
229
Note: See TracBrowser for help on using the repository browser.