diff options
Diffstat (limited to 'stylesheets/patcheslist.xsl')
-rw-r--r-- | stylesheets/patcheslist.xsl | 73 |
1 files changed, 30 insertions, 43 deletions
diff --git a/stylesheets/patcheslist.xsl b/stylesheets/patcheslist.xsl index a8496b6c0..9662b04ac 100644 --- a/stylesheets/patcheslist.xsl +++ b/stylesheets/patcheslist.xsl @@ -4,65 +4,52 @@ %general-entities; ]> -<!-- To work against BLFS some changes are needed --> - <xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" version="1.0"> <xsl:output method="text"/> - <xsl:param name="links.directory"> - <xsl:value-of select="substring-after('&patches-root;', 'patches/')"/> + <!-- Allow select the dest dir at runtime --> + <xsl:param name="dest.dir"> + <xsl:value-of select="concat('/home/httpd/', substring-after('&patches-root;', 'http://'))"/> </xsl:param> <xsl:template match="/"> - <xsl:text>#! /bin/bash
</xsl:text> - <xsl:text>
 cd /home/httpd/</xsl:text> - <xsl:value-of select="substring-after('&patches-root;', 'http://')"/> + <xsl:text>#! /bin/bash

</xsl:text> + <!-- Create dest.dir if it don't exist --> + <xsl:text> mkdir -p </xsl:text> + <xsl:value-of select="$dest.dir"/> + <xsl:text> &&
</xsl:text> + <xsl:text> cd </xsl:text> + <xsl:value-of select="$dest.dir"/> <xsl:text> &&

</xsl:text> - <xsl:text> rm -f *.patch &&

</xsl:text> + <!-- Touch a dummy patch to prevent fails if dest dir is empty, then remove old patches --> + <xsl:text> touch dummy.patch &&
 rm -f *.patch &&

</xsl:text> <xsl:apply-templates/> + <!-- Ensure correct owneship --> <xsl:text>
 chgrp lfswww *.patch &&
</xsl:text> <xsl:text>
 exit
</xsl:text> </xsl:template> - <xsl:template match="//text()"> - <xsl:text/> - </xsl:template> + <xsl:template match="//text()"/> <xsl:template match="//ulink"> - <xsl:if test="contains(@url, '.patch') and contains(@url, '&patches-root;')"> - <xsl:choose> - <xsl:when test="ancestor-or-self::*/@condition = 'pdf'"/> - <xsl:otherwise> - <xsl:text> cp </xsl:text> - <xsl:text>/home/httpd/</xsl:text> - <xsl:value-of select="substring-before (substring-after ('&patches-root;', 'http://'), $links.directory)"/> - <xsl:text>downloads/</xsl:text> - <xsl:if test="contains (@url, '-')"> - <xsl:variable name="cut" select="translate (@url, '0123456789', '2222222222')"/> - <xsl:variable name="links.directory2" select="translate ($links.directory, '0123456789', '2222222222')"/> - <xsl:choose> - <xsl:when test="contains ($cut, ',')"> - <xsl:value-of select="substring-before (substring-after($cut, $links.directory2), ',2')"/> - </xsl:when> - <xsl:otherwise> - <xsl:choose> - <xsl:when test="contains ($cut, '-src-2')"> - <xsl:value-of select="substring-before (substring-after($cut, $links.directory2), '-src-2')"/> - </xsl:when> - <xsl:otherwise> - <xsl:value-of select="substring-before (substring-after($cut, $links.directory2), '-2')"/> - </xsl:otherwise> - </xsl:choose> - </xsl:otherwise> - </xsl:choose> - </xsl:if> - <xsl:text>/</xsl:text> - <xsl:value-of select="substring-after(@url, $links.directory)"/> - <xsl:text> . 
</xsl:text> - </xsl:otherwise> - </xsl:choose> + <!-- Match only local patches links and skip duplicated URLs splitted for PDF output--> + <xsl:if test="contains(@url, '.patch') and contains(@url, '&patches-root;') + and not(ancestor-or-self::*/@condition = 'pdf')"> + <xsl:variable name="patch.name" select="substring-after(@url, '&patches-root;')"/> + <xsl:variable name="cut" + select="translate(substring-after($patch.name, '-'), '0123456789', '0000000000')"/> + <xsl:variable name="patch.name2"> + <xsl:value-of select="substring-before($patch.name, '-')"/> + <xsl:text>-</xsl:text> + <xsl:value-of select="$cut"/> + </xsl:variable> + <xsl:text> cp /home/httpd/www.linuxfromscratch.org/patches/downloads/</xsl:text> + <xsl:value-of select="substring-before($patch.name2, '-0')"/> + <xsl:text>/</xsl:text> + <xsl:value-of select="$patch.name"/> + <xsl:text> . 
</xsl:text> </xsl:if> </xsl:template> |