plcopen/pou_variables.xslt
changeset 1936 b85b13b1c2ec
parent 1348 aee0a7eb833a
child 1943 9dc0e38552b2
--- a/plcopen/pou_variables.xslt	Fri Feb 16 01:38:34 2018 +0100
+++ b/plcopen/pou_variables.xslt	Fri Feb 16 01:48:48 2018 +0100
@@ -1,23 +1,11 @@
 <?xml version="1.0"?>
-<xsl:stylesheet xmlns:func="http://exslt.org/functions" xmlns:dyn="http://exslt.org/dynamic" xmlns:str="http://exslt.org/strings" xmlns:math="http://exslt.org/math" xmlns:exsl="http://exslt.org/common" xmlns:xhtml="http://www.w3.org/1999/xhtml" xmlns:yml="http://fdik.org/yml" xmlns:set="http://exslt.org/sets" xmlns:ppx="http://www.plcopen.org/xml/tc6_0201" xmlns:ns="pou_vars_ns" xmlns:regexp="http://exslt.org/regular-expressions" xmlns:xsl="http://www.w3.org/1999/XSL/Transform" extension-element-prefixes="ns" version="1.0" exclude-result-prefixes="ns">
+<xsl:stylesheet xmlns:exsl="http://exslt.org/common" xmlns:xhtml="http://www.w3.org/1999/xhtml" xmlns:ppx="http://www.plcopen.org/xml/tc6_0201" xmlns:ns="pou_vars_ns" xmlns:xsl="http://www.w3.org/1999/XSL/Transform" extension-element-prefixes="ns" version="1.0" exclude-result-prefixes="ns">
   <xsl:output method="xml"/>
-  <xsl:variable name="space" select="'                                                                                                                                                                                                        '"/>
-  <xsl:param name="autoindent" select="4"/>
-  <xsl:template match="text()">
-    <xsl:param name="_indent" select="0"/>
-  </xsl:template>
-  <xsl:template mode="var_class" match="text()">
-    <xsl:param name="_indent" select="0"/>
-  </xsl:template>
-  <xsl:template mode="var_type" match="text()">
-    <xsl:param name="_indent" select="0"/>
-  </xsl:template>
-  <xsl:template mode="var_edit" match="text()">
-    <xsl:param name="_indent" select="0"/>
-  </xsl:template>
-  <xsl:template mode="var_debug" match="text()">
-    <xsl:param name="_indent" select="0"/>
-  </xsl:template>
+  <xsl:template match="text()"/>
+  <xsl:template mode="var_class" match="text()"/>
+  <xsl:template mode="var_type" match="text()"/>
+  <xsl:template mode="var_edit" match="text()"/>
+  <xsl:template mode="var_debug" match="text()"/>
   <xsl:variable name="project">
     <xsl:copy-of select="document('project')/project/*"/>
   </xsl:variable>
@@ -28,7 +16,6 @@
     <xsl:copy-of select="document('extensions')/extensions/*"/>
   </xsl:variable>
   <xsl:template name="add_root">
-    <xsl:param name="_indent" select="0"/>
     <xsl:param name="class"/>
     <xsl:param name="type"/>
     <xsl:param name="edit">
@@ -40,7 +27,6 @@
     <xsl:value-of select="ns:SetRoot($class, $type, $edit, $debug)"/>
   </xsl:template>
   <xsl:template match="ppx:pou">
-    <xsl:param name="_indent" select="0"/>
     <xsl:call-template name="add_root">
       <xsl:with-param name="class">
         <xsl:value-of select="@pouType"/>
@@ -49,37 +35,26 @@
         <xsl:value-of select="@name"/>
       </xsl:with-param>
     </xsl:call-template>
-    <xsl:apply-templates select="ppx:interface">
-      <xsl:with-param name="_indent" select="$_indent + (1) * $autoindent"/>
-    </xsl:apply-templates>
-    <xsl:apply-templates mode="variable_list" select="ppx:actions/ppx:action | ppx:transitions/ppx:transition">
-      <xsl:with-param name="_indent" select="$_indent + (1) * $autoindent"/>
-    </xsl:apply-templates>
+    <xsl:apply-templates select="ppx:interface"/>
+    <xsl:apply-templates mode="variable_list" select="ppx:actions/ppx:action | ppx:transitions/ppx:transition"/>
   </xsl:template>
   <xsl:template match="ppx:action">
-    <xsl:param name="_indent" select="0"/>
     <xsl:call-template name="add_root">
       <xsl:with-param name="class">
         <xsl:text>action</xsl:text>
       </xsl:with-param>
     </xsl:call-template>
-    <xsl:apply-templates select="ancestor::ppx:pou/child::ppx:interface">
-      <xsl:with-param name="_indent" select="$_indent + (1) * $autoindent"/>
-    </xsl:apply-templates>
+    <xsl:apply-templates select="ancestor::ppx:pou/child::ppx:interface"/>
   </xsl:template>
   <xsl:template match="ppx:transition">
-    <xsl:param name="_indent" select="0"/>
     <xsl:call-template name="add_root">
       <xsl:with-param name="class">
         <xsl:text>transition</xsl:text>
       </xsl:with-param>
     </xsl:call-template>
-    <xsl:apply-templates select="ancestor::ppx:pou/child::ppx:interface">
-      <xsl:with-param name="_indent" select="$_indent + (1) * $autoindent"/>
-    </xsl:apply-templates>
+    <xsl:apply-templates select="ancestor::ppx:pou/child::ppx:interface"/>
   </xsl:template>
   <xsl:template match="ppx:configuration">
-    <xsl:param name="_indent" select="0"/>
     <xsl:call-template name="add_root">
       <xsl:with-param name="class">
         <xsl:text>configuration</xsl:text>
@@ -88,15 +63,10 @@
         <xsl:text>false</xsl:text>
       </xsl:with-param>
     </xsl:call-template>
-    <xsl:apply-templates mode="variable_list" select="ppx:resource">
-      <xsl:with-param name="_indent" select="$_indent + (1) * $autoindent"/>
-    </xsl:apply-templates>
-    <xsl:apply-templates select="ppx:globalVars">
-      <xsl:with-param name="_indent" select="$_indent + (1) * $autoindent"/>
-    </xsl:apply-templates>
+    <xsl:apply-templates mode="variable_list" select="ppx:resource"/>
+    <xsl:apply-templates select="ppx:globalVars"/>
   </xsl:template>
   <xsl:template match="ppx:resource">
-    <xsl:param name="_indent" select="0"/>
     <xsl:call-template name="add_root">
       <xsl:with-param name="class">
         <xsl:text>resource</xsl:text>
@@ -105,45 +75,32 @@
         <xsl:text>false</xsl:text>
       </xsl:with-param>
     </xsl:call-template>
-    <xsl:apply-templates mode="variable_list" select="ppx:pouInstance | ppx:task/ppx:pouInstance">
-      <xsl:with-param name="_indent" select="$_indent + (1) * $autoindent"/>
-    </xsl:apply-templates>
-    <xsl:apply-templates select="ppx:globalVars">
-      <xsl:with-param name="_indent" select="$_indent + (1) * $autoindent"/>
-    </xsl:apply-templates>
+    <xsl:apply-templates mode="variable_list" select="ppx:pouInstance | ppx:task/ppx:pouInstance"/>
+    <xsl:apply-templates select="ppx:globalVars"/>
   </xsl:template>
   <xsl:template name="variables_infos">
-    <xsl:param name="_indent" select="0"/>
     <xsl:param name="var_class"/>
     <xsl:for-each select="ppx:variable">
       <xsl:variable name="class">
         <xsl:apply-templates mode="var_class" select="ppx:type">
-          <xsl:with-param name="_indent" select="$_indent + (1) * $autoindent"/>
           <xsl:with-param name="default_class">
             <xsl:value-of select="$var_class"/>
           </xsl:with-param>
         </xsl:apply-templates>
       </xsl:variable>
       <xsl:variable name="type">
-        <xsl:apply-templates mode="var_type" select="ppx:type">
-          <xsl:with-param name="_indent" select="$_indent + (1) * $autoindent"/>
-        </xsl:apply-templates>
+        <xsl:apply-templates mode="var_type" select="ppx:type"/>
       </xsl:variable>
       <xsl:variable name="edit">
-        <xsl:apply-templates mode="var_edit" select="ppx:type">
-          <xsl:with-param name="_indent" select="$_indent + (1) * $autoindent"/>
-        </xsl:apply-templates>
+        <xsl:apply-templates mode="var_edit" select="ppx:type"/>
       </xsl:variable>
       <xsl:variable name="debug">
-        <xsl:apply-templates mode="var_debug" select="ppx:type">
-          <xsl:with-param name="_indent" select="$_indent + (1) * $autoindent"/>
-        </xsl:apply-templates>
+        <xsl:apply-templates mode="var_debug" select="ppx:type"/>
       </xsl:variable>
       <xsl:value-of select="ns:AddVariable(@name, $class, $type, $edit, $debug)"/>
     </xsl:for-each>
   </xsl:template>
   <xsl:template match="ppx:localVars">
-    <xsl:param name="_indent" select="0"/>
     <xsl:call-template name="variables_infos">
       <xsl:with-param name="var_class">
         <xsl:text>Local</xsl:text>
@@ -151,7 +108,6 @@
     </xsl:call-template>
   </xsl:template>
   <xsl:template match="ppx:globalVars">
-    <xsl:param name="_indent" select="0"/>
     <xsl:call-template name="variables_infos">
       <xsl:with-param name="var_class">
         <xsl:text>Global</xsl:text>
@@ -159,7 +115,6 @@
     </xsl:call-template>
   </xsl:template>
   <xsl:template match="ppx:externalVars">
-    <xsl:param name="_indent" select="0"/>
     <xsl:call-template name="variables_infos">
       <xsl:with-param name="var_class">
         <xsl:text>External</xsl:text>
@@ -167,7 +122,6 @@
     </xsl:call-template>
   </xsl:template>
   <xsl:template match="ppx:tempVars">
-    <xsl:param name="_indent" select="0"/>
     <xsl:call-template name="variables_infos">
       <xsl:with-param name="var_class">
         <xsl:text>Temp</xsl:text>
@@ -175,7 +129,6 @@
     </xsl:call-template>
   </xsl:template>
   <xsl:template match="ppx:inputVars">
-    <xsl:param name="_indent" select="0"/>
     <xsl:call-template name="variables_infos">
       <xsl:with-param name="var_class">
         <xsl:text>Input</xsl:text>
@@ -183,7 +136,6 @@
     </xsl:call-template>
   </xsl:template>
   <xsl:template match="ppx:outputVars">
-    <xsl:param name="_indent" select="0"/>
     <xsl:call-template name="variables_infos">
       <xsl:with-param name="var_class">
         <xsl:text>Output</xsl:text>
@@ -191,7 +143,6 @@
     </xsl:call-template>
   </xsl:template>
   <xsl:template match="ppx:inOutVars">
-    <xsl:param name="_indent" select="0"/>
     <xsl:call-template name="variables_infos">
       <xsl:with-param name="var_class">
         <xsl:text>InOut</xsl:text>
@@ -199,7 +150,6 @@
     </xsl:call-template>
   </xsl:template>
   <xsl:template name="add_variable">
-    <xsl:param name="_indent" select="0"/>
     <xsl:param name="name"/>
     <xsl:param name="class"/>
     <xsl:param name="type"/>
@@ -212,7 +162,6 @@
     <xsl:value-of select="ns:AddVariable($name, $class, $type, $edit, $debug)"/>
   </xsl:template>
   <xsl:template mode="variable_list" match="ppx:action">
-    <xsl:param name="_indent" select="0"/>
     <xsl:call-template name="add_variable">
       <xsl:with-param name="name">
         <xsl:value-of select="@name"/>
@@ -223,7 +172,6 @@
     </xsl:call-template>
   </xsl:template>
   <xsl:template mode="variable_list" match="ppx:transition">
-    <xsl:param name="_indent" select="0"/>
     <xsl:call-template name="add_variable">
       <xsl:with-param name="name">
         <xsl:value-of select="@name"/>
@@ -234,7 +182,6 @@
     </xsl:call-template>
   </xsl:template>
   <xsl:template mode="variable_list" match="ppx:resource">
-    <xsl:param name="_indent" select="0"/>
     <xsl:call-template name="add_variable">
       <xsl:with-param name="name">
         <xsl:value-of select="@name"/>
@@ -248,7 +195,6 @@
     </xsl:call-template>
   </xsl:template>
   <xsl:template mode="variable_list" match="ppx:pouInstance">
-    <xsl:param name="_indent" select="0"/>
     <xsl:call-template name="add_variable">
       <xsl:with-param name="name">
         <xsl:value-of select="@name"/>
@@ -262,7 +208,6 @@
     </xsl:call-template>
   </xsl:template>
   <xsl:template mode="var_class" match="*[self::ppx:type or self::ppx:baseType]/ppx:derived">
-    <xsl:param name="_indent" select="0"/>
     <xsl:param name="default_class"/>
     <xsl:variable name="type_name" select="@name"/>
     <xsl:variable name="pou_infos">
@@ -270,9 +215,7 @@
     </xsl:variable>
     <xsl:choose>
       <xsl:when test="$pou_infos != ''">
-        <xsl:apply-templates mode="var_class" select="exsl:node-set($pou_infos)">
-          <xsl:with-param name="_indent" select="$_indent + (1) * $autoindent"/>
-        </xsl:apply-templates>
+        <xsl:apply-templates mode="var_class" select="exsl:node-set($pou_infos)"/>
       </xsl:when>
       <xsl:otherwise>
         <xsl:value-of select="$default_class"/>
@@ -280,20 +223,16 @@
     </xsl:choose>
   </xsl:template>
   <xsl:template mode="var_class" match="ppx:pou">
-    <xsl:param name="_indent" select="0"/>
     <xsl:value-of select="@pouType"/>
   </xsl:template>
   <xsl:template mode="var_class" match="*[self::ppx:type or self::ppx:baseType]/*">
-    <xsl:param name="_indent" select="0"/>
     <xsl:param name="default_class"/>
     <xsl:value-of select="$default_class"/>
   </xsl:template>
   <xsl:template mode="var_type" match="*[self::ppx:type or self::ppx:baseType]/ppx:derived">
-    <xsl:param name="_indent" select="0"/>
     <xsl:value-of select="@name"/>
   </xsl:template>
   <xsl:template mode="var_type" match="*[self::ppx:type or self::ppx:baseType]/ppx:array">
-    <xsl:param name="_indent" select="0"/>
     <xsl:text>ARRAY [</xsl:text>
     <xsl:for-each select="ppx:dimension">
       <xsl:value-of select="@lower"/>
@@ -301,24 +240,18 @@
       <xsl:value-of select="@upper"/>
     </xsl:for-each>
     <xsl:text>] OF </xsl:text>
-    <xsl:apply-templates mode="var_type" select="ppx:baseType">
-      <xsl:with-param name="_indent" select="$_indent + (1) * $autoindent"/>
-    </xsl:apply-templates>
+    <xsl:apply-templates mode="var_type" select="ppx:baseType"/>
   </xsl:template>
   <xsl:template mode="var_type" match="*[self::ppx:type or self::ppx:baseType]/ppx:string">
-    <xsl:param name="_indent" select="0"/>
     <xsl:text>STRING</xsl:text>
   </xsl:template>
   <xsl:template mode="var_type" match="*[self::ppx:type or self::ppx:baseType]/ppx:wstring">
-    <xsl:param name="_indent" select="0"/>
     <xsl:text>WSTRING</xsl:text>
   </xsl:template>
   <xsl:template mode="var_type" match="*[self::ppx:type or self::ppx:baseType]/*">
-    <xsl:param name="_indent" select="0"/>
     <xsl:value-of select="local-name()"/>
   </xsl:template>
   <xsl:template mode="var_edit" match="*[self::ppx:type or self::ppx:baseType]/ppx:derived">
-    <xsl:param name="_indent" select="0"/>
     <xsl:variable name="type_name" select="@name"/>
     <xsl:variable name="pou_infos">
       <xsl:copy-of select="exsl:node-set($project)/ppx:project/ppx:types/ppx:pous/ppx:pou[@name=$type_name]"/>
@@ -333,26 +266,19 @@
     </xsl:choose>
   </xsl:template>
   <xsl:template mode="var_edit" match="*[self::ppx:type or self::ppx:baseType]/ppx:array">
-    <xsl:param name="_indent" select="0"/>
-    <xsl:apply-templates mode="var_edit" select="ppx:baseType">
-      <xsl:with-param name="_indent" select="$_indent + (1) * $autoindent"/>
-    </xsl:apply-templates>
+    <xsl:apply-templates mode="var_edit" select="ppx:baseType"/>
   </xsl:template>
   <xsl:template mode="var_edit" match="*[self::ppx:type or self::ppx:baseType]/*">
-    <xsl:param name="_indent" select="0"/>
     <xsl:text>false</xsl:text>
   </xsl:template>
   <xsl:template mode="var_debug" match="*[self::ppx:type or self::ppx:baseType]/ppx:derived">
-    <xsl:param name="_indent" select="0"/>
     <xsl:variable name="type_name" select="@name"/>
     <xsl:variable name="datatype_infos">
       <xsl:copy-of select="exsl:node-set($project)/ppx:project/ppx:types/ppx:pous/ppx:pou[@name=$type_name] |&#10;                    exsl:node-set($project)/ppx:project/ppx:types/ppx:dataTypes/ppx:dataType[@name=$type_name] |&#10;                    exsl:node-set($stdlib)/ppx:project/ppx:types/ppx:dataTypes/ppx:dataType[@name=$type_name] |&#10;                    exsl:node-set($extensions)/ppx:project/ppx:types/ppx:dataTypes/ppx:dataType[@name=$type_name]"/>
     </xsl:variable>
     <xsl:choose>
       <xsl:when test="$datatype_infos != ''">
-        <xsl:apply-templates mode="var_debug" select="exsl:node-set($datatype_infos)">
-          <xsl:with-param name="_indent" select="$_indent + (1) * $autoindent"/>
-        </xsl:apply-templates>
+        <xsl:apply-templates mode="var_debug" select="exsl:node-set($datatype_infos)"/>
       </xsl:when>
       <xsl:otherwise>
         <xsl:text>false</xsl:text>
@@ -360,19 +286,15 @@
     </xsl:choose>
   </xsl:template>
   <xsl:template mode="var_debug" match="ppx:pou">
-    <xsl:param name="_indent" select="0"/>
     <xsl:text>true</xsl:text>
   </xsl:template>
   <xsl:template mode="var_debug" match="*[self::ppx:type or self::ppx:baseType]/ppx:array">
-    <xsl:param name="_indent" select="0"/>
     <xsl:text>false</xsl:text>
   </xsl:template>
   <xsl:template mode="var_debug" match="*[self::ppx:type or self::ppx:baseType]/ppx:struct">
-    <xsl:param name="_indent" select="0"/>
     <xsl:text>false</xsl:text>
   </xsl:template>
   <xsl:template mode="var_debug" match="*[self::ppx:type or self::ppx:baseType]/*">
-    <xsl:param name="_indent" select="0"/>
     <xsl:text>true</xsl:text>
   </xsl:template>
 </xsl:stylesheet>