view refs.xsl @ 21:f05f0d0ee296

fix false positives
author Henry S. Thompson <ht@markup.co.uk>
date Wed, 05 Apr 2017 11:24:11 +0100
parents 16bba7a0d0bd
children ca98c74a7cb1
line wrap: on
line source

<?xml version='1.0'?>
<!DOCTYPE doc SYSTEM "../../../lib/xml/xsl.dtd" >
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" version="3.0" xmlns:s="http://schemas.openxmlformats.org/spreadsheetml/2006/main" xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:e="http://markup.co.uk/excel" exclude-result-prefixes="xs s" xmlns="http://schemas.openxmlformats.org/spreadsheetml/2006/main" xmlns:xf="http://www.w3.org/2005/xpath-functions">
  <xsl:variable name="pat1">("[^"]*")|(\{[^}]+})|(,)|([^=\-+*/();:,.$&lt;>^!]+(?:\.[^=\-+*/();:,.$&lt;>^!]+)*\()|([)])|(^=|\()|((?:'[^']+')|(?:\[[0-9]+\][^!]*))|(\$?[A-Z]+\$?[0-9]+)|([a-zA-Z_\\][a-zA-Z0-9._]*)|(.)</xsl:variable>
 <xsl:param name="pat" select="$pat1"/>

 <xsl:template match="/">
  <e:refs><xsl:apply-templates select="//s:c"/></e:refs>
 </xsl:template>
 
 <xsl:template match="s:c[s:f]">
  <xsl:variable name="tokens" select="analyze-string(.,$pat)/xf:match/xf:group"/>
  <xsl:if test="@r='B1'"><xsl:message><xsl:value-of select="$tokens/@nr"/></xsl:message>
<xsl:message><xsl:value-of select="$tokens/."/></xsl:message>
  </xsl:if>
  <xsl:if test="$tokens[@nr=8]">
   <xsl:variable name="n" select="count($tokens)"/>
   <xsl:variable name="singles" select="for $i in (1 to $n)
       return if ($tokens[$i][@nr=8] and not($tokens[$i - 1][@nr=10 and .=(':','!')]) and not($tokens[$i + 1][@nr=10 and .=':']))
            then translate($tokens[$i],'$','')
            else ()"/>
   <xsl:variable name="ranges" select="for $i in (1 to count($tokens))
          return if ($tokens[$i][@nr=10 and .=':' and
                                not($i gt 2 and
                                    $tokens[$i - 2][@nr=10 and .='!'])])
            then translate(concat($tokens[$i - 1],':',$tokens[$i + 1]),'$','')
            else ()"/>
   <xsl:variable name="externals" select="for $i in (1 to count($tokens))
          return if ($tokens[$i][@nr=7])
            then 
              let $bit := concat($tokens[$i],'!',
                                 translate($tokens[$i + 2],'$',''))
              return if ((($i+3) le $n) and $tokens[$i + 3][@nr=10 and .=':'])
                then concat($bit,':',translate($tokens[$i + 4],'$',''))
                else $bit
            else ()"/>
   <e:ref c="{@r}" r="{$singles}" rr="{$ranges}" er="{$externals}"/></xsl:if>
 </xsl:template>
 
 <xsl:template match="s:c"/>
</xsl:stylesheet>