From: Lady <redacted> Date: Sat, 20 Jan 2024 17:02:11 +0000 (-0500) Subject: Better wrapper support for plural result trees X-Git-Tag: 0.4.2~1 X-Git-Url: https://git.ladys.computer/Shushe/commitdiff_plain/3b97090500b8714bd32d01e4e4ac2c10cdbdf713?ds=inline Better wrapper support for plural result trees It’s not unsensible for a result tree to consist of both a `<html:body>` and an `<html:head>` without a wrapping `<html:html>` element, assuming that the result is going to be wrapped. This commit improves support for this pattern in the wrapper. --- diff --git a/lib/catalog2transform.xslt b/lib/catalog2transform.xslt index 22e71c8..1d36bb1 100644 --- a/lib/catalog2transform.xslt +++ b/lib/catalog2transform.xslt @@ -122,7 +122,7 @@ If a copy of the M·P·L was not distributed with this file, You can obtain one <xslt:template match="text()" mode="书社:metadata"/> <xslt:template match="/" mode="书社:wrap"> <xslt:variable name="metadata"> - <xslt:copy-of select="html:html/html:head/node()"/> + <xslt:copy-of select="html:html/html:head/node()|html:head/node()"/> <xslt:apply-templates select="." mode="书社:metadata"/> <xslt:apply-templates select="document('')/xslt:transform/xslt:include" mode="书社:metadata"/> </xslt:variable> @@ -132,15 +132,25 @@ If a copy of the M·P·L was not distributed with this file, You can obtain one <xslt:value-of select="$VERSION"/> </xslt:attribute> </xslt:if> - <xslt:copy-of select="html:html/@*|*/@xml:lang|html:*/@lang|svg:*/@lang"/> + <xslt:copy-of select="html:html/@*"/> + <xslt:if test="not(html:html/@lang) and (html:*/@lang|svg:*/@lang|*/@xml:lang)"> + <xslt:attribute name="lang"> + <xslt:value-of select="html:*/@lang|svg:*/@lang|*/@xml:lang"/> + </xslt:attribute> + </xslt:if> + <xslt:if test="not(html:html/@xml:lang) and (html:*/@lang|svg:*/@lang|*/@xml:lang)"> + <xslt:attribute name="xml:lang"> + <xslt:value-of select="html:*/@lang|svg:*/@lang|*/@xml:lang"/> + </xslt:attribute> + </xslt:if> <html:head> - <xslt:copy-of select="html:html/html:head/@*"/> + <xslt:copy-of select="html:html/html:head/@*|html:head/@*"/> <html:title> <xslt:for-each select="exsl:node-set($metadata)/html:title"> <xslt:value-of select="."/> </xslt:for-each> </html:title> - <xslt:copy-of select="exsl:node-set($metadata)/node()[self::comment() or self::* and not(self::html:title)]"/> + <xslt:copy-of select="exsl:node-set($metadata)/node()[not(self::*) or not(self::html:title)]"/> <xslt:if test="not(exsl:node-set($metadata)/html:meta[@name='generator'])"> <html:meta name="generator"> <xslt:attribute name="content"> @@ -158,7 +168,7 @@ If a copy of the M·P·L was not distributed with this file, You can obtain one <xslt:copy-of select="html:html/html:body/@*|html:body/@*"/> <xslt:apply-templates select="document('')/xslt:transform/xslt:include" mode="书社:header"/> <xslt:apply-templates select="." mode="书社:header"/> - <xslt:copy-of select="node()[not(self::html:html or self::html:body)]|html:html/node()[not(self::html:head or self::html:body)]|html:html/html:body/node()|html:body/node()"/> + <xslt:copy-of select="node()[not(self::html:html or self::html:head or self::html:body)]|html:html/node()[not(self::html:head or self::html:body)]|html:html/html:body/node()|html:body/node()"/> <xslt:apply-templates select="." mode="书社:footer"/> <xslt:apply-templates select="document('')/xslt:transform/xslt:include" mode="书社:footer"/> </html:body>