1cdf0e10cSrcweir<?xml version="1.0" encoding="UTF-8"?>
2*1e519d8dSAndrew Rist<!--***********************************************************
3*1e519d8dSAndrew Rist *
4*1e519d8dSAndrew Rist * Licensed to the Apache Software Foundation (ASF) under one
5*1e519d8dSAndrew Rist * or more contributor license agreements.  See the NOTICE file
6*1e519d8dSAndrew Rist * distributed with this work for additional information
7*1e519d8dSAndrew Rist * regarding copyright ownership.  The ASF licenses this file
8*1e519d8dSAndrew Rist * to you under the Apache License, Version 2.0 (the
9*1e519d8dSAndrew Rist * "License"); you may not use this file except in compliance
10*1e519d8dSAndrew Rist * with the License.  You may obtain a copy of the License at
11*1e519d8dSAndrew Rist *
12*1e519d8dSAndrew Rist *   http://www.apache.org/licenses/LICENSE-2.0
13*1e519d8dSAndrew Rist *
14*1e519d8dSAndrew Rist * Unless required by applicable law or agreed to in writing,
15*1e519d8dSAndrew Rist * software distributed under the License is distributed on an
16*1e519d8dSAndrew Rist * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
17*1e519d8dSAndrew Rist * KIND, either express or implied.  See the License for the
18*1e519d8dSAndrew Rist * specific language governing permissions and limitations
19*1e519d8dSAndrew Rist * under the License.
20*1e519d8dSAndrew Rist *
21*1e519d8dSAndrew Rist ***********************************************************-->
22cdf0e10cSrcweir
23cdf0e10cSrcweir
24cdf0e10cSrcweir<xsl:stylesheet version="1.0"
25cdf0e10cSrcweir	xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
26cdf0e10cSrcweir	xmlns:chart="urn:oasis:names:tc:opendocument:xmlns:chart:1.0"
27cdf0e10cSrcweir	xmlns:config="urn:oasis:names:tc:opendocument:xmlns:config:1.0"
28cdf0e10cSrcweir	xmlns:dc="http://purl.org/dc/elements/1.1/"
29cdf0e10cSrcweir	xmlns:dom="http://www.w3.org/2001/xml-events"
30cdf0e10cSrcweir	xmlns:dr3d="urn:oasis:names:tc:opendocument:xmlns:dr3d:1.0"
31cdf0e10cSrcweir	xmlns:draw="urn:oasis:names:tc:opendocument:xmlns:drawing:1.0"
32cdf0e10cSrcweir	xmlns:fo="urn:oasis:names:tc:opendocument:xmlns:xsl-fo-compatible:1.0"
33cdf0e10cSrcweir	xmlns:form="urn:oasis:names:tc:opendocument:xmlns:form:1.0"
34cdf0e10cSrcweir	xmlns:math="http://www.w3.org/1998/Math/MathML"
35cdf0e10cSrcweir	xmlns:meta="urn:oasis:names:tc:opendocument:xmlns:meta:1.0"
36cdf0e10cSrcweir	xmlns:number="urn:oasis:names:tc:opendocument:xmlns:datastyle:1.0"
37cdf0e10cSrcweir	xmlns:office="urn:oasis:names:tc:opendocument:xmlns:office:1.0"
38cdf0e10cSrcweir	xmlns:ooo="http://openoffice.org/2004/office"
39cdf0e10cSrcweir	xmlns:oooc="http://openoffice.org/2004/calc"
40cdf0e10cSrcweir	xmlns:ooow="http://openoffice.org/2004/writer"
41cdf0e10cSrcweir	xmlns:script="urn:oasis:names:tc:opendocument:xmlns:script:1.0"
42cdf0e10cSrcweir	xmlns:style="urn:oasis:names:tc:opendocument:xmlns:style:1.0"
43cdf0e10cSrcweir	xmlns:svg="urn:oasis:names:tc:opendocument:xmlns:svg-compatible:1.0"
44cdf0e10cSrcweir	xmlns:table="urn:oasis:names:tc:opendocument:xmlns:table:1.0"
45cdf0e10cSrcweir	xmlns:text="urn:oasis:names:tc:opendocument:xmlns:text:1.0"
46cdf0e10cSrcweir	xmlns:xlink="http://www.w3.org/1999/xlink"
47cdf0e10cSrcweir	xmlns:xt="http://www.jclark.com/xt"
48cdf0e10cSrcweir	xmlns:common="http://exslt.org/common"
49cdf0e10cSrcweir	xmlns:xalan="http://xml.apache.org/xalan"
50cdf0e10cSrcweir	xmlns="urn:schemas-microsoft-com:office:spreadsheet" xmlns:c="urn:schemas-microsoft-com:office:component:spreadsheet" xmlns:html="http://www.w3.org/TR/REC-html40" xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:ss="urn:schemas-microsoft-com:office:spreadsheet" xmlns:x2="http://schemas.microsoft.com/office/excel/2003/xml" xmlns:x="urn:schemas-microsoft-com:office:excel" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
51cdf0e10cSrcweir	exclude-result-prefixes="chart config dc dom dr3d draw fo form math meta number office ooo oooc ooow script style svg table text xlink xt common xalan">
52cdf0e10cSrcweir
53cdf0e10cSrcweir
54cdf0e10cSrcweir	<!-- Mapping @table:formula to @ss:Formula translating the expression syntax -->
55cdf0e10cSrcweir	<xsl:template match="@table:formula">
56cdf0e10cSrcweir		<xsl:param name="calculatedCellPosition" />
57cdf0e10cSrcweir		<xsl:param name="calculatedRowPosition" />
58cdf0e10cSrcweir
59cdf0e10cSrcweir		<xsl:attribute name="ss:Formula">
60cdf0e10cSrcweir			<xsl:call-template name="translate-formular-expression">
61cdf0e10cSrcweir				<xsl:with-param name="rowPos"    select="$calculatedRowPosition" />
62cdf0e10cSrcweir				<xsl:with-param name="columnPos" select="$calculatedCellPosition" />
63cdf0e10cSrcweir				<xsl:with-param name="expression" select="." />
64cdf0e10cSrcweir			</xsl:call-template>
65cdf0e10cSrcweir		</xsl:attribute>
66cdf0e10cSrcweir	</xsl:template>
67cdf0e10cSrcweir
68cdf0e10cSrcweir
69cdf0e10cSrcweir	<!-- Translate OOOC formula expressions of table cells to spreadsheetml expression
70cdf0e10cSrcweir
71cdf0e10cSrcweir		For example:
72cdf0e10cSrcweir			"oooc:=ROUNDDOWN(123.321;2)"
73cdf0e10cSrcweir				to "=ROUNDDOWN(123.321,2)"
74cdf0e10cSrcweir			"oooc:=([.B2]-[.C2])"
75cdf0e10cSrcweir				to  "=(RC[-2]-RC[-1])"
76cdf0e10cSrcweir			"oooc:=DCOUNTA([.E14:.F21];[.F14];[.H14:.I15])"
77cdf0e10cSrcweir				to  "=DCOUNTA(R[-17]C[3]:R[-10]C[4],R[-17]C[4],R[-17]C[6]:R[-16]C[7])"   -->
78cdf0e10cSrcweir	<xsl:template name="translate-formular-expression">
79cdf0e10cSrcweir		<!--  return position or range for formula or other -->
80cdf0e10cSrcweir		<xsl:param name="rowPos" /> <!-- the position in row (vertical) of cell -->
81cdf0e10cSrcweir		<xsl:param name="columnPos" /> <!-- the position in column (horizontal of cell) -->
82cdf0e10cSrcweir		<xsl:param name="expression" /> <!-- the expression string to be converted  -->
83cdf0e10cSrcweir
84cdf0e10cSrcweir		<xsl:choose>
85cdf0e10cSrcweir			<xsl:when test="$expression != ''">
86cdf0e10cSrcweir				<xsl:choose>
87cdf0e10cSrcweir					<!-- OASIS Open Document XML formular expressions  -->
88cdf0e10cSrcweir					<xsl:when test="starts-with($expression,'oooc:')">
89cdf0e10cSrcweir						<!-- giving out the '=', which will be removed with 'oooc:=' to enable recursive string parsing  -->
90cdf0e10cSrcweir						<xsl:text>=</xsl:text>
91cdf0e10cSrcweir						<xsl:call-template name="function-parameter-mapping">
92cdf0e10cSrcweir							<xsl:with-param name="rowPos" select="$rowPos" />
93cdf0e10cSrcweir							<xsl:with-param name="columnPos" select="$columnPos" />
94cdf0e10cSrcweir							<!-- 1) remove 'oooc:=' prefix and exchange ';' with ',' -->
95cdf0e10cSrcweir							<xsl:with-param name="expression" select="translate(substring($expression,7),';',',')"/>
96cdf0e10cSrcweir						</xsl:call-template>
97cdf0e10cSrcweir					</xsl:when>
98cdf0e10cSrcweir					<xsl:otherwise>
99cdf0e10cSrcweir						<xsl:value-of select="$expression" />
100cdf0e10cSrcweir					</xsl:otherwise>
101cdf0e10cSrcweir				</xsl:choose>
102cdf0e10cSrcweir			</xsl:when>
103cdf0e10cSrcweir			<xsl:otherwise>
104cdf0e10cSrcweir				<xsl:value-of select="$expression" />
105cdf0e10cSrcweir			</xsl:otherwise>
106cdf0e10cSrcweir		</xsl:choose>
107cdf0e10cSrcweir	</xsl:template>
108cdf0e10cSrcweir
109cdf0e10cSrcweir	<!-- As the function API of our Office and MS Office show differences in the argumentlists,
110cdf0e10cSrcweir			-	sometimes the last parameter have to be neglected
111cdf0e10cSrcweir			-	sometimes a default have to be added
112cdf0e10cSrcweir		these exchanges have to be done as well -->
113cdf0e10cSrcweir	<xsl:template name="function-parameter-mapping">
114cdf0e10cSrcweir		<xsl:param name="rowPos" /> <!-- the position in row (vertical of cell) -->
115cdf0e10cSrcweir		<xsl:param name="columnPos" /> <!-- the position in column (horizontal of cell) -->
116cdf0e10cSrcweir		<xsl:param name="expression" /> <!-- expression to be exchanged -->
117cdf0e10cSrcweir
118cdf0e10cSrcweir		<!-- Choose if the expression contains one of the function, which might need changes -->
119cdf0e10cSrcweir		<xsl:choose>
120cdf0e10cSrcweir			<!-- if not contain one of the functions, which need parameter mapping -->
121cdf0e10cSrcweir			<xsl:when test="not(contains($expression, 'ADDRESS(') or
122cdf0e10cSrcweir								contains($expression, 'CEILING(') or
123cdf0e10cSrcweir								contains($expression, 'FLOOR(') or
124cdf0e10cSrcweir								contains($expression, 'IF(') or
125cdf0e10cSrcweir								contains($expression, 'ROUND('))">
126cdf0e10cSrcweir				<!-- simply translate possily exisiting column & row references -->
127cdf0e10cSrcweir				<xsl:call-template name="translate-oooc-expression">
128cdf0e10cSrcweir					<xsl:with-param name="rowPos" select="$rowPos" />
129cdf0e10cSrcweir					<xsl:with-param name="columnPos" select="$columnPos" />
130cdf0e10cSrcweir					<xsl:with-param name="expression" select="$expression"/>
131cdf0e10cSrcweir				</xsl:call-template>
132cdf0e10cSrcweir			</xsl:when>
133cdf0e10cSrcweir			<!-- functions to be mapped -->
134cdf0e10cSrcweir			<xsl:otherwise>
135cdf0e10cSrcweir				<xsl:variable name="functionPrefix" select="substring-before($expression, '(')" />
136cdf0e10cSrcweir				<xsl:variable name="expressionSuffix" select="substring-after($expression, '(')" />
137cdf0e10cSrcweir
138cdf0e10cSrcweir				<!-- translate in case the expression contains row/cell references aside of the function name -->
139cdf0e10cSrcweir				<xsl:call-template name="translate-oooc-expression">
140cdf0e10cSrcweir					<xsl:with-param name="rowPos" select="$rowPos" />
141cdf0e10cSrcweir					<xsl:with-param name="columnPos" select="$columnPos" />
142cdf0e10cSrcweir					<xsl:with-param name="expression" select="$functionPrefix"/>
143cdf0e10cSrcweir				</xsl:call-template>
144cdf0e10cSrcweir				<!-- Prefix do not include the bracket -->
145cdf0e10cSrcweir				<xsl:text>(</xsl:text>
146cdf0e10cSrcweir				<xsl:choose>
147cdf0e10cSrcweir					<xsl:when test="not(contains($functionPrefix, 'ADDRESS') or
148cdf0e10cSrcweir										contains($functionPrefix, 'CEILING') or
149cdf0e10cSrcweir										contains($functionPrefix, 'FLOOR') or
150cdf0e10cSrcweir										(contains($functionPrefix, 'IF') and not(
151cdf0e10cSrcweir											contains($functionPrefix, 'COUNTIF') or
152cdf0e10cSrcweir											contains($functionPrefix, 'SUMIF'))) or
153cdf0e10cSrcweir										contains($functionPrefix, 'ROUND'))">
154cdf0e10cSrcweir						<xsl:call-template name="function-parameter-mapping">
155cdf0e10cSrcweir							<xsl:with-param name="rowPos" select="$rowPos" />
156cdf0e10cSrcweir							<xsl:with-param name="columnPos" select="$columnPos" />
157cdf0e10cSrcweir							<xsl:with-param name="expression" select="$expressionSuffix"/>
158cdf0e10cSrcweir						</xsl:call-template>
159cdf0e10cSrcweir					</xsl:when>
160cdf0e10cSrcweir					<xsl:otherwise>
161cdf0e10cSrcweir						<xsl:choose>
162cdf0e10cSrcweir							<xsl:when test="contains($functionPrefix, 'ADDRESS')">
163cdf0e10cSrcweir								<xsl:call-template name="find-parameters">
164cdf0e10cSrcweir									<xsl:with-param name="rowPos" select="$rowPos" />
165cdf0e10cSrcweir									<xsl:with-param name="columnPos" select="$columnPos" />
166cdf0e10cSrcweir									<xsl:with-param name="expressionSuffix" select="$expressionSuffix"/>
167cdf0e10cSrcweir									<xsl:with-param name="parameterRemoval" select="4" />
168cdf0e10cSrcweir								</xsl:call-template>
169cdf0e10cSrcweir							</xsl:when>
170cdf0e10cSrcweir							<xsl:when test="contains($functionPrefix, 'CEILING') or
171cdf0e10cSrcweir											contains($functionPrefix, 'FLOOR')">
172cdf0e10cSrcweir								<xsl:call-template name="find-parameters">
173cdf0e10cSrcweir									<xsl:with-param name="rowPos" select="$rowPos" />
174cdf0e10cSrcweir									<xsl:with-param name="columnPos" select="$columnPos" />
175cdf0e10cSrcweir									<xsl:with-param name="expressionSuffix" select="$expressionSuffix"/>
176cdf0e10cSrcweir									<xsl:with-param name="parameterRemoval" select="3" />
177cdf0e10cSrcweir								</xsl:call-template>
178cdf0e10cSrcweir							</xsl:when>
179cdf0e10cSrcweir							<xsl:when test="contains($functionPrefix, 'IF')">
180cdf0e10cSrcweir								<xsl:if test="not(contains($functionPrefix, 'COUNTIF') or
181cdf0e10cSrcweir												  contains($functionPrefix, 'SUMIF'))">
182cdf0e10cSrcweir									<xsl:call-template name="find-parameters">
183cdf0e10cSrcweir										<xsl:with-param name="rowPos" select="$rowPos" />
184cdf0e10cSrcweir										<xsl:with-param name="columnPos" select="$columnPos" />
185cdf0e10cSrcweir										<xsl:with-param name="expressionSuffix" select="$expressionSuffix"/>
186cdf0e10cSrcweir										<xsl:with-param name="parameterAddition" select="'true'" />
187cdf0e10cSrcweir										<xsl:with-param name="additonAfterLastParameter" select="2" />
188cdf0e10cSrcweir									</xsl:call-template>
189cdf0e10cSrcweir								</xsl:if>
190cdf0e10cSrcweir							</xsl:when>
191cdf0e10cSrcweir							<xsl:when test="contains($functionPrefix, 'ROUND')">
192cdf0e10cSrcweir								<xsl:call-template name="find-parameters">
193cdf0e10cSrcweir									<xsl:with-param name="rowPos" select="$rowPos" />
194cdf0e10cSrcweir									<xsl:with-param name="columnPos" select="$columnPos" />
195cdf0e10cSrcweir									<xsl:with-param name="expressionSuffix" select="$expressionSuffix"/>
196cdf0e10cSrcweir									<xsl:with-param name="parameterAddition" select="'null'" />
197cdf0e10cSrcweir									<xsl:with-param name="additonAfterLastParameter" select="1" />
198cdf0e10cSrcweir								</xsl:call-template>
199cdf0e10cSrcweir							</xsl:when>
200cdf0e10cSrcweir						</xsl:choose>
201cdf0e10cSrcweir					</xsl:otherwise>
202cdf0e10cSrcweir				</xsl:choose>
203cdf0e10cSrcweir			</xsl:otherwise>
204cdf0e10cSrcweir		</xsl:choose>
205cdf0e10cSrcweir	</xsl:template>
206cdf0e10cSrcweir
207cdf0e10cSrcweir	<!-- Each parameter of the argumentlist have to be determined.
208cdf0e10cSrcweir	Due to the low level string functionlity in XSLT it becomes a clumsy task -->
209cdf0e10cSrcweir	<xsl:template name="find-parameters">
210cdf0e10cSrcweir		<!-- used for mapping of row/column reference  -->
211cdf0e10cSrcweir		<xsl:param name="rowPos" /> <!-- the position in row (vertical of cell) -->
212cdf0e10cSrcweir		<xsl:param name="columnPos" /> <!-- the position in column (horizontal of cell) -->
213cdf0e10cSrcweir		<!-- used for mapping of parameter  -->
214cdf0e10cSrcweir		<xsl:param name="parameterRemoval" />
215cdf0e10cSrcweir		<xsl:param name="parameterAddition" />
216cdf0e10cSrcweir		<xsl:param name="additonAfterLastParameter" />
217cdf0e10cSrcweir		<!-- used as helper to find a parameter  -->
218cdf0e10cSrcweir		<xsl:param name="expressionSuffix" />
219cdf0e10cSrcweir		<xsl:param name="parameterNumber" select="1" />
220cdf0e10cSrcweir
221cdf0e10cSrcweir		<xsl:variable name="parameter">
222cdf0e10cSrcweir			<xsl:call-template name="getParameter">
223cdf0e10cSrcweir				<xsl:with-param name="expressionSuffix" select="$expressionSuffix"/>
224cdf0e10cSrcweir			</xsl:call-template>
225cdf0e10cSrcweir		</xsl:variable>
226cdf0e10cSrcweir
227cdf0e10cSrcweir		<xsl:choose>
228cdf0e10cSrcweir			<!-- if it is not the last parameter -->
229cdf0e10cSrcweir			<xsl:when test="starts-with(substring-after($expressionSuffix, $parameter), ',')">
230cdf0e10cSrcweir				<!-- searches the argument for functions to be mapped -->
231cdf0e10cSrcweir				<xsl:if test="not($parameterRemoval = $parameterNumber)">
232cdf0e10cSrcweir					<xsl:call-template name="function-parameter-mapping">
233cdf0e10cSrcweir						<xsl:with-param name="rowPos" select="$rowPos" />
234cdf0e10cSrcweir						<xsl:with-param name="columnPos" select="$columnPos" />
235cdf0e10cSrcweir						<xsl:with-param name="expression">
236cdf0e10cSrcweir							<xsl:choose>
237cdf0e10cSrcweir								<!-- in case a character will be removed the preceding won't make a comma -->
238cdf0e10cSrcweir								<xsl:when test="$parameterRemoval = ($parameterNumber + 1)">
239cdf0e10cSrcweir									<xsl:value-of select="$parameter" />
240cdf0e10cSrcweir								</xsl:when>
241cdf0e10cSrcweir								<xsl:otherwise>
242cdf0e10cSrcweir									<xsl:value-of select="concat($parameter, ',')" />
243cdf0e10cSrcweir								</xsl:otherwise>
244cdf0e10cSrcweir							</xsl:choose>
245cdf0e10cSrcweir						</xsl:with-param>
246cdf0e10cSrcweir					</xsl:call-template>
247cdf0e10cSrcweir				</xsl:if>
248cdf0e10cSrcweir				<!-- searches for the next parameter -->
249cdf0e10cSrcweir				<xsl:call-template name="find-parameters">
250cdf0e10cSrcweir					<xsl:with-param name="rowPos" select="$rowPos" />
251cdf0e10cSrcweir					<xsl:with-param name="columnPos" select="$columnPos" />
252cdf0e10cSrcweir					<xsl:with-param name="expressionSuffix" select="substring-after(substring-after($expressionSuffix, $parameter),',')"/>
253cdf0e10cSrcweir					<xsl:with-param name="parameterAddition" select="$parameterAddition" />
254cdf0e10cSrcweir					<xsl:with-param name="parameterRemoval" select="$parameterRemoval" />
255cdf0e10cSrcweir					<xsl:with-param name="additonAfterLastParameter" select="$additonAfterLastParameter" />
256cdf0e10cSrcweir					<xsl:with-param name="parameterNumber" select="$parameterNumber + 1" />
257cdf0e10cSrcweir				</xsl:call-template>
258cdf0e10cSrcweir			</xsl:when>
259cdf0e10cSrcweir			<xsl:otherwise>
260cdf0e10cSrcweir				<!-- the last parameter -->
261cdf0e10cSrcweir				<xsl:choose>
262cdf0e10cSrcweir					<xsl:when test="$parameterRemoval = $parameterNumber">
263cdf0e10cSrcweir						<!-- searches the rest of the expression for functions to be mapped -->
264cdf0e10cSrcweir						<xsl:call-template name="function-parameter-mapping">
265cdf0e10cSrcweir							<xsl:with-param name="rowPos" select="$rowPos" />
266cdf0e10cSrcweir							<xsl:with-param name="columnPos" select="$columnPos" />
267cdf0e10cSrcweir							<xsl:with-param name="expression" select="substring-after($expressionSuffix, $parameter)"/>
268cdf0e10cSrcweir						</xsl:call-template>
269cdf0e10cSrcweir					</xsl:when>
270cdf0e10cSrcweir					<xsl:when test="$parameterAddition and ($parameterNumber  = $additonAfterLastParameter)">
271cdf0e10cSrcweir						<!-- searches the rest of the expression for functions to be mapped -->
272cdf0e10cSrcweir						<xsl:call-template name="function-parameter-mapping">
273cdf0e10cSrcweir							<xsl:with-param name="rowPos" select="$rowPos" />
274cdf0e10cSrcweir							<xsl:with-param name="columnPos" select="$columnPos" />
275cdf0e10cSrcweir							<xsl:with-param name="expression" select="$parameter" />
276cdf0e10cSrcweir						</xsl:call-template>
277cdf0e10cSrcweir						<!-- searches last parameter and additional parameters for functions to be mapped -->
278cdf0e10cSrcweir						<xsl:call-template name="function-parameter-mapping">
279cdf0e10cSrcweir							<xsl:with-param name="rowPos" select="$rowPos" />
280cdf0e10cSrcweir							<xsl:with-param name="columnPos" select="$columnPos" />
281cdf0e10cSrcweir							<!-- for the final parameter the latter substring is the ')' -->
282cdf0e10cSrcweir							<xsl:with-param name="expression" select="concat(',', $parameterAddition, substring-after($expressionSuffix, $parameter))"/>
283cdf0e10cSrcweir						</xsl:call-template>
284cdf0e10cSrcweir					</xsl:when>
285cdf0e10cSrcweir					<xsl:otherwise>
286cdf0e10cSrcweir						<!-- searches the argument for functions to be mapped -->
287cdf0e10cSrcweir						<xsl:call-template name="function-parameter-mapping">
288cdf0e10cSrcweir							<xsl:with-param name="rowPos" select="$rowPos" />
289cdf0e10cSrcweir							<xsl:with-param name="columnPos" select="$columnPos" />
290cdf0e10cSrcweir							<xsl:with-param name="expression" select="$parameter" />
291cdf0e10cSrcweir						</xsl:call-template>
292cdf0e10cSrcweir						<!-- searches the rest of the expression for functions to be mapped -->
293cdf0e10cSrcweir						<xsl:call-template name="function-parameter-mapping">
294cdf0e10cSrcweir							<xsl:with-param name="rowPos" select="$rowPos" />
295cdf0e10cSrcweir							<xsl:with-param name="columnPos" select="$columnPos" />
296cdf0e10cSrcweir							<xsl:with-param name="expression" select="substring-after($expressionSuffix, $parameter)"/>
297cdf0e10cSrcweir						</xsl:call-template>
298cdf0e10cSrcweir					</xsl:otherwise>
299cdf0e10cSrcweir				</xsl:choose>
300cdf0e10cSrcweir			</xsl:otherwise>
301cdf0e10cSrcweir		</xsl:choose>
302cdf0e10cSrcweir	</xsl:template>
303cdf0e10cSrcweir
304cdf0e10cSrcweir	<xsl:template name="getParameter">
305cdf0e10cSrcweir		<xsl:param name="closingBracketCount" select="0" />
306cdf0e10cSrcweir		<xsl:param name="openingBracketCount" select="0" />
307cdf0e10cSrcweir		<xsl:param name="expressionSuffix" />
308cdf0e10cSrcweir		<xsl:param name="parameterCandidate">
309cdf0e10cSrcweir			<xsl:choose>
310cdf0e10cSrcweir				<!-- if there are multiple parameter -->
311cdf0e10cSrcweir				<xsl:when test="contains(substring-before($expressionSuffix, ')'), ',')">
312cdf0e10cSrcweir					<xsl:value-of select="substring-before($expressionSuffix, ',')"/>
313cdf0e10cSrcweir				</xsl:when>
314cdf0e10cSrcweir				<xsl:otherwise>
315cdf0e10cSrcweir					<xsl:value-of select="substring-before($expressionSuffix, ')')"/>
316cdf0e10cSrcweir				</xsl:otherwise>
317cdf0e10cSrcweir			</xsl:choose>
318cdf0e10cSrcweir		</xsl:param>
319cdf0e10cSrcweir		<xsl:param name="earlierCandidate" select="$parameterCandidate" />
320cdf0e10cSrcweir
321cdf0e10cSrcweir		<xsl:choose>
322cdf0e10cSrcweir			<xsl:when test="contains($parameterCandidate, '(') or contains($parameterCandidate, ')')">
323cdf0e10cSrcweir				<xsl:choose>
324cdf0e10cSrcweir					<!-- contains only closing bracket(s) -->
325cdf0e10cSrcweir					<xsl:when test="contains($parameterCandidate, '(') and not(contains($parameterCandidate, ')'))">
326cdf0e10cSrcweir						<xsl:call-template name="getParameter">
327cdf0e10cSrcweir							<xsl:with-param name="openingBracketCount" select="$openingBracketCount + 1" />
328cdf0e10cSrcweir							<xsl:with-param name="closingBracketCount" select="$closingBracketCount" />
329cdf0e10cSrcweir							<xsl:with-param name="parameterCandidate" select="substring-after($parameterCandidate, '(')" />
330cdf0e10cSrcweir							<xsl:with-param name="earlierCandidate" select="$earlierCandidate" />
331cdf0e10cSrcweir							<xsl:with-param name="expressionSuffix" select="$expressionSuffix"/>
332cdf0e10cSrcweir						</xsl:call-template>
333cdf0e10cSrcweir					</xsl:when>
334cdf0e10cSrcweir					<!-- contains only opening bracket(s) -->
335cdf0e10cSrcweir					<xsl:when test="not(contains($parameterCandidate, '(')) and contains($parameterCandidate, ')')">
336cdf0e10cSrcweir						<xsl:call-template name="getParameter">
337cdf0e10cSrcweir							<xsl:with-param name="openingBracketCount" select="$openingBracketCount" />
338cdf0e10cSrcweir							<xsl:with-param name="closingBracketCount" select="$closingBracketCount + 1" />
339cdf0e10cSrcweir							<xsl:with-param name="parameterCandidate" select="substring-after($parameterCandidate, ')')" />
340cdf0e10cSrcweir							<xsl:with-param name="earlierCandidate" select="$earlierCandidate" />
341cdf0e10cSrcweir							<xsl:with-param name="expressionSuffix" select="$expressionSuffix"/>
342cdf0e10cSrcweir						</xsl:call-template>
343cdf0e10cSrcweir					</xsl:when>
344cdf0e10cSrcweir					<xsl:otherwise>
345cdf0e10cSrcweir						<xsl:choose>
346cdf0e10cSrcweir							<xsl:when test="string-length(substring-before($parameterCandidate, '(')) &lt;
347cdf0e10cSrcweir											string-length(substring-before($parameterCandidate, ')'))">
348cdf0e10cSrcweir								<xsl:call-template name="getParameter">
349cdf0e10cSrcweir									<xsl:with-param name="openingBracketCount" select="$openingBracketCount + 1" />
350cdf0e10cSrcweir									<xsl:with-param name="closingBracketCount" select="$closingBracketCount" />
351cdf0e10cSrcweir									<xsl:with-param name="parameterCandidate" select="substring-after($parameterCandidate, '(')" />
352cdf0e10cSrcweir									<xsl:with-param name="earlierCandidate" select="$earlierCandidate" />
353cdf0e10cSrcweir									<xsl:with-param name="expressionSuffix" select="$expressionSuffix"/>
354cdf0e10cSrcweir								</xsl:call-template>
355cdf0e10cSrcweir							</xsl:when>
356cdf0e10cSrcweir							<xsl:otherwise>
357cdf0e10cSrcweir								<xsl:call-template name="getParameter">
358cdf0e10cSrcweir									<xsl:with-param name="openingBracketCount" select="$openingBracketCount" />
359cdf0e10cSrcweir									<xsl:with-param name="closingBracketCount" select="$closingBracketCount + 1" />
360cdf0e10cSrcweir									<xsl:with-param name="parameterCandidate" select="substring-after($parameterCandidate, ')')" />
361cdf0e10cSrcweir									<xsl:with-param name="earlierCandidate" select="$earlierCandidate" />
362cdf0e10cSrcweir									<xsl:with-param name="expressionSuffix" select="$expressionSuffix"/>
363cdf0e10cSrcweir								</xsl:call-template>
364cdf0e10cSrcweir							</xsl:otherwise>
365cdf0e10cSrcweir						</xsl:choose>
366cdf0e10cSrcweir					</xsl:otherwise>
367cdf0e10cSrcweir				</xsl:choose>
368cdf0e10cSrcweir			</xsl:when>
369cdf0e10cSrcweir			<xsl:otherwise>
370cdf0e10cSrcweir				<xsl:choose>
371cdf0e10cSrcweir					<xsl:when test="$openingBracketCount = $closingBracketCount">
372cdf0e10cSrcweir						<xsl:value-of select="$earlierCandidate" />
373cdf0e10cSrcweir					</xsl:when>
374cdf0e10cSrcweir					<xsl:otherwise>
375cdf0e10cSrcweir						<xsl:value-of select="$earlierCandidate" />
376cdf0e10cSrcweir						<xsl:variable name="parameterCandidate2">
377cdf0e10cSrcweir							<xsl:variable name="formularAfterCandidate" select="substring-after($expressionSuffix, $earlierCandidate)" />
378cdf0e10cSrcweir							<xsl:variable name="parameterTillBracket" select="concat(substring-before($formularAfterCandidate,')'),')')" />
379cdf0e10cSrcweir							<xsl:variable name="parameterTillComma" select="substring-before(substring-after($expressionSuffix, $parameterTillBracket),',')" />
380cdf0e10cSrcweir							<xsl:choose>
381cdf0e10cSrcweir								<xsl:when test="string-length($parameterTillComma) &gt; 0 and
382cdf0e10cSrcweir												not(contains($parameterTillComma, '('))">
383cdf0e10cSrcweir									<xsl:choose>
384cdf0e10cSrcweir										<xsl:when test="starts-with($formularAfterCandidate, ',')">
385cdf0e10cSrcweir											<xsl:value-of select="concat(',',substring-before(substring-after($formularAfterCandidate,','),','))"/>
386cdf0e10cSrcweir										</xsl:when>
387cdf0e10cSrcweir										<xsl:otherwise>
388cdf0e10cSrcweir											<xsl:value-of select="substring-before($formularAfterCandidate,',')"/>
389cdf0e10cSrcweir										</xsl:otherwise>
390cdf0e10cSrcweir									</xsl:choose>
391cdf0e10cSrcweir								</xsl:when>
392cdf0e10cSrcweir								<xsl:otherwise>
393cdf0e10cSrcweir									<xsl:value-of select="$parameterTillBracket"/>
394cdf0e10cSrcweir								</xsl:otherwise>
395cdf0e10cSrcweir							</xsl:choose>
396cdf0e10cSrcweir						</xsl:variable>
397cdf0e10cSrcweir						<xsl:call-template name="getParameter">
398cdf0e10cSrcweir							<xsl:with-param name="closingBracketCount" select="$closingBracketCount" />
399cdf0e10cSrcweir							<xsl:with-param name="openingBracketCount" select="$openingBracketCount" />
400cdf0e10cSrcweir							<xsl:with-param name="parameterCandidate" select="$parameterCandidate2" />
401cdf0e10cSrcweir							<xsl:with-param name="earlierCandidate" select="$parameterCandidate2" />
402cdf0e10cSrcweir							<xsl:with-param name="expressionSuffix" select="$expressionSuffix" />
403cdf0e10cSrcweir						</xsl:call-template>
404cdf0e10cSrcweir					</xsl:otherwise>
405cdf0e10cSrcweir				</xsl:choose>
406cdf0e10cSrcweir			</xsl:otherwise>
407cdf0e10cSrcweir		</xsl:choose>
408cdf0e10cSrcweir	</xsl:template>
409cdf0e10cSrcweir
410cdf0e10cSrcweir	<!-- Mapping table-cell definitions by exchangomg all table cell definitions:
411cdf0e10cSrcweir		a) a pair of cells e.g. "[.E14:.F21]" to "R[-17]C[3]:R[-10]C[4]"
412cdf0e10cSrcweir		b) a single cell e.g. "[.F14]" to "R[-17]"-->
413cdf0e10cSrcweir	<xsl:template name="translate-oooc-expression">
414cdf0e10cSrcweir		<xsl:param name="rowPos" /> <!-- the position in row (vertical of cell) -->
415cdf0e10cSrcweir		<xsl:param name="columnPos" /> <!-- the position in column (horizontal of cell) -->
416cdf0e10cSrcweir		<xsl:param name="expression" /> <!-- expression to be exchanged -->
417cdf0e10cSrcweir
418cdf0e10cSrcweir		<xsl:choose>
419cdf0e10cSrcweir			<xsl:when test="contains($expression, '[')">
420cdf0e10cSrcweir
421cdf0e10cSrcweir				<!-- Giving out the part before '[.' -->
422cdf0e10cSrcweir				<xsl:value-of select="substring-before($expression, '[')" />
423cdf0e10cSrcweir
424cdf0e10cSrcweir				<!-- Mapping cell definitions
425cdf0e10cSrcweir				1) a pair of cells e.g. "[.E14:.F21]" to "R[-17]C[3]:R[-10]C[4]"
426cdf0e10cSrcweir				2) a single cell e.g. "[.F14]" to "R[-17]"-->
427cdf0e10cSrcweir				<xsl:variable name="remainingExpression" select="substring-after($expression, '[')"/>
428cdf0e10cSrcweir				<xsl:choose>
429cdf0e10cSrcweir					<xsl:when test="contains(substring-before($remainingExpression, ']'), ':')">
430cdf0e10cSrcweir						<xsl:call-template name="translate-cell-expression">
431cdf0e10cSrcweir							<xsl:with-param name="rowPos" select="$rowPos" />
432cdf0e10cSrcweir							<xsl:with-param name="columnPos" select="$columnPos" />
433cdf0e10cSrcweir							<xsl:with-param name="expression" select="substring-before($remainingExpression, ':')" />
434cdf0e10cSrcweir						</xsl:call-template>
435cdf0e10cSrcweir						<xsl:value-of select="':'" />
436cdf0e10cSrcweir						<xsl:call-template name="translate-cell-expression">
437cdf0e10cSrcweir							<xsl:with-param name="rowPos" select="$rowPos" />
438cdf0e10cSrcweir							<xsl:with-param name="columnPos" select="$columnPos" />
439cdf0e10cSrcweir							<xsl:with-param name="expression" select="substring-after(substring-before($remainingExpression, ']'), ':')" />
440cdf0e10cSrcweir						</xsl:call-template>
441cdf0e10cSrcweir					</xsl:when>
442cdf0e10cSrcweir					<xsl:otherwise>
443cdf0e10cSrcweir						<xsl:call-template name="translate-cell-expression">
444cdf0e10cSrcweir							<xsl:with-param name="rowPos" select="$rowPos" />
445cdf0e10cSrcweir							<xsl:with-param name="columnPos" select="$columnPos" />
446cdf0e10cSrcweir							<xsl:with-param name="expression" select="substring-before($remainingExpression, ']')" />
447cdf0e10cSrcweir						</xsl:call-template>
448cdf0e10cSrcweir					</xsl:otherwise>
449cdf0e10cSrcweir				</xsl:choose>
450cdf0e10cSrcweir				<xsl:call-template name="translate-oooc-expression">
451cdf0e10cSrcweir					<xsl:with-param name="rowPos" select="$rowPos" />
452cdf0e10cSrcweir					<xsl:with-param name="columnPos" select="$columnPos" />
453cdf0e10cSrcweir					<xsl:with-param name="expression" select="substring-after($remainingExpression,']')"/>
454cdf0e10cSrcweir				</xsl:call-template>
455cdf0e10cSrcweir			</xsl:when>
456cdf0e10cSrcweir			<xsl:otherwise>
457cdf0e10cSrcweir				<!-- Giving out the remaining part -->
458cdf0e10cSrcweir				<xsl:value-of select="$expression" />
459cdf0e10cSrcweir			</xsl:otherwise>
460cdf0e10cSrcweir		</xsl:choose>
461cdf0e10cSrcweir	</xsl:template>
462cdf0e10cSrcweir
463cdf0e10cSrcweir
464cdf0e10cSrcweir	<!-- A cell expression has usually starts with a '.' otherwise it references to a sheet  -->
465cdf0e10cSrcweir	<xsl:template name="translate-cell-expression">
466cdf0e10cSrcweir		<xsl:param name="rowPos" /> <!-- the vertical position of the current cell -->
467cdf0e10cSrcweir		<xsl:param name="columnPos" /> <!-- the horizontal position of the current cell -->
468cdf0e10cSrcweir		<xsl:param name="targetRowPos" select="0"/> <!-- the vertical position of the target cell -->
469cdf0e10cSrcweir		<xsl:param name="targetColumnPos" select="0"/> <!-- the horizontal position of the target cell -->
470cdf0e10cSrcweir		<xsl:param name="charPos" select="0"/> <!-- current column position (needed for multiplying) -->
471cdf0e10cSrcweir		<xsl:param name="digitPos" select="0"/>  <!-- current row position (needed for multiplying) -->
472cdf0e10cSrcweir		<xsl:param name="expression" /> <!-- expression to be parsed by character -->
473cdf0e10cSrcweir		<xsl:param name="isRow" select="true()"/> <!-- the string (e.g. $D39 is parsed character per character from the back,
474cdf0e10cSrcweir													   first the row, later the column is parsed -->
475cdf0e10cSrcweir
476cdf0e10cSrcweir		<xsl:choose>
477cdf0e10cSrcweir			<xsl:when test="starts-with($expression, '.')">
478cdf0e10cSrcweir				<xsl:variable name="expLength" select="string-length($expression)" />
479cdf0e10cSrcweir				<xsl:choose>
480cdf0e10cSrcweir					<!-- parsing from the end, till only the '.' remains -->
481cdf0e10cSrcweir					<xsl:when test="$expLength != 1">
482cdf0e10cSrcweir						<xsl:variable name="token" select="substring($expression, $expLength)" />
483cdf0e10cSrcweir						<xsl:choose>
484cdf0e10cSrcweir							<xsl:when test="$token='0' or $token='1' or $token='2' or $token='3' or $token='4' or $token='5' or $token='6' or $token='7' or $token='8' or $token='9'">
485cdf0e10cSrcweir								<xsl:variable name="multiplier">
486cdf0e10cSrcweir									<xsl:call-template name="calculate-square-numbers">
487cdf0e10cSrcweir										<xsl:with-param name="base" select="10" />
488cdf0e10cSrcweir										<xsl:with-param name="exponent" select="$digitPos"/>
489cdf0e10cSrcweir									</xsl:call-template>
490cdf0e10cSrcweir								</xsl:variable>
491cdf0e10cSrcweir								<xsl:call-template name="translate-cell-expression">
492cdf0e10cSrcweir									<xsl:with-param name="columnPos" select="$columnPos" />
493cdf0e10cSrcweir									<xsl:with-param name="rowPos" select="$rowPos" />
494cdf0e10cSrcweir									<xsl:with-param name="targetColumnPos" select="$targetColumnPos" />
495cdf0e10cSrcweir									<xsl:with-param name="targetRowPos" select="$targetRowPos + $multiplier * $token" />
496cdf0e10cSrcweir									<xsl:with-param name="digitPos" select="$digitPos + 1" />
497cdf0e10cSrcweir									<xsl:with-param name="charPos" select="$charPos" />
498cdf0e10cSrcweir									<!-- removing the last character-->
499cdf0e10cSrcweir									<xsl:with-param name="expression" select="substring($expression, 1, $expLength - 1)" />
500cdf0e10cSrcweir									<xsl:with-param name="isRow" select="true()" />
501cdf0e10cSrcweir								</xsl:call-template>
502cdf0e10cSrcweir							</xsl:when>
503cdf0e10cSrcweir							<xsl:when test="$token = '$'">
504cdf0e10cSrcweir								<xsl:choose>
505cdf0e10cSrcweir									<!-- if this is the first '$' after '.' (column-->
506cdf0e10cSrcweir									<xsl:when test="$expLength = 2">
507cdf0e10cSrcweir										<xsl:text>C</xsl:text><xsl:value-of select="$targetColumnPos"/>
508cdf0e10cSrcweir									</xsl:when>
509cdf0e10cSrcweir									<xsl:otherwise>
510cdf0e10cSrcweir										<xsl:text>R</xsl:text><xsl:value-of select="$targetRowPos"/>
511cdf0e10cSrcweir										<xsl:call-template name="translate-cell-expression">
512cdf0e10cSrcweir											<xsl:with-param name="columnPos" select="$columnPos" />
513cdf0e10cSrcweir											<xsl:with-param name="rowPos" select="$rowPos" />
514cdf0e10cSrcweir											<xsl:with-param name="targetColumnPos" select="$targetColumnPos" />
515cdf0e10cSrcweir											<xsl:with-param name="targetRowPos" select="$targetRowPos" />
516cdf0e10cSrcweir											<xsl:with-param name="charPos" select="$charPos" />
517cdf0e10cSrcweir											<!-- removing the last character-->
518cdf0e10cSrcweir											<xsl:with-param name="expression" select="substring($expression, 1, $expLength - 1)" />
519cdf0e10cSrcweir											<xsl:with-param name="isRow" select="false()" />
520cdf0e10cSrcweir										</xsl:call-template>
521cdf0e10cSrcweir									</xsl:otherwise>
522cdf0e10cSrcweir								</xsl:choose>
523cdf0e10cSrcweir							</xsl:when>
524cdf0e10cSrcweir							<!-- in case of a letter -->
525cdf0e10cSrcweir							<xsl:otherwise>
526cdf0e10cSrcweir								<xsl:if test="$isRow">
527cdf0e10cSrcweir									<xsl:text>R</xsl:text>
528cdf0e10cSrcweir									<xsl:if test="$targetRowPos != $rowPos">
529cdf0e10cSrcweir										<xsl:text>[</xsl:text><xsl:value-of select="$targetRowPos - $rowPos"/><xsl:text>]</xsl:text>
530cdf0e10cSrcweir									</xsl:if>
531cdf0e10cSrcweir								</xsl:if>
532cdf0e10cSrcweir								<xsl:variable name="multiplier">
533cdf0e10cSrcweir									<xsl:call-template name="calculate-square-numbers">
534cdf0e10cSrcweir										<xsl:with-param name="base" select="26" />
535cdf0e10cSrcweir										<xsl:with-param name="exponent" select="$charPos"/>
536cdf0e10cSrcweir									</xsl:call-template>
537cdf0e10cSrcweir								</xsl:variable>
538cdf0e10cSrcweir								<xsl:variable name="tokenNumber">
539cdf0e10cSrcweir									<xsl:call-template name="character-to-number">
540cdf0e10cSrcweir										<xsl:with-param name="character" select="$token" />
541cdf0e10cSrcweir									</xsl:call-template>
542cdf0e10cSrcweir								</xsl:variable>
543cdf0e10cSrcweir
544cdf0e10cSrcweir								<xsl:call-template name="translate-cell-expression">
545cdf0e10cSrcweir									<xsl:with-param name="columnPos" select="$columnPos" />
546cdf0e10cSrcweir									<xsl:with-param name="rowPos" select="$rowPos" />
547cdf0e10cSrcweir									<xsl:with-param name="targetColumnPos" select="$targetColumnPos + $multiplier * $tokenNumber" />
548cdf0e10cSrcweir									<xsl:with-param name="targetRowPos" select="$targetRowPos" />
549cdf0e10cSrcweir									<xsl:with-param name="digitPos" select="$digitPos" />
550cdf0e10cSrcweir									<xsl:with-param name="charPos" select="$charPos + 1" />
551cdf0e10cSrcweir									<!-- removing the last character-->
552cdf0e10cSrcweir									<xsl:with-param name="expression" select="substring($expression, 1, $expLength - 1)" />
553cdf0e10cSrcweir									<xsl:with-param name="isRow" select="false()" />
554cdf0e10cSrcweir								</xsl:call-template>
555cdf0e10cSrcweir							</xsl:otherwise>
556cdf0e10cSrcweir						</xsl:choose>
557cdf0e10cSrcweir					</xsl:when>
558cdf0e10cSrcweir					<xsl:otherwise>
559cdf0e10cSrcweir						<xsl:text>C</xsl:text>
560cdf0e10cSrcweir						<xsl:if test="$targetColumnPos != $columnPos">
561cdf0e10cSrcweir							<xsl:text>[</xsl:text><xsl:value-of select="$targetColumnPos - $columnPos"/><xsl:text>]</xsl:text>
562cdf0e10cSrcweir						</xsl:if>
563cdf0e10cSrcweir					</xsl:otherwise>
564cdf0e10cSrcweir				</xsl:choose>
565cdf0e10cSrcweir			</xsl:when>
566cdf0e10cSrcweir			<xsl:otherwise>
567cdf0e10cSrcweir				<xsl:variable name="sheetName" select="substring-before($expression, '.')" />
568cdf0e10cSrcweir				<xsl:value-of select="$sheetName"/><xsl:text>!</xsl:text>
569cdf0e10cSrcweir				<xsl:call-template name="translate-cell-expression">
570cdf0e10cSrcweir					<xsl:with-param name="rowPos" select="$rowPos" />
571cdf0e10cSrcweir					<xsl:with-param name="columnPos" select="$columnPos" />
572cdf0e10cSrcweir					<xsl:with-param name="expression" select="substring-after($expression, $sheetName)" />
573cdf0e10cSrcweir				</xsl:call-template>
574cdf0e10cSrcweir			</xsl:otherwise>
575cdf0e10cSrcweir		</xsl:choose>
576cdf0e10cSrcweir	</xsl:template>
577cdf0e10cSrcweir
578cdf0e10cSrcweir
579cdf0e10cSrcweir	<xsl:template name="calculate-square-numbers">
580cdf0e10cSrcweir		<xsl:param name="base" />
581cdf0e10cSrcweir		<xsl:param name="exponent" />
582cdf0e10cSrcweir		<xsl:param name="return" select="1" />
583cdf0e10cSrcweir
584cdf0e10cSrcweir		<xsl:choose>
585cdf0e10cSrcweir			<xsl:when test="$exponent > '1'">
586cdf0e10cSrcweir				<xsl:call-template name="calculate-square-numbers">
587cdf0e10cSrcweir					<xsl:with-param name="base" select="$base" />
588cdf0e10cSrcweir					<xsl:with-param name="exponent" select="$exponent - 1"/>
589cdf0e10cSrcweir					<xsl:with-param name="return" select="$return * $base" />
590cdf0e10cSrcweir				</xsl:call-template>
591cdf0e10cSrcweir			</xsl:when>
592cdf0e10cSrcweir			<xsl:when test="$exponent = '1'">
593cdf0e10cSrcweir				<xsl:value-of select="$return * $base"/>
594cdf0e10cSrcweir			</xsl:when>
595cdf0e10cSrcweir			<!-- if exponent is equal '0' -->
596cdf0e10cSrcweir			<xsl:otherwise>
597cdf0e10cSrcweir				<xsl:value-of select="1"/>
598cdf0e10cSrcweir			</xsl:otherwise>
599cdf0e10cSrcweir		</xsl:choose>
600cdf0e10cSrcweir	</xsl:template>
601cdf0e10cSrcweir
602cdf0e10cSrcweir
603cdf0e10cSrcweir	<xsl:template name="character-to-number">
604cdf0e10cSrcweir		<xsl:param name="character" />
605cdf0e10cSrcweir		<xsl:choose>
606cdf0e10cSrcweir			<xsl:when test="$character = 'A'">1</xsl:when>
607cdf0e10cSrcweir			<xsl:when test="$character = 'B'">2</xsl:when>
608cdf0e10cSrcweir			<xsl:when test="$character = 'C'">3</xsl:when>
609cdf0e10cSrcweir			<xsl:when test="$character = 'D'">4</xsl:when>
610cdf0e10cSrcweir			<xsl:when test="$character = 'E'">5</xsl:when>
611cdf0e10cSrcweir			<xsl:when test="$character = 'F'">6</xsl:when>
612cdf0e10cSrcweir			<xsl:when test="$character = 'G'">7</xsl:when>
613cdf0e10cSrcweir			<xsl:when test="$character = 'H'">8</xsl:when>
614cdf0e10cSrcweir			<xsl:when test="$character = 'I'">9</xsl:when>
615cdf0e10cSrcweir			<xsl:when test="$character = 'J'">10</xsl:when>
616cdf0e10cSrcweir			<xsl:when test="$character = 'K'">11</xsl:when>
617cdf0e10cSrcweir			<xsl:when test="$character = 'L'">12</xsl:when>
618cdf0e10cSrcweir			<xsl:when test="$character = 'M'">13</xsl:when>
619cdf0e10cSrcweir			<xsl:when test="$character = 'N'">14</xsl:when>
620cdf0e10cSrcweir			<xsl:when test="$character = 'O'">15</xsl:when>
621cdf0e10cSrcweir			<xsl:when test="$character = 'P'">16</xsl:when>
622cdf0e10cSrcweir			<xsl:when test="$character = 'Q'">17</xsl:when>
623cdf0e10cSrcweir			<xsl:when test="$character = 'R'">18</xsl:when>
624cdf0e10cSrcweir			<xsl:when test="$character = 'S'">19</xsl:when>
625cdf0e10cSrcweir			<xsl:when test="$character = 'T'">20</xsl:when>
626cdf0e10cSrcweir			<xsl:when test="$character = 'U'">21</xsl:when>
627cdf0e10cSrcweir			<xsl:when test="$character = 'V'">22</xsl:when>
628cdf0e10cSrcweir			<xsl:when test="$character = 'W'">23</xsl:when>
629cdf0e10cSrcweir			<xsl:when test="$character = 'X'">24</xsl:when>
630cdf0e10cSrcweir			<xsl:when test="$character = 'Y'">25</xsl:when>
631cdf0e10cSrcweir			<xsl:when test="$character = 'Z'">26</xsl:when>
632cdf0e10cSrcweir			<xsl:otherwise/>
633cdf0e10cSrcweir		</xsl:choose>
634cdf0e10cSrcweir	</xsl:template>
635cdf0e10cSrcweir
636cdf0e10cSrcweir</xsl:stylesheet>
637