diff options
author | Jeremy Huntwork <jhuntwork@linuxfromscratch.org> | 2006-12-04 04:48:25 +0000 |
---|---|---|
committer | Jeremy Huntwork <jhuntwork@linuxfromscratch.org> | 2006-12-04 04:48:25 +0000 |
commit | 3a4594b22c7ad36dac6687b920decabed2c287ae (patch) | |
tree | f89d2922270ea4636d1d44fd5939389ff3dc163f /stylesheets/wget-list.xsl | |
parent | 3d8a36219be2f6e535817ec37da9f16f19ea4da5 (diff) |
Added a stylesheet and Makefile target that will allow the dynamic creation of a wget-list.
Stylesheet is modified from jhalfs-2.0.
This will be useful to our current FTP maintainer in dynamically collecting packages.
git-svn-id: http://svn.linuxfromscratch.org/LFS/trunk/BOOK@7878 4aa44e1e-78dd-0310-a6d2-fbcd4c07a689
Diffstat (limited to 'stylesheets/wget-list.xsl')
-rw-r--r-- | stylesheets/wget-list.xsl | 74 |
1 files changed, 74 insertions, 0 deletions
diff --git a/stylesheets/wget-list.xsl b/stylesheets/wget-list.xsl new file mode 100644 index 000000000..d0da2bd3b --- /dev/null +++ b/stylesheets/wget-list.xsl @@ -0,0 +1,74 @@ +<?xml version='1.0' encoding='ISO-8859-1'?> + +<!-- $Id$ --> + +<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" + version="1.0"> + + <xsl:output method="text"/> + + <!-- The FTP server used as fallback --> + <xsl:param name="server">ftp://ftp.osuosl.org</xsl:param> + + <!-- The libc model used for HLFS --> + <xsl:param name="model" select="glibc"/> + + <xsl:template match="/"> + <xsl:apply-templates select="//ulink"/> + </xsl:template> + + <xsl:template match="ulink"> + <!-- If some package don't have the predefined strings in their + name, the next test must be fixed to match it also. Skip possible + duplicated URLs due that may be splitted for PDF output --> + <xsl:if test="(ancestor::varlistentry[@condition=$model] + or not(ancestor::varlistentry[@condition])) and + (contains(@url, '.tar.') or contains(@url, '.tgz') + or contains(@url, '.patch')) and + not(ancestor-or-self::*/@condition = 'pdf')"> + <!-- Extract the package name --> + <xsl:variable name="package"> + <xsl:call-template name="package.name"> + <xsl:with-param name="url" select="@url"/> + </xsl:call-template> + </xsl:variable> + <!-- Extract the directory for that package --> + <xsl:variable name="cut" + select="translate(substring-after($package, '-'), + '0123456789', '0000000000')"/> + <xsl:variable name="package2"> + <xsl:value-of select="substring-before($package, '-')"/> + <xsl:text>-</xsl:text> + <xsl:value-of select="$cut"/> + </xsl:variable> + <xsl:variable name="dirname" select="substring-before($package2, '-0')"/> + <!-- Write the upstream URLs, except the redirected ones --> + <xsl:value-of select="@url"/> + <xsl:text> </xsl:text> + <xsl:text>
</xsl:text> + </xsl:if> + </xsl:template> + + <xsl:template name="package.name"> + <xsl:param name="url"/> + <xsl:choose> + <xsl:when test="contains($url, '/')"> + <xsl:call-template name="package.name"> + <xsl:with-param name="url" select="substring-after($url, '/')"/> + </xsl:call-template> + </xsl:when> + <xsl:otherwise> + <xsl:choose> + <xsl:when test="contains($url, '?')"> + <xsl:value-of select="substring-before($url, '?')"/> + </xsl:when> + <xsl:otherwise> + <xsl:value-of select="$url"/> + </xsl:otherwise> + </xsl:choose> + </xsl:otherwise> + </xsl:choose> + </xsl:template> + +</xsl:stylesheet> + |