Added sect1info templates and some customization hocks.
This commit is contained in:
parent
3778352091
commit
13b4ab5803
1 changed files with 111 additions and 20 deletions
131
LFS/lfs.xsl
131
LFS/lfs.xsl
|
@ -41,6 +41,29 @@
|
||||||
<!-- Locale setting -->
|
<!-- Locale setting -->
|
||||||
<xsl:param name="lang" select="C"/>
|
<xsl:param name="lang" select="C"/>
|
||||||
|
|
||||||
|
|
||||||
|
<!-- ####################################################################### -->
|
||||||
|
|
||||||
|
<!-- ########### NAMED USER TEMPLATES TO ALLOW CUSTOMIZATIONS ############## -->
|
||||||
|
|
||||||
|
<!-- Hock for user header additions -->
|
||||||
|
<xsl:template name="user_header">
|
||||||
|
<xsl:text>
</xsl:text>
|
||||||
|
</xsl:template>
|
||||||
|
|
||||||
|
|
||||||
|
<!-- Hock for user envars or extra commands before cd into the sources dir -->
|
||||||
|
<xsl:template name="user_pre_commands">
|
||||||
|
<xsl:text>
</xsl:text>
|
||||||
|
</xsl:template>
|
||||||
|
|
||||||
|
|
||||||
|
<!-- Hock for user footer additions -->
|
||||||
|
<xsl:template name="user_footer">
|
||||||
|
<xsl:text>
</xsl:text>
|
||||||
|
</xsl:template>
|
||||||
|
|
||||||
|
|
||||||
<!-- ####################################################################### -->
|
<!-- ####################################################################### -->
|
||||||
|
|
||||||
<!-- ########################### NAMED TEMPLATES ########################### -->
|
<!-- ########################### NAMED TEMPLATES ########################### -->
|
||||||
|
@ -66,6 +89,7 @@
|
||||||
|
|
||||||
<!-- Script header -->
|
<!-- Script header -->
|
||||||
<xsl:template name="header">
|
<xsl:template name="header">
|
||||||
|
<!-- Set the shabang -->
|
||||||
<xsl:choose>
|
<xsl:choose>
|
||||||
<xsl:when test="@id='ch-system-creatingdirs' or
|
<xsl:when test="@id='ch-system-creatingdirs' or
|
||||||
@id='ch-system-createfiles' or
|
@id='ch-system-createfiles' or
|
||||||
|
@ -76,14 +100,13 @@
|
||||||
<xsl:text>#!/bin/bash
</xsl:text>
|
<xsl:text>#!/bin/bash
</xsl:text>
|
||||||
</xsl:otherwise>
|
</xsl:otherwise>
|
||||||
</xsl:choose>
|
</xsl:choose>
|
||||||
|
<!-- Set +h -->
|
||||||
<xsl:text>set +h
</xsl:text>
|
<xsl:text>set +h
</xsl:text>
|
||||||
|
<!-- Set -e -->
|
||||||
<xsl:if test="not(@id='ch-tools-stripping') and
|
<xsl:if test="not(@id='ch-tools-stripping') and
|
||||||
not(@id='ch-system-strippingagain')">
|
not(@id='ch-system-strippingagain')">
|
||||||
<xsl:text>set -e
</xsl:text>
|
<xsl:text>set -e
</xsl:text>
|
||||||
</xsl:if>
|
</xsl:if>
|
||||||
|
|
||||||
<xsl:text>
</xsl:text>
|
<xsl:text>
</xsl:text>
|
||||||
</xsl:template>
|
</xsl:template>
|
||||||
|
|
||||||
|
@ -110,20 +133,40 @@
|
||||||
|
|
||||||
<!-- Script footer -->
|
<!-- Script footer -->
|
||||||
<xsl:template name="footer">
|
<xsl:template name="footer">
|
||||||
|
<!-- Dump the build time -->
|
||||||
<xsl:if test="not(@id='ch-system-chroot') and
|
<xsl:if test="not(@id='ch-system-chroot') and
|
||||||
not(@id='ch-system-revisedchroot')">
|
not(@id='ch-system-revisedchroot')">
|
||||||
<xsl:text>echo -e "\n\nTotalseconds: $SECONDS\n"
</xsl:text>
|
<xsl:text>

echo -e "\n\nTotalseconds: $SECONDS\n"
</xsl:text>
|
||||||
</xsl:if>
|
</xsl:if>
|
||||||
|
<!-- Exit -->
|
||||||
<xsl:text>exit
</xsl:text>
|
<xsl:text>
exit
</xsl:text>
|
||||||
</xsl:template>
|
</xsl:template>
|
||||||
|
|
||||||
|
|
||||||
|
<!-- Extract a package name from a package URL -->
|
||||||
|
<xsl:template name="package_name">
|
||||||
|
<xsl:param name="url" select="foo"/>
|
||||||
|
<xsl:param name="sub-url" select="substring-after($url,'/')"/>
|
||||||
|
<xsl:choose>
|
||||||
|
<xsl:when test="contains($sub-url,'/')">
|
||||||
|
<xsl:call-template name="package_name">
|
||||||
|
<xsl:with-param name="url" select="$sub-url"/>
|
||||||
|
</xsl:call-template>
|
||||||
|
</xsl:when>
|
||||||
|
<xsl:otherwise>
|
||||||
|
<xsl:value-of select="$sub-url"/>
|
||||||
|
</xsl:otherwise>
|
||||||
|
</xsl:choose>
|
||||||
|
</xsl:template>
|
||||||
|
|
||||||
|
|
||||||
<!-- ######################################################################## -->
|
<!-- ######################################################################## -->
|
||||||
|
|
||||||
<!-- ############################# MATCH TEMPLATES ########################## -->
|
<!-- ############################# MATCH TEMPLATES ########################## -->
|
||||||
|
|
||||||
<!-- Root element -->
|
<!-- Root element -->
|
||||||
<xsl:template match="/">
|
<xsl:template match="/">
|
||||||
|
<!-- Start processing at chapter level -->
|
||||||
<xsl:apply-templates select="//chapter"/>
|
<xsl:apply-templates select="//chapter"/>
|
||||||
</xsl:template>
|
</xsl:template>
|
||||||
|
|
||||||
|
@ -132,12 +175,10 @@
|
||||||
<xsl:template match="chapter">
|
<xsl:template match="chapter">
|
||||||
<xsl:if test="@id='chapter-temporary-tools' or @id='chapter-building-system'
|
<xsl:if test="@id='chapter-temporary-tools' or @id='chapter-building-system'
|
||||||
or @id='chapter-bootscripts' or @id='chapter-bootable'">
|
or @id='chapter-bootscripts' or @id='chapter-bootable'">
|
||||||
|
|
||||||
<!-- The dir name -->
|
<!-- The dir name -->
|
||||||
<xsl:variable name="dirname">
|
<xsl:variable name="dirname">
|
||||||
<xsl:call-template name="dirname"/>
|
<xsl:call-template name="dirname"/>
|
||||||
</xsl:variable>
|
</xsl:variable>
|
||||||
|
|
||||||
<!-- The chapter order position -->
|
<!-- The chapter order position -->
|
||||||
<xsl:variable name="ch_position" select="position()"/>
|
<xsl:variable name="ch_position" select="position()"/>
|
||||||
<xsl:variable name="ch_order">
|
<xsl:variable name="ch_order">
|
||||||
|
@ -151,34 +192,28 @@
|
||||||
</xsl:otherwise>
|
</xsl:otherwise>
|
||||||
</xsl:choose>
|
</xsl:choose>
|
||||||
</xsl:variable>
|
</xsl:variable>
|
||||||
|
<!-- Process the childrens -->
|
||||||
<xsl:apply-templates select="sect1">
|
<xsl:apply-templates select="sect1">
|
||||||
<xsl:with-param name="ch_order" select="$ch_order"/>
|
<xsl:with-param name="ch_order" select="$ch_order"/>
|
||||||
<xsl:with-param name="dirname" select="$dirname"/>
|
<xsl:with-param name="dirname" select="$dirname"/>
|
||||||
</xsl:apply-templates>
|
</xsl:apply-templates>
|
||||||
|
|
||||||
</xsl:if>
|
</xsl:if>
|
||||||
</xsl:template>
|
</xsl:template>
|
||||||
|
|
||||||
|
|
||||||
<!-- sect1 -->
|
<!-- sect1 -->
|
||||||
<xsl:template match="sect1">
|
<xsl:template match="sect1">
|
||||||
|
|
||||||
<!-- Inherited chapter order -->
|
<!-- Inherited chapter order -->
|
||||||
<xsl:param name="ch_order" select="foo"/>
|
<xsl:param name="ch_order" select="foo"/>
|
||||||
|
|
||||||
<!-- Inherited dir name -->
|
<!-- Inherited dir name -->
|
||||||
<xsl:param name="dirname" select="foo"/>
|
<xsl:param name="dirname" select="foo"/>
|
||||||
|
|
||||||
<xsl:if test="count(descendant::screen/userinput) > 0 and
|
<xsl:if test="count(descendant::screen/userinput) > 0 and
|
||||||
count(descendant::screen/userinput) >
|
count(descendant::screen/userinput) >
|
||||||
count(descendant::screen[@role='nodump'])">
|
count(descendant::screen[@role='nodump'])">
|
||||||
|
|
||||||
<!-- Base file name -->
|
<!-- Base file name -->
|
||||||
<xsl:variable name="filename">
|
<xsl:variable name="filename">
|
||||||
<xsl:call-template name="filename"/>
|
<xsl:call-template name="filename"/>
|
||||||
</xsl:variable>
|
</xsl:variable>
|
||||||
|
|
||||||
<!-- Sect1 order position -->
|
<!-- Sect1 order position -->
|
||||||
<xsl:variable name="sect1_position" select="position()"/>
|
<xsl:variable name="sect1_position" select="position()"/>
|
||||||
<xsl:variable name="sect1_order">
|
<xsl:variable name="sect1_order">
|
||||||
|
@ -192,34 +227,90 @@
|
||||||
</xsl:otherwise>
|
</xsl:otherwise>
|
||||||
</xsl:choose>
|
</xsl:choose>
|
||||||
</xsl:variable>
|
</xsl:variable>
|
||||||
|
|
||||||
<!-- Script build order -->
|
<!-- Script build order -->
|
||||||
<xsl:variable name="order" select="concat($ch_order,'_',$sect1_order)"/>
|
<xsl:variable name="order" select="concat($ch_order,'_',$sect1_order)"/>
|
||||||
|
|
||||||
<!-- Creating dirs and files -->
|
<!-- Creating dirs and files -->
|
||||||
<exsl:document href="{$dirname}/{$order}-{$filename}" method="text">
|
<exsl:document href="{$dirname}/{$order}-{$filename}" method="text">
|
||||||
<xsl:call-template name="header"/>
|
<xsl:call-template name="header"/>
|
||||||
|
<xsl:call-template name="user_header"/>
|
||||||
|
<xsl:apply-templates select="sect1info[@condition='script']">
|
||||||
|
<xsl:with-param name="phase" select="$filename"/>
|
||||||
|
</xsl:apply-templates>
|
||||||
|
<xsl:call-template name="user_pre_commands"/>
|
||||||
<xsl:call-template name="pre_commands"/>
|
<xsl:call-template name="pre_commands"/>
|
||||||
<xsl:apply-templates select=".//screen"/>
|
<xsl:apply-templates select=".//screen"/>
|
||||||
<xsl:call-template name="post_commands"/>
|
<xsl:call-template name="post_commands"/>
|
||||||
|
<xsl:call-template name="user_footer"/>
|
||||||
<xsl:call-template name="footer"/>
|
<xsl:call-template name="footer"/>
|
||||||
</exsl:document>
|
</exsl:document>
|
||||||
|
|
||||||
</xsl:if>
|
</xsl:if>
|
||||||
</xsl:template>
|
</xsl:template>
|
||||||
|
|
||||||
|
|
||||||
|
<!-- sect1info -->
|
||||||
|
<xsl:template match="sect1info">
|
||||||
|
<!-- Build phase (base file name) to be used for PM -->
|
||||||
|
<xsl:param name="phase" select="foo"/>
|
||||||
|
<xsl:text>
PKG_PHASE=</xsl:text>
|
||||||
|
<xsl:value-of select="$phase"/>
|
||||||
|
<!-- Package name -->
|
||||||
|
<xsl:apply-templates select="productname"/>
|
||||||
|
<!-- Package version -->
|
||||||
|
<xsl:apply-templates select="productnumber"/>
|
||||||
|
<!-- Tarball name -->
|
||||||
|
<xsl:apply-templates select="address"/>
|
||||||
|
<xsl:text>

</xsl:text>
|
||||||
|
</xsl:template>
|
||||||
|
|
||||||
|
|
||||||
|
<!-- productname -->
|
||||||
|
<xsl:template match="productname">
|
||||||
|
<xsl:text>
PACKAGE=</xsl:text>
|
||||||
|
<xsl:apply-templates/>
|
||||||
|
</xsl:template>
|
||||||
|
|
||||||
|
|
||||||
|
<!-- productnumber -->
|
||||||
|
<xsl:template match="productnumber">
|
||||||
|
<xsl:text>
VERSION=</xsl:text>
|
||||||
|
<xsl:apply-templates/>
|
||||||
|
</xsl:template>
|
||||||
|
|
||||||
|
|
||||||
|
<!-- address -->
|
||||||
|
<xsl:template match="address">
|
||||||
|
<xsl:text>
TARBALL=</xsl:text>
|
||||||
|
<xsl:call-template name="package_name">
|
||||||
|
<xsl:with-param name="url">
|
||||||
|
<xsl:apply-templates/>
|
||||||
|
</xsl:with-param>
|
||||||
|
</xsl:call-template>
|
||||||
|
<xsl:apply-templates select="otheraddr" mode="tarball"/>
|
||||||
|
</xsl:template>
|
||||||
|
|
||||||
|
|
||||||
|
<!-- otheraddr -->
|
||||||
|
<xsl:template match="otheraddr"/>
|
||||||
|
<xsl:template match="otheraddr" mode="tarball">
|
||||||
|
<xsl:text>
TARBALL_</xsl:text>
|
||||||
|
<xsl:value-of select="position()"/>
|
||||||
|
<xsl:text>=</xsl:text>
|
||||||
|
<xsl:call-template name="package_name">
|
||||||
|
<xsl:with-param name="url" select="."/>
|
||||||
|
</xsl:call-template>
|
||||||
|
</xsl:template>
|
||||||
|
|
||||||
|
|
||||||
|
<!-- screen -->
|
||||||
<xsl:template match="screen">
|
<xsl:template match="screen">
|
||||||
<xsl:if test="child::* = userinput and not(@role = 'nodump')">
|
<xsl:if test="child::* = userinput and not(@role = 'nodump')">
|
||||||
<xsl:apply-templates select="userinput" mode="screen"/>
|
<xsl:apply-templates select="userinput"/>
|
||||||
</xsl:if>
|
</xsl:if>
|
||||||
</xsl:template>
|
</xsl:template>
|
||||||
|
|
||||||
<xsl:template match="userinput" mode="screen">
|
|
||||||
|
<!-- userinput -->
|
||||||
|
<xsl:template match="userinput">
|
||||||
<xsl:choose>
|
<xsl:choose>
|
||||||
<!-- Estandarized package formats -->
|
<!-- Estandarized package formats -->
|
||||||
<xsl:when test="contains(string(),'tar.gz')">
|
<xsl:when test="contains(string(),'tar.gz')">
|
||||||
|
|
Reference in a new issue