--- a/PLCControler.py Wed Oct 09 22:01:21 2013 +0200
+++ b/PLCControler.py Wed Oct 09 23:06:47 2013 +0200
@@ -242,35 +242,13 @@
# Helpers object for generating instances path list
#-------------------------------------------------------------------------------
-class InstanceDefinition(etree.XSLTExtension):
+class InstancesPathFactory: - def __init__(self, controller, debug):
- etree.XSLTExtension.__init__(self)
- self.Controller = controller
- def execute(self, context, self_node, input_node, output_parent):
- instance_infos = etree.Element('infos')
- self.process_children(context, instance_infos)
+ def __init__(self, instances): + self.Instances = instances - pou_infos = self.Controller.GetPou(instance_infos.get("name"), self.Debug)
- if pou_infos is not None:
- pou_instance = etree.Element('pou_instance',
- pou_path=instance_infos.get("path"))
- pou_instance.append(deepcopy(pou_infos))
- self.apply_templates(context, pou_instance, output_parent)
- datatype_infos = self.Controller.GetDataType(instance_infos.get("name"), self.Debug)
- if datatype_infos is not None:
- datatype_instance = etree.Element('datatype_instance',
- datatype_path=instance_infos.get("path"))
- datatype_instance.append(deepcopy(datatype_infos))
- self.apply_templates(context, datatype_instance, output_parent)
-instances_path_xslt = etree.parse(
- os.path.join(ScriptDirectory, "plcopen", "instances_path.xslt"))
+ def AddInstance(self, context, *args): + self.Instances.append(args[0][0]) #-------------------------------------------------------------------------------
# Helpers object for generating instance tagname
@@ -795,14 +773,25 @@
def GetInstanceList(self, root, name, debug = False):
project = self.GetProject(debug)
+ factory = InstancesPathFactory(instances) + parser = etree.XMLParser() + parser.resolvers.add(LibraryResolver(self, debug)) instances_path_xslt_tree = etree.XSLT(
+ os.path.join(ScriptDirectory, "plcopen", "instances_path.xslt"), - ("instances_ns", "instance_definition"):
- InstanceDefinition(self, debug)})
+ ("instances_ns", "AddInstance"): factory.AddInstance}) - return instances_path_xslt_tree(root,
- instance_type=etree.XSLT.strparam(name)).getroot()
+ instances_path_xslt_tree(root, + instance_type=etree.XSLT.strparam(name)) def SearchPouInstances(self, tagname, debug = False):
@@ -810,10 +799,7 @@
words = tagname.split("::")
- result = self.GetInstanceList(project, words[1])
- return [instance.get("path") for instance in result]
+ return self.GetInstanceList(project, words[1]) --- a/plcopen/instances_path.xslt Wed Oct 09 22:01:21 2013 +0200
+++ b/plcopen/instances_path.xslt Wed Oct 09 23:06:47 2013 +0200
@@ -1,38 +1,55 @@
-<xsl:stylesheet version="1.0"
- xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
- xmlns:ppx="http://www.plcopen.org/xml/tc6_0201"
- xmlns:ns="instances_ns"
- extension-element-prefixes="ns"
- exclude-result-prefixes="ns">
+<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="instances_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:output method="xml"/> + <xsl:variable name="space" select="' '"/> + <xsl:param name="autoindent" select="4"/> <xsl:param name="instance_type"/>
+ <xsl:template match="text()"> + <xsl:param name="_indent" select="0"/> + <xsl:variable name="project"> + <xsl:copy-of select="document('project')/project/*"/> + <xsl:variable name="stdlib"> + <xsl:copy-of select="document('stdlib')/stdlib/*"/> + <xsl:variable name="extensions"> + <xsl:copy-of select="document('extensions')/extensions/*"/> <xsl:template match="ppx:project">
- <xsl:apply-templates select="ppx:instances/ppx:configurations/ppx:configuration"/>
+ <xsl:param name="_indent" select="0"/> + <xsl:apply-templates select="ppx:instances/ppx:configurations/ppx:configuration"> + <xsl:with-param name="_indent" select="$_indent + (1) * $autoindent"/> <xsl:template match="ppx:configuration">
- <xsl:apply-templates select="ppx:globalVars/ppx:variable[ppx:type/ppx:derived]">
- <xsl:with-param name="parent_path" select="@name"/>
- <xsl:apply-templates select="ppx:resource">
- <xsl:with-param name="parent_path" select="@name"/>
+ <xsl:param name="_indent" select="0"/> + <xsl:apply-templates select="ppx:globalVars/ppx:variable[ppx:type/ppx:derived] | ppx:resource"> + <xsl:with-param name="_indent" select="$_indent + (1) * $autoindent"/> + <xsl:with-param name="parent_path"> + <xsl:value-of select="@name"/> <xsl:template match="ppx:resource">
+ <xsl:param name="_indent" select="0"/> <xsl:param name="parent_path"/>
<xsl:variable name="resource_path">
<xsl:value-of select="$parent_path"/>
<xsl:value-of select="@name"/>
- <xsl:apply-templates select="ppx:globalVars/ppx:variable[ppx:type/ppx:derived]">
- <xsl:with-param name="parent_path" select="$resource_path"/>
- <xsl:apply-templates select="ppx:pouInstance | ppx:task/ppx:pouInstance">
- <xsl:with-param name="parent_path" select="$resource_path"/>
+ <xsl:apply-templates select="ppx:globalVars/ppx:variable[ppx:type/ppx:derived] | ppx:pouInstance | ppx:task/ppx:pouInstance"> + <xsl:with-param name="_indent" select="$_indent + (1) * $autoindent"/> + <xsl:with-param name="parent_path"> + <xsl:value-of select="$resource_path"/> <xsl:template match="ppx:pouInstance">
+ <xsl:param name="_indent" select="0"/> <xsl:param name="parent_path"/>
<xsl:variable name="pou_instance_path">
<xsl:value-of select="$parent_path"/>
@@ -41,37 +58,43 @@
<xsl:when test="@typeName=$instance_type">
- <xsl:attribute name="path">
- <xsl:value-of select="$pou_instance_path"/>
+ <xsl:value-of select="ns:AddInstance($pou_instance_path)"/> - <ns:instance_definition>
- <xsl:attribute name="name">
- <xsl:value-of select="@typeName"/>
- <xsl:attribute name="path">
+ <xsl:variable name="type_name"> + <xsl:value-of select="@typeName"/> + <xsl:apply-templates select="exsl:node-set($project)/ppx:project/ppx:types/ppx:pous/ppx:pou[@name=$type_name] | exsl:node-set($project)/ppx:project/ppx:types/ppx:dataTypes/ppx:dataType[@name=$type_name] | exsl:node-set($stdlib)/ppx:project/ppx:types/ppx:pous/ppx:pou[@name=$type_name] | exsl:node-set($stdlib)/ppx:project/ppx:types/ppx:dataTypes/ppx:dataType[@name=$type_name] | exsl:node-set($extensions)/ppx:project/ppx:types/ppx:pous/ppx:pou[@name=$type_name] | exsl:node-set($extensions)/ppx:project/ppx:types/ppx:dataTypes/ppx:dataType[@name=$type_name]"> + <xsl:with-param name="_indent" select="$_indent + (1) * $autoindent"/> + <xsl:with-param name="instance_path"> <xsl:value-of select="$pou_instance_path"/>
- </ns:instance_definition>
<xsl:template match="ppx:pou">
+ <xsl:param name="_indent" select="0"/> <xsl:param name="instance_path"/>
<xsl:apply-templates select="ppx:interface/*/ppx:variable[ppx:type/ppx:derived]">
- <xsl:with-param name="parent_path" select="$instance_path"/>
+ <xsl:with-param name="_indent" select="$_indent + (1) * $autoindent"/> + <xsl:with-param name="parent_path"> + <xsl:value-of select="$instance_path"/> <xsl:template match="ppx:dataType">
+ <xsl:param name="_indent" select="0"/> <xsl:param name="instance_path"/>
<xsl:apply-templates select="ppx:baseType/*[self::ppx:derived or self::ppx:struct or self::ppx:array]">
- <xsl:with-param name="parent_path" select="$instance_path"/>
+ <xsl:with-param name="_indent" select="$_indent + (1) * $autoindent"/> + <xsl:with-param name="parent_path"> + <xsl:value-of select="$instance_path"/> <xsl:template match="ppx:variable">
+ <xsl:param name="_indent" select="0"/> <xsl:param name="parent_path"/>
<xsl:variable name="variable_path">
<xsl:value-of select="$parent_path"/>
@@ -79,32 +102,34 @@
<xsl:value-of select="@name"/>
<xsl:apply-templates select="ppx:type/ppx:derived">
- <xsl:with-param name="variable_path" select="$variable_path"/>
+ <xsl:with-param name="_indent" select="$_indent + (1) * $autoindent"/> + <xsl:with-param name="variable_path"> + <xsl:value-of select="$variable_path"/> <xsl:template match="ppx:derived">
+ <xsl:param name="_indent" select="0"/> <xsl:param name="variable_path"/>
<xsl:when test="@name=$instance_type">
- <xsl:attribute name="path">
- <xsl:value-of select="$variable_path"/>
+ <xsl:value-of select="ns:AddInstance($variable_path)"/> - <ns:instance_definition>
- <xsl:attribute name="name">
- <xsl:value-of select="@name"/>
- <xsl:attribute name="path">
+ <xsl:variable name="type_name"> + <xsl:value-of select="@name"/> + <xsl:apply-templates select="exsl:node-set($project)/ppx:project/ppx:types/ppx:pous/ppx:pou[@name=$type_name] | exsl:node-set($project)/ppx:project/ppx:types/ppx:dataTypes/ppx:dataType[@name=$type_name] | exsl:node-set($stdlib)/ppx:project/ppx:types/ppx:pous/ppx:pou[@name=$type_name] | exsl:node-set($stdlib)/ppx:project/ppx:types/ppx:dataTypes/ppx:dataType[@name=$type_name] | exsl:node-set($extensions)/ppx:project/ppx:types/ppx:pous/ppx:pou[@name=$type_name] | exsl:node-set($extensions)/ppx:project/ppx:types/ppx:dataTypes/ppx:dataType[@name=$type_name]"> + <xsl:with-param name="_indent" select="$_indent + (1) * $autoindent"/> + <xsl:with-param name="instance_path"> <xsl:value-of select="$variable_path"/>
- </ns:instance_definition>
- <xsl:template name="ppx:struct">
+ <xsl:template match="ppx:struct"> + <xsl:param name="_indent" select="0"/> <xsl:param name="variable_path"/>
<xsl:for-each select="ppx:variable[ppx:type/ppx:derived or ppx:type/ppx:struct or ppx:type/ppx:array]">
<xsl:variable name="element_path">
@@ -112,26 +137,40 @@
<xsl:value-of select="@name"/>
- <xsl:apply-templates select="ppx:type/*[self::ppx:derived or self::ppx:struct or self::ppx:array]">
- <xsl:with-param name="variable_path" select="$element_path"/>
+ <xsl:apply-templates select="ppx:type/*[self::ppx:derived or self::ppx:struct or self::ppx:array]"> + <xsl:with-param name="_indent" select="$_indent + (1) * $autoindent"/> + <xsl:with-param name="variable_path"> + <xsl:value-of select="$element_path"/> - <xsl:template name="ppx:array">
+ <xsl:template match="ppx:array"> + <xsl:param name="_indent" select="0"/> <xsl:param name="variable_path"/>
<xsl:apply-templates select="ppx:baseType/*[self::ppx:derived or self::ppx:struct or self::ppx:array]">
- <xsl:with-param name="variable_path" select="$variable_path"/>
+ <xsl:with-param name="_indent" select="$_indent + (1) * $autoindent"/> + <xsl:with-param name="variable_path"> + <xsl:value-of select="$variable_path"/> <xsl:template match="pou_instance">
+ <xsl:param name="_indent" select="0"/> - <xsl:with-param name="instance_path" select="@pou_path"/>
+ <xsl:with-param name="_indent" select="$_indent + (1) * $autoindent"/> + <xsl:with-param name="instance_path"> + <xsl:value-of select="@pou_path"/> <xsl:template match="datatype_instance">
+ <xsl:param name="_indent" select="0"/> - <xsl:with-param name="instance_path" select="@datatype_path"/>
+ <xsl:with-param name="_indent" select="$_indent + (1) * $autoindent"/> + <xsl:with-param name="instance_path"> + <xsl:value-of select="@datatype_path"/> - <xsl:template match="text()"/>
\ No newline at end of file