Сначала нужно добавить второй шаблон, соответствующий entry
узлам, в котором есть genericData
, так как вам нужно будет повторить код для каждого такого узла
<xsl:template match="entry[value/genericData]">
<xsl:for-each select="value/genericData">
<xsl:call-template name="splitter">
<xsl:with-param name="path" select="identifier" />
</xsl:call-template>
</xsl:for-each>
</xsl:template>
Вам также необходимо настроитькод, который проверяет узлы-потомки entry
, чтобы он получал только первый уровень узлов entry
, а не всех потомков
<xsl:when test="self::genericData">
<xsl:apply-templates select="properties/entry" />
</xsl:when>
Попробуйте этот XSLT:
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" version="1.0">
<xsl:output method="xml" indent="yes"/>
<xsl:template match="@*|node()">
<xsl:copy>
<xsl:apply-templates select="@*|node()"/>
</xsl:copy>
</xsl:template>
<xsl:template match="entry">
<xsl:call-template name="splitter">
<xsl:with-param name="path" select="key" />
<xsl:with-param name="value" select="value" />
</xsl:call-template>
</xsl:template>
<xsl:template match="entry[value/genericData]">
<xsl:for-each select="value/genericData">
<xsl:call-template name="splitter">
<xsl:with-param name="path" select="identifier" />
</xsl:call-template>
</xsl:for-each>
</xsl:template>
<xsl:template name="splitter">
<xsl:param name="path" />
<xsl:param name="value" />
<xsl:choose>
<xsl:when test="contains($path, '/')">
<xsl:element name="{substring-before($path, '/')}">
<xsl:call-template name="splitter">
<xsl:with-param name="path" select="substring-after($path, '/')" />
<xsl:with-param name="value" select="$value" />
</xsl:call-template>
</xsl:element>
</xsl:when>
<xsl:otherwise>
<xsl:element name="{$path}">
<xsl:choose>
<xsl:when test="self::genericData">
<xsl:apply-templates select="properties/entry" />
</xsl:when>
<xsl:otherwise>
<xsl:value-of select="$value" />
</xsl:otherwise>
</xsl:choose>
</xsl:element>
</xsl:otherwise>
</xsl:choose>
</xsl:template>
</xsl:stylesheet>