--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/plcopen/instances_path.xslt Mon Nov 18 12:12:31 2013 +0900
@@ -0,0 +1,158 @@
+<?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="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:template>
+ <xsl:variable name="project">
+ <xsl:copy-of select="document('project')/project/*"/>
+ </xsl:variable>
+ <xsl:variable name="stdlib">
+ <xsl:copy-of select="document('stdlib')/stdlib/*"/>
+ </xsl:variable>
+ <xsl:variable name="extensions">
+ <xsl:copy-of select="document('extensions')/extensions/*"/>
+ </xsl:variable>
+ <xsl:template match="ppx:project">
+ <xsl:param name="_indent" select="0"/>
+ <instances>
+ <xsl:apply-templates select="ppx:instances/ppx:configurations/ppx:configuration">
+ <xsl:with-param name="_indent" select="$_indent + (1) * $autoindent"/>
+ </xsl:apply-templates>
+ </instances>
+ </xsl:template>
+ <xsl:template match="ppx:configuration">
+ <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:with-param>
+ </xsl:apply-templates>
+ </xsl:template>
+ <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:text>.</xsl:text>
+ <xsl:value-of select="@name"/>
+ </xsl:variable>
+ <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:with-param>
+ </xsl:apply-templates>
+ </xsl:template>
+ <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"/>
+ <xsl:text>.</xsl:text>
+ <xsl:value-of select="@name"/>
+ </xsl:variable>
+ <xsl:choose>
+ <xsl:when test="@typeName=$instance_type">
+ <xsl:value-of select="ns:AddInstance($pou_instance_path)"/>
+ </xsl:when>
+ <xsl:otherwise>
+ <xsl:variable name="type_name">
+ <xsl:value-of select="@typeName"/>
+ </xsl:variable>
+ <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"/>
+ </xsl:with-param>
+ </xsl:apply-templates>
+ </xsl:otherwise>
+ </xsl:choose>
+ </xsl:template>
+ <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="_indent" select="$_indent + (1) * $autoindent"/>
+ <xsl:with-param name="parent_path">
+ <xsl:value-of select="$instance_path"/>
+ </xsl:with-param>
+ </xsl:apply-templates>
+ </xsl:template>
+ <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="_indent" select="$_indent + (1) * $autoindent"/>
+ <xsl:with-param name="parent_path">
+ <xsl:value-of select="$instance_path"/>
+ </xsl:with-param>
+ </xsl:apply-templates>
+ </xsl:template>
+ <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"/>
+ <xsl:text>.</xsl:text>
+ <xsl:value-of select="@name"/>
+ </xsl:variable>
+ <xsl:apply-templates select="ppx:type/ppx:derived">
+ <xsl:with-param name="_indent" select="$_indent + (1) * $autoindent"/>
+ <xsl:with-param name="variable_path">
+ <xsl:value-of select="$variable_path"/>
+ </xsl:with-param>
+ </xsl:apply-templates>
+ </xsl:template>
+ <xsl:template match="ppx:derived">
+ <xsl:param name="_indent" select="0"/>
+ <xsl:param name="variable_path"/>
+ <xsl:choose>
+ <xsl:when test="@name=$instance_type">
+ <xsl:value-of select="ns:AddInstance($variable_path)"/>
+ </xsl:when>
+ <xsl:otherwise>
+ <xsl:variable name="type_name">
+ <xsl:value-of select="@name"/>
+ </xsl:variable>
+ <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"/>
+ </xsl:with-param>
+ </xsl:apply-templates>
+ </xsl:otherwise>
+ </xsl:choose>
+ </xsl:template>
+ <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">
+ <xsl:value-of select="$variable_path"/>
+ <xsl:text>.</xsl:text>
+ <xsl:value-of select="@name"/>
+ </xsl:variable>
+ </xsl:for-each>
+ <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:with-param>
+ </xsl:apply-templates>
+ </xsl:template>
+ <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="_indent" select="$_indent + (1) * $autoindent"/>
+ <xsl:with-param name="variable_path">
+ <xsl:value-of select="$variable_path"/>
+ </xsl:with-param>
+ </xsl:apply-templates>
+ </xsl:template>
+</xsl:stylesheet>