SVGHMI: update generated XSLT files svghmi
authorEdouard Tisserant
Fri, 18 Jun 2021 11:47:55 +0200
branchsvghmi
changeset 3264 51645afeded9
parent 3263 1205b2d0acf2
child 3265 f3cb352048b6
SVGHMI: update generated XSLT files
svghmi/analyse_widget.xslt
svghmi/gen_dnd_widget_svg.xslt
svghmi/gen_index_xhtml.xslt
--- a/svghmi/analyse_widget.xslt	Fri Jun 18 11:47:33 2021 +0200
+++ b/svghmi/analyse_widget.xslt	Fri Jun 18 11:47:55 2021 +0200
@@ -121,6 +121,11 @@
             </path>
           </xsl:if>
         </xsl:for-each>
+        <xsl:if test="svg:desc">
+          <desc>
+            <xsl:value-of select="svg:desc/text()"/>
+          </desc>
+        </xsl:if>
       </widget>
     </xsl:if>
   </xsl:template>
--- a/svghmi/gen_dnd_widget_svg.xslt	Fri Jun 18 11:47:33 2021 +0200
+++ b/svghmi/gen_dnd_widget_svg.xslt	Fri Jun 18 11:47:55 2021 +0200
@@ -1,9 +1,8 @@
 <?xml version="1.0"?>
 <xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" xmlns:exsl="http://exslt.org/common" xmlns:regexp="http://exslt.org/regular-expressions" xmlns:str="http://exslt.org/strings" xmlns:func="http://exslt.org/functions" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:cc="http://creativecommons.org/ns#" xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" xmlns:svg="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd" xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape" xmlns:ns="beremiz" version="1.0" extension-element-prefixes="ns func exsl regexp str dyn" exclude-result-prefixes="ns func exsl regexp str dyn">
   <xsl:output method="xml"/>
-  <xsl:param name="hmi_path"/>
   <xsl:variable name="hmi_elements" select="//svg:*[starts-with(@inkscape:label, 'HMI:')]"/>
-  <xsl:variable name="subhmitree" select="ns:GetSubHMITree()"/>
+  <xsl:variable name="widgetparams" select="ns:GetWidgetParams()"/>
   <xsl:variable name="indexed_hmitree" select="/.."/>
   <xsl:variable name="pathregex" select="'^([^\[,]+)(\[[^\]]+\])?([\d,]*)$'"/>
   <xsl:template mode="parselabel" match="*">
@@ -124,6 +123,11 @@
             </path>
           </xsl:if>
         </xsl:for-each>
+        <xsl:if test="svg:desc">
+          <desc>
+            <xsl:value-of select="svg:desc/text()"/>
+          </desc>
+        </xsl:if>
       </widget>
     </xsl:if>
   </xsl:template>
@@ -151,20 +155,22 @@
     <xsl:apply-templates mode="parselabel" select="$hmi_elements"/>
   </xsl:variable>
   <xsl:variable name="parsed_widgets" select="exsl:node-set($_parsed_widgets)"/>
-  <xsl:variable name="selected_node_type" select="local-name($subhmitree)"/>
   <xsl:variable name="svg_widget" select="$parsed_widgets/widget[1]"/>
   <xsl:variable name="svg_widget_type" select="$svg_widget/@type"/>
   <xsl:variable name="svg_widget_path" select="$svg_widget/@path"/>
   <xsl:variable name="svg_widget_count" select="count($parsed_widgets/widget)"/>
-  <xsl:template mode="replace_path" match="@* | node()">
+  <xsl:template mode="replace_params" match="@* | node()">
     <xsl:copy>
-      <xsl:apply-templates mode="replace_path" select="@* | node()"/>
+      <xsl:apply-templates mode="replace_params" select="@* | node()"/>
     </xsl:copy>
   </xsl:template>
-  <xsl:template mode="replace_path" match="path/@value">
-    <xsl:attribute name="value">
-      <xsl:value-of select="$hmi_path"/>
-    </xsl:attribute>
+  <xsl:template mode="replace_params" match="arg"/>
+  <xsl:template mode="replace_params" match="path"/>
+  <xsl:template mode="replace_params" match="widget">
+    <xsl:copy>
+      <xsl:apply-templates mode="replace_params" select="@* | node()"/>
+      <xsl:copy-of select="$widgetparams/*"/>
+    </xsl:copy>
   </xsl:template>
   <xsl:template xmlns="http://www.w3.org/2000/svg" mode="inline_svg" match="@*">
     <xsl:copy/>
@@ -174,7 +180,7 @@
     <xsl:copy>
       <xsl:if test="@id = $svg_widget/@id">
         <xsl:variable name="substituted_widget">
-          <xsl:apply-templates mode="replace_path" select="$svg_widget"/>
+          <xsl:apply-templates mode="replace_params" select="$svg_widget"/>
         </xsl:variable>
         <xsl:variable name="substituted_widget_ns" select="exsl:node-set($substituted_widget)"/>
         <xsl:variable name="new_label">
@@ -187,8 +193,6 @@
       <xsl:apply-templates mode="inline_svg" select="@* | node()"/>
     </xsl:copy>
   </xsl:template>
-  <xsl:variable name="NODES_TYPES" select="str:split('HMI_ROOT HMI_NODE')"/>
-  <xsl:variable name="HMI_NODES_COMPAT" select="str:split('Page Jump Foreach')"/>
   <xsl:template match="/">
     <xsl:comment>
       <xsl:text>Widget dropped in Inkscape from Beremiz</xsl:text>
@@ -204,24 +208,7 @@
           <xsl:text>Multiple widget DnD not yet supported</xsl:text>
         </xsl:message>
       </xsl:when>
-      <xsl:when test="$selected_node_type = $NODES_TYPES and                     not($svg_widget_type = $HMI_NODES_COMPAT)">
-        <xsl:message terminate="yes">
-          <xsl:text>Widget incompatible with selected HMI tree node</xsl:text>
-        </xsl:message>
-      </xsl:when>
     </xsl:choose>
-    <xsl:variable name="testmsg">
-      <msg>
-        <xsl:value-of select="$hmi_path"/>
-      </msg>
-      <msg>
-        <xsl:value-of select="$selected_node_type"/>
-      </msg>
-      <msg>
-        <xsl:value-of select="$svg_widget_type"/>
-      </msg>
-    </xsl:variable>
-    <xsl:value-of select="ns:PassMessage($testmsg)"/>
     <xsl:apply-templates mode="inline_svg" select="/"/>
   </xsl:template>
 </xsl:stylesheet>
--- a/svghmi/gen_index_xhtml.xslt	Fri Jun 18 11:47:33 2021 +0200
+++ b/svghmi/gen_index_xhtml.xslt	Fri Jun 18 11:47:55 2021 +0200
@@ -1,6 +1,6 @@
 <?xml version="1.0"?>
-<xsl:stylesheet xmlns:ns="beremiz" xmlns:definitions="definitions" xmlns:xhtml="http://www.w3.org/1999/xhtml" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:func="http://exslt.org/functions" xmlns:epilogue="epilogue" xmlns:preamble="preamble" xmlns:xlink="http://www.w3.org/1999/xlink" xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd" xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape" xmlns:svg="http://www.w3.org/2000/svg" xmlns:cc="http://creativecommons.org/ns#" xmlns:xsl="http://www.w3.org/1999/XSL/Transform" xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" xmlns:str="http://exslt.org/strings" xmlns:regexp="http://exslt.org/regular-expressions" xmlns:exsl="http://exslt.org/common" xmlns:declarations="declarations" xmlns:debug="debug" exclude-result-prefixes="ns func exsl regexp str dyn debug preamble epilogue declarations definitions" extension-element-prefixes="ns func exsl regexp str dyn" version="1.0">
-  <xsl:output method="xml" cdata-section-elements="xhtml:script"/>
+<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" xmlns:exsl="http://exslt.org/common" xmlns:regexp="http://exslt.org/regular-expressions" xmlns:str="http://exslt.org/strings" xmlns:func="http://exslt.org/functions" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:cc="http://creativecommons.org/ns#" xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" xmlns:svg="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd" xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape" xmlns:xhtml="http://www.w3.org/1999/xhtml" xmlns:debug="debug" xmlns:preamble="preamble" xmlns:declarations="declarations" xmlns:definitions="definitions" xmlns:epilogue="epilogue" xmlns:ns="beremiz" version="1.0" extension-element-prefixes="ns func exsl regexp str dyn" exclude-result-prefixes="ns func exsl regexp str dyn debug preamble epilogue declarations definitions">
+  <xsl:output cdata-section-elements="xhtml:script" method="xml"/>
   <xsl:variable name="svg" select="/svg:svg"/>
   <xsl:variable name="hmi_elements" select="//svg:*[starts-with(@inkscape:label, 'HMI:')]"/>
   <xsl:variable name="hmitree" select="ns:GetHMITree()"/>
@@ -255,6 +255,11 @@
             </path>
           </xsl:if>
         </xsl:for-each>
+        <xsl:if test="svg:desc">
+          <desc>
+            <xsl:value-of select="svg:desc/text()"/>
+          </desc>
+        </xsl:if>
       </widget>
     </xsl:if>
   </xsl:template>
@@ -1743,7 +1748,7 @@
 </xsl:text>
   </xsl:template>
   <xsl:variable name="excluded_types" select="str:split('Page VarInit VarInitPersistent')"/>
-  <xsl:key use="@type" name="TypesKey" match="widget"/>
+  <xsl:key name="TypesKey" match="widget" use="@type"/>
   <declarations:hmi-classes/>
   <xsl:template match="declarations:hmi-classes">
     <xsl:text>
@@ -7446,9 +7451,9 @@
     <xsl:comment>
       <xsl:text>Made with SVGHMI. https://beremiz.org</xsl:text>
     </xsl:comment>
-    <html xmlns:svg="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" xmlns="http://www.w3.org/1999/xhtml">
+    <html xmlns="http://www.w3.org/1999/xhtml" xmlns:svg="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
       <head>
-        <style media="screen" type="text/css">
+        <style type="text/css" media="screen">
           <xsl:value-of select="ns:GetFonts()"/>
         </style>
       </head>