aboutsummaryrefslogtreecommitdiffstats
path: root/stylesheets/lfs-xsl/pdf
diff options
context:
space:
mode:
authorManuel Canales Esparcia <manuel@linuxfromscratch.org>2007-07-05 21:18:33 +0000
committerManuel Canales Esparcia <manuel@linuxfromscratch.org>2007-07-05 21:18:33 +0000
commitc873d8072e3e1fb78b1be4ba5e3f8e3548d29694 (patch)
treefb2387ca1b158477659e00660269c92b94f4a00a /stylesheets/lfs-xsl/pdf
parentbdbaf3eb1f0b1c8ef150764638c7473b9c25db96 (diff)
Added new-xsl files.
git-svn-id: http://svn.linuxfromscratch.org/LFS/trunk/BOOK@8196 4aa44e1e-78dd-0310-a6d2-fbcd4c07a689
Diffstat (limited to 'stylesheets/lfs-xsl/pdf')
-rw-r--r--stylesheets/lfs-xsl/pdf/lfs-admon.xsl81
-rw-r--r--stylesheets/lfs-xsl/pdf/lfs-index.xsl140
-rw-r--r--stylesheets/lfs-xsl/pdf/lfs-lists.xsl174
-rw-r--r--stylesheets/lfs-xsl/pdf/lfs-mixed.xsl360
-rw-r--r--stylesheets/lfs-xsl/pdf/lfs-pagesetup.xsl249
-rw-r--r--stylesheets/lfs-xsl/pdf/lfs-xref.xsl169
6 files changed, 1173 insertions, 0 deletions
diff --git a/stylesheets/lfs-xsl/pdf/lfs-admon.xsl b/stylesheets/lfs-xsl/pdf/lfs-admon.xsl
new file mode 100644
index 000000000..14a0b80d8
--- /dev/null
+++ b/stylesheets/lfs-xsl/pdf/lfs-admon.xsl
@@ -0,0 +1,81 @@
+<?xml version='1.0' encoding='ISO-8859-1'?>
+
+<!--
+$LastChangedBy$
+$Date$
+-->
+
+<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
+ xmlns:fo="http://www.w3.org/1999/XSL/Format"
+ version="1.0">
+
+ <!-- This stylesheet controls how admonitions are displayed -->
+
+ <!-- Use graphics in admonitions? 1 = yes, 0 = no -->
+ <xsl:param name="admon.graphics" select="1"/>
+
+ <!-- Path to admonition graphics relative to index.xml -->
+ <xsl:param name="admon.graphics.path" select="'images/'"/>
+
+ <!-- Global admonitions properties -->
+ <xsl:attribute-set name="graphical.admonition.properties">
+ <xsl:attribute name="keep-together.within-column">
+ <xsl:variable name="keep.together">
+ <xsl:call-template name="pi.dbfo_keep-together"/>
+ </xsl:variable>
+ <xsl:choose>
+ <xsl:when test="$keep.together != ''">
+ <xsl:value-of select="$keep.together"/>
+ </xsl:when>
+ <xsl:otherwise>always</xsl:otherwise>
+ </xsl:choose>
+ </xsl:attribute>
+ <xsl:attribute name="space-before.optimum">0.6em</xsl:attribute>
+ <xsl:attribute name="space-before.minimum">0.4em</xsl:attribute>
+ <xsl:attribute name="space-before.maximum">0.8em</xsl:attribute>
+ <xsl:attribute name="space-after.optimum">0.6em</xsl:attribute>
+ <xsl:attribute name="space-after.minimum">0.4em</xsl:attribute>
+ <xsl:attribute name="space-after.maximum">0.8em</xsl:attribute>
+ <xsl:attribute name="padding-start">5pt</xsl:attribute>
+ <xsl:attribute name="padding-top">5pt</xsl:attribute>
+ <xsl:attribute name="padding-bottom">5pt</xsl:attribute>
+ <xsl:attribute name="border-style">solid</xsl:attribute>
+ <xsl:attribute name="border-width">0.5pt</xsl:attribute>
+ <xsl:attribute name="background-color">#FFFFE6</xsl:attribute>
+ <xsl:attribute name="border-color">
+ <xsl:choose>
+ <xsl:when test="self::note | self::tip">#E0E0E0</xsl:when>
+ <xsl:otherwise>#DCC</xsl:otherwise>
+ </xsl:choose>
+ </xsl:attribute>
+ </xsl:attribute-set>
+
+ <!-- Properties for admonitions titles -->
+ <xsl:attribute-set name="admonition.title.properties">
+ <xsl:attribute name="font-size">14pt</xsl:attribute>
+ <xsl:attribute name="font-weight">bold</xsl:attribute>
+ <xsl:attribute name="hyphenate">false</xsl:attribute>
+ <xsl:attribute name="keep-with-next.within-column">always</xsl:attribute>
+ <xsl:attribute name="color">
+ <xsl:choose>
+ <xsl:when test="ancestor-or-self::important | ancestor-or-self::warning
+ | ancestor-or-self::caution">#500</xsl:when>
+ <xsl:otherwise>#000</xsl:otherwise>
+ </xsl:choose>
+ </xsl:attribute>
+ </xsl:attribute-set>
+
+ <!-- Properties for admonitions text -->
+ <xsl:attribute-set name="admonition.properties">
+ <xsl:attribute name="margin-right">5pt</xsl:attribute>
+ </xsl:attribute-set>
+
+ <!-- admon.graphic.width:
+ Making the graphic smaller. -->
+ <!-- The original template is in {docbook-xsl}/fo/admon.xsl -->
+ <xsl:template match="*" mode="admon.graphic.width">
+ <xsl:param name="node" select="."/>
+ <xsl:text>24pt</xsl:text>
+ </xsl:template>
+
+</xsl:stylesheet>
diff --git a/stylesheets/lfs-xsl/pdf/lfs-index.xsl b/stylesheets/lfs-xsl/pdf/lfs-index.xsl
new file mode 100644
index 000000000..4d0d79463
--- /dev/null
+++ b/stylesheets/lfs-xsl/pdf/lfs-index.xsl
@@ -0,0 +1,140 @@
+<?xml version='1.0' encoding='ISO-8859-1'?>
+
+<!--
+$LastChangedBy$
+$Date$
+-->
+
+<!DOCTYPE xsl:stylesheet [
+<!ENTITY lowercase "'Aa&#192;&#224;&#193;&#225;&#194;&#226;&#195;&#227;&#196;&#228;&#197;&#229;&#256;&#257;&#258;&#259;&#260;&#261;&#461;&#462;&#478;&#479;&#480;&#481;&#506;&#507;&#512;&#513;&#514;&#515;&#550;&#551;&#7680;&#7681;&#7834;&#7840;&#7841;&#7842;&#7843;&#7844;&#7845;&#7846;&#7847;&#7848;&#7849;&#7850;&#7851;&#7852;&#7853;&#7854;&#7855;&#7856;&#7857;&#7858;&#7859;&#7860;&#7861;&#7862;&#7863;Bb&#384;&#385;&#595;&#386;&#387;&#7682;&#7683;&#7684;&#7685;&#7686;&#7687;Cc&#199;&#231;&#262;&#263;&#264;&#265;&#266;&#267;&#268;&#269;&#391;&#392;&#597;&#7688;&#7689;Dd&#270;&#271;&#272;&#273;&#394;&#599;&#395;&#396;&#453;&#498;&#545;&#598;&#7690;&#7691;&#7692;&#7693;&#7694;&#7695;&#7696;&#7697;&#7698;&#7699;Ee&#200;&#232;&#201;&#233;&#202;&#234;&#203;&#235;&#274;&#275;&#276;&#277;&#278;&#279;&#280;&#281;&#282;&#283;&#516;&#517;&#518;&#519;&#552;&#553;&#7700;&#7701;&#7702;&#7703;&#7704;&#7705;&#7706;&#7707;&#7708;&#7709;&#7864;&#7865;&#7866;&#7867;&#7868;&#7869;&#7870;&#7871;&#7872;&#7873;&#7874;&#7875;&#7876;&#7877;&#7878;&#7879;Ff&#401;&#402;&#7710;&#7711;Gg&#284;&#285;&#286;&#287;&#288;&#289;&#290;&#291;&#403;&#608;&#484;&#485;&#486;&#487;&#500;&#501;&#7712;&#7713;Hh&#292;&#293;&#294;&#295;&#542;&#543;&#614;&#7714;&#7715;&#7716;&#7717;&#7718;&#7719;&#7720;&#7721;&#7722;&#7723;&#7830;Ii&#204;&#236;&#205;&#237;&#206;&#238;&#207;&#239;&#296;&#297;&#298;&#299;&#300;&#301;&#302;&#303;&#304;&#407;&#616;&#463;&#464;&#520;&#521;&#522;&#523;&#7724;&#7725;&#7726;&#7727;&#7880;&#7881;&#7882;&#7883;Jj&#308;&#309;&#496;&#669;Kk&#310;&#311;&#408;&#409;&#488;&#489;&#7728;&#7729;&#7730;&#7731;&#7732;&#7733;Ll&#313;&#314;&#315;&#316;&#317;&#318;&#319;&#320;&#321;&#322;&#410;&#456;&#564;&#619;&#620;&#621;&#7734;&#7735;&#7736;&#7737;&#7738;&#7739;&#7740;&#7741;Mm&#625;&#7742;&#7743;&#7744;&#7745;&#7746;&#7747;Nn&#209;&#241;&#323;&#324;&#325;&#326;&#327;&#328;&#413;&#626;&#414;&#544;&#459;&#504;&#505;&#565;&#627;&#7748;&#7749;&#7750;&#7751;&#7752;&#7753;&#7754;&#7755;Oo&#210;&#242;&#211;&#243;&#212;&#244;&#213;&#245;&#214;&#246;&#216;&#248;&#332;&#333;&#334;&#335;&#336;&#337;&#415;&#416;&#417;&#465;&#466;&#490;&#491;&#492;&#493;&#510;&#511;&#524;&#525;&#526;&#527;&#554;&#555;&#556;&#557;&#558;&#559;&#560;&#561;&#7756;&#7757;&#7758;&#7759;&#7760;&#7761;&#7762;&#7763;&#7884;&#7885;&#7886;&#7887;&#7888;&#7889;&#7890;&#7891;&#7892;&#7893;&#7894;&#7895;&#7896;&#7897;&#7898;&#7899;&#7900;&#7901;&#7902;&#7903;&#7904;&#7905;&#7906;&#7907;Pp&#420;&#421;&#7764;&#7765;&#7766;&#7767;Qq&#672;Rr&#340;&#341;&#342;&#343;&#344;&#345;&#528;&#529;&#530;&#531;&#636;&#637;&#638;&#7768;&#7769;&#7770;&#7771;&#7772;&#7773;&#7774;&#7775;Ss&#346;&#347;&#348;&#349;&#350;&#351;&#352;&#353;&#536;&#537;&#642;&#7776;&#7777;&#7778;&#7779;&#7780;&#7781;&#7782;&#7783;&#7784;&#7785;Tt&#354;&#355;&#356;&#357;&#358;&#359;&#427;&#428;&#429;&#430;&#648;&#538;&#539;&#566;&#7786;&#7787;&#7788;&#7789;&#7790;&#7791;&#7792;&#7793;&#7831;Uu&#217;&#249;&#218;&#250;&#219;&#251;&#220;&#252;&#360;&#361;&#362;&#363;&#364;&#365;&#366;&#367;&#368;&#369;&#370;&#371;&#431;&#432;&#467;&#468;&#469;&#470;&#471;&#472;&#473;&#474;&#475;&#476;&#532;&#533;&#534;&#535;&#7794;&#7795;&#7796;&#7797;&#7798;&#7799;&#7800;&#7801;&#7802;&#7803;&#7908;&#7909;&#7910;&#7911;&#7912;&#7913;&#7914;&#7915;&#7916;&#7917;&#7918;&#7919;&#7920;&#7921;Vv&#434;&#651;&#7804;&#7805;&#7806;&#7807;Ww&#372;&#373;&#7808;&#7809;&#7810;&#7811;&#7812;&#7813;&#7814;&#7815;&#7816;&#7817;&#7832;Xx&#7818;&#7819;&#7820;&#7821;Yy&#221;&#253;&#255;&#376;&#374;&#375;&#435;&#436;&#562;&#563;&#7822;&#7823;&#7833;&#7922;&#7923;&#7924;&#7925;&#7926;&#7927;&#7928;&#7929;Zz&#377;&#378;&#379;&#380;&#381;&#382;&#437;&#438;&#548;&#549;&#656;&#657;&#7824;&#7825;&#7826;&#7827;&#7828;&#7829;&#7829;'">
+<!ENTITY uppercase "'AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABBBBBBBBBBBBBCCCCCCCCCCCCCCCCCDDDDDDDDDDDDDDDDDDDDDDDDEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEFFFFFFGGGGGGGGGGGGGGGGGGGGHHHHHHHHHHHHHHHHHHHHIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIJJJJJJKKKKKKKKKKKKKKLLLLLLLLLLLLLLLLLLLLLLLLLLMMMMMMMMMNNNNNNNNNNNNNNNNNNNNNNNNNNNOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOOPPPPPPPPQQQRRRRRRRRRRRRRRRRRRRRRRRSSSSSSSSSSSSSSSSSSSSSSSTTTTTTTTTTTTTTTTTTTTTTTTTUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUVVVVVVVVWWWWWWWWWWWWWWWXXXXXXYYYYYYYYYYYYYYYYYYYYYYYZZZZZZZZZZZZZZZZZZZZZ'">
+<!ENTITY primary 'normalize-space(concat(primary/@sortas, primary[not(@sortas) or @sortas = ""]))'>
+<!ENTITY scope "count(ancestor::node()|$scope) = count(ancestor::node()) and ($role = @role or $type = @type or (string-length($role) = 0 and string-length($type) = 0))">
+]>
+
+<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
+ xmlns:fo="http://www.w3.org/1999/XSL/Format"
+ version="1.0">
+
+ <!-- This stylesheet controls how the Index is generated.
+ Entities comes from {docbook-xsl}/common/entities.ent -->
+
+ <!-- Override for punctuation separating an index term from its list
+ of page references. -->
+ <xsl:param name="index.term.separator" select="': '"></xsl:param>
+
+ <!-- Divisions title properties. -->
+ <xsl:attribute-set name="index.div.title.properties">
+ <xsl:attribute name="margin-left">0pt</xsl:attribute>
+ <xsl:attribute name="font-size">14.4pt</xsl:attribute>
+ <xsl:attribute name="font-family">
+ <xsl:value-of select="$title.fontset"/>
+ </xsl:attribute>
+ <xsl:attribute name="font-weight">bold</xsl:attribute>
+ <xsl:attribute name="keep-with-next.within-column">always</xsl:attribute>
+ <xsl:attribute name="space-before.optimum">1em</xsl:attribute>
+ <xsl:attribute name="space-before.minimum">0.8em</xsl:attribute>
+ <xsl:attribute name="space-before.maximum">1.2em</xsl:attribute>
+ <xsl:attribute name="space-after.optimum">0.5em</xsl:attribute>
+ <xsl:attribute name="space-after.minimum">0.3em</xsl:attribute>
+ <xsl:attribute name="space-after.maximum">0.7em</xsl:attribute>
+ <xsl:attribute name="start-indent">0pt</xsl:attribute>
+ </xsl:attribute-set>
+
+ <!-- Properties applied to the block containing entries in an Index. -->
+ <xsl:attribute-set name="index.entry.properties">
+ <xsl:attribute name="start-indent">0.5pc</xsl:attribute>
+ </xsl:attribute-set>
+
+ <!-- Divisions:
+ Translate alphabetical divisons titles to by-type titles. -->
+ <!-- The original template is in {docbook-xsl}/fo/autoidx.xsl -->
+ <xsl:template match="indexterm" mode="index-div-basic">
+ <xsl:param name="scope" select="."/>
+ <xsl:param name="role" select="''"/>
+ <xsl:param name="type" select="''"/>
+ <xsl:variable name="key"
+ select="translate(substring(&primary;, 1, 1),&lowercase;,&uppercase;)"/>
+ <xsl:variable name="divtitle" select="translate($key, &lowercase;, &uppercase;)"/>
+ <xsl:if test="key('letter', $key)[&scope;]
+ [count(.|key('primary', &primary;)[&scope;][1]) = 1]">
+ <fo:block>
+ <xsl:if test="contains(concat(&lowercase;, &uppercase;), $key)">
+ <xsl:call-template name="indexdiv.title">
+ <xsl:with-param name="titlecontent">
+ <xsl:choose>
+ <xsl:when test="$divtitle = 'A'">
+ <xsl:call-template name="gentext">
+ <xsl:with-param name="key">Packages</xsl:with-param>
+ </xsl:call-template>
+ </xsl:when>
+ <xsl:when test="$divtitle = 'B'">
+ <xsl:call-template name="gentext">
+ <xsl:with-param name="key">Programs</xsl:with-param>
+ </xsl:call-template>
+ </xsl:when>
+ <xsl:when test="$divtitle = 'C'">
+ <xsl:call-template name="gentext">
+ <xsl:with-param name="key">Libraries</xsl:with-param>
+ </xsl:call-template>
+ </xsl:when>
+ <xsl:when test="$divtitle = 'D'">
+ <xsl:choose>
+ <xsl:when test="$book-type = 'blfs'">
+ <xsl:call-template name="gentext">
+ <xsl:with-param name="key">Kernel Configuration</xsl:with-param>
+ </xsl:call-template>
+ </xsl:when>
+ <xsl:otherwise>
+ <xsl:call-template name="gentext">
+ <xsl:with-param name="key">Scripts</xsl:with-param>
+ </xsl:call-template>
+ </xsl:otherwise>
+ </xsl:choose>
+ </xsl:when>
+ <xsl:when test="$divtitle = 'E'">
+ <xsl:choose>
+ <xsl:when test="$book-type = 'blfs'">
+ <xsl:call-template name="gentext">
+ <xsl:with-param name="key">Configuration Files</xsl:with-param>
+ </xsl:call-template>
+ </xsl:when>
+ <xsl:otherwise>
+ <xsl:call-template name="gentext">
+ <xsl:with-param name="key">Others</xsl:with-param>
+ </xsl:call-template>
+ </xsl:otherwise>
+ </xsl:choose>
+ </xsl:when>
+ <xsl:when test="$divtitle = 'F'">
+ <xsl:call-template name="gentext">
+ <xsl:with-param name="key">Bootscripts</xsl:with-param>
+ </xsl:call-template>
+ </xsl:when>
+ <xsl:when test="$divtitle = 'G'">
+ <xsl:call-template name="gentext">
+ <xsl:with-param name="key">Others</xsl:with-param>
+ </xsl:call-template>
+ </xsl:when>
+ <xsl:otherwise>
+ <xsl:value-of select="$divtitle"/>
+ </xsl:otherwise>
+ </xsl:choose>
+ </xsl:with-param>
+ </xsl:call-template>
+ </xsl:if>
+ <fo:block xsl:use-attribute-sets="index.entry.properties">
+ <xsl:apply-templates select="key('letter', $key)[&scope;]
+ [count(.|key('primary', &primary;)[&scope;][1])=1]"
+ mode="index-primary">
+ <xsl:sort select="translate(&primary;, &lowercase;, &uppercase;)"/>
+ <xsl:with-param name="scope" select="$scope"/>
+ <xsl:with-param name="role" select="$role"/>
+ <xsl:with-param name="type" select="$type"/>
+ </xsl:apply-templates>
+ </fo:block>
+ </fo:block>
+ </xsl:if>
+ </xsl:template>
+
+</xsl:stylesheet>
diff --git a/stylesheets/lfs-xsl/pdf/lfs-lists.xsl b/stylesheets/lfs-xsl/pdf/lfs-lists.xsl
new file mode 100644
index 000000000..34dfc73cf
--- /dev/null
+++ b/stylesheets/lfs-xsl/pdf/lfs-lists.xsl
@@ -0,0 +1,174 @@
+<?xml version='1.0' encoding='ISO-8859-1'?>
+
+<!--
+$LastChangedBy$
+$Date$
+-->
+
+<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
+ xmlns:fo="http://www.w3.org/1999/XSL/Format"
+ version="1.0">
+
+ <!-- This stylesheet controls how list are generated. -->
+
+ <!-- What spacing do you want before and after lists? -->
+ <xsl:attribute-set name="list.block.spacing">
+ <xsl:attribute name="space-before.optimum">0.6em</xsl:attribute>
+ <xsl:attribute name="space-before.minimum">0.4em</xsl:attribute>
+ <xsl:attribute name="space-before.maximum">0.8em</xsl:attribute>
+ <xsl:attribute name="space-after.optimum">0.6em</xsl:attribute>
+ <xsl:attribute name="space-after.minimum">0.4em</xsl:attribute>
+ <xsl:attribute name="space-after.maximum">0.8em</xsl:attribute>
+ </xsl:attribute-set>
+
+ <!-- What spacing do you want between list items? -->
+ <xsl:attribute-set name="list.item.spacing">
+ <xsl:attribute name="space-before.optimum">0.4em</xsl:attribute>
+ <xsl:attribute name="space-before.minimum">0.2em</xsl:attribute>
+ <xsl:attribute name="space-before.maximum">0.6em</xsl:attribute>
+ </xsl:attribute-set>
+
+ <!-- Properties that apply to each list-block generated by itemizedlist. -->
+ <xsl:attribute-set name="itemizedlist.properties"
+ use-attribute-sets="list.block.properties">
+ <xsl:attribute name="text-align">left</xsl:attribute>
+ </xsl:attribute-set>
+
+ <!-- Format variablelists lists as blocks? 1 = yes, 0 = no
+ Default variablelist format. We override it when necesary
+ using the list-presentation processing instruction. -->
+ <xsl:param name="variablelist.as.blocks" select="1"/>
+
+ <!-- Specifies the longest term in variablelists.
+ Used when list-presentation = list -->
+ <xsl:param name="variablelist.max.termlength">35</xsl:param>
+
+ <!-- varlistentry mode block:
+ Addibg a bullet, left alignament, and @kepp-*.* attributes
+ for packages and paches list. -->
+ <!-- The original template is in {docbook-xsl}/fo/list.xsl -->
+ <xsl:template match="varlistentry" mode="vl.as.blocks">
+ <xsl:variable name="id"><xsl:call-template name="object.id"/></xsl:variable>
+ <xsl:choose>
+ <xsl:when test="ancestor::variablelist/@role = 'materials'">
+ <fo:block id="{$id}" xsl:use-attribute-sets="list.item.spacing"
+ keep-together.within-column="always" font-weight="bold"
+ keep-with-next.within-column="always" text-align="left">
+ <xsl:text>&#x2022; </xsl:text>
+ <xsl:apply-templates select="term"/>
+ </fo:block>
+ <fo:block text-align="left"
+ keep-together.within-column="always"
+ keep-with-previous.within-column="always">
+ <xsl:apply-templates select="listitem"/>
+ </fo:block>
+ </xsl:when>
+ <xsl:otherwise>
+ <fo:block id="{$id}" xsl:use-attribute-sets="list.item.spacing"
+ keep-together.within-column="always"
+ keep-with-next.within-column="always" margin-left="1em">
+ <xsl:apply-templates select="term"/>
+ </fo:block>
+ <fo:block margin-left="2em">
+ <xsl:apply-templates select="listitem"/>
+ </fo:block>
+ </xsl:otherwise>
+ </xsl:choose>
+ </xsl:template>
+
+ <!-- segmentedlist:
+ Making it an actual FO list to can indent items.
+ Adjust vertical space. -->
+ <!-- The original template is in {docbook-xsl}/fo/list.xsl -->
+ <xsl:template match="segmentedlist">
+ <xsl:variable name="id">
+ <xsl:call-template name="object.id"/>
+ </xsl:variable>
+ <fo:list-block id="{$id}" provisional-distance-between-starts="12em"
+ provisional-label-separation="1em"
+ keep-together.within-column="always">
+ <xsl:choose>
+ <xsl:when test="ancestor::appendix[@id='appendixc']">
+ <xsl:attribute name="space-before.optimum">0.2em</xsl:attribute>
+ <xsl:attribute name="space-before.minimum">0em</xsl:attribute>
+ <xsl:attribute name="space-before.maximum">0.4em</xsl:attribute>
+ <xsl:attribute name="space-after.optimum">0.2em</xsl:attribute>
+ <xsl:attribute name="space-after.minimum">0em</xsl:attribute>
+ <xsl:attribute name="space-after.maximum">0.4em</xsl:attribute>
+ <xsl:attribute name="keep-with-previous.within-column">always</xsl:attribute>
+ </xsl:when>
+ <xsl:otherwise>
+ <xsl:attribute name="space-before.optimum">0.4em</xsl:attribute>
+ <xsl:attribute name="space-before.minimum">0.2em</xsl:attribute>
+ <xsl:attribute name="space-before.maximum">0.6em</xsl:attribute>
+ <xsl:attribute name="space-after.optimum">0.4em</xsl:attribute>
+ <xsl:attribute name="space-after.minimum">0.2em</xsl:attribute>
+ <xsl:attribute name="space-after.maximum">0.6em</xsl:attribute>
+ </xsl:otherwise>
+ </xsl:choose>
+ <xsl:apply-templates select="seglistitem/seg"/>
+ </fo:list-block>
+ </xsl:template>
+
+ <!-- seg:
+ Self-made template based on the original seg template
+ found in {docbook-xsl}/fo/list.xsl
+ Making segmentedlist an actual FO list to can indent items. -->
+ <xsl:template match="seglistitem/seg">
+ <xsl:variable name="id">
+ <xsl:call-template name="object.id"/>
+ </xsl:variable>
+ <xsl:variable name="segnum" select="count(preceding-sibling::seg)+1"/>
+ <xsl:variable name="seglist" select="ancestor::segmentedlist"/>
+ <xsl:variable name="segtitles" select="$seglist/segtitle"/>
+ <fo:list-item xsl:use-attribute-sets="compact.list.item.spacing">
+ <fo:list-item-label end-indent="label-end()" text-align="start">
+ <fo:block>
+ <fo:inline font-weight="bold">
+ <xsl:apply-templates select="$segtitles[$segnum=position()]"
+ mode="segtitle-in-seg"/>
+ <xsl:text>:</xsl:text>
+ </fo:inline>
+ </fo:block>
+ </fo:list-item-label>
+ <fo:list-item-body start-indent="body-start()">
+ <fo:block id="{$id}">
+ <xsl:apply-templates/>
+ </fo:block>
+ </fo:list-item-body>
+ </fo:list-item>
+ </xsl:template>
+
+ <!-- simplelist:
+ Self-made template. Wrap it into a fo:block and process member childs.
+ If @type is specified, the original templates will be used.
+ NOTE: when using type='horiz' or type='vert', FOP-0.93 will complaints
+ about not supported table-layout="auto" -->
+ <xsl:template match="simplelist">
+ <fo:block xsl:use-attribute-sets="simplelist.properties">
+ <xsl:apply-templates mode="condensed"/>
+ </fo:block>
+ </xsl:template>
+
+ <!-- member:
+ Self-made template to wrap it into a fo:block using customized
+ properties. -->
+ <xsl:template match="member" mode="condensed">
+ <fo:block xsl:use-attribute-sets="simplelist.properties">
+ <xsl:call-template name="simple.xlink">
+ <xsl:with-param name="content">
+ <xsl:apply-templates/>
+ </xsl:with-param>
+ </xsl:call-template>
+ </fo:block>
+ </xsl:template>
+
+ <!-- Properties associated with our simplelist format. -->
+ <xsl:attribute-set name="simplelist.properties">
+ <xsl:attribute name="keep-with-previous.within-column">always</xsl:attribute>
+ <xsl:attribute name="space-before.optimum">0em</xsl:attribute>
+ <xsl:attribute name="space-before.minimum">0em</xsl:attribute>
+ <xsl:attribute name="space-before.maximum">0.2em</xsl:attribute>
+ </xsl:attribute-set>
+
+</xsl:stylesheet> \ No newline at end of file
diff --git a/stylesheets/lfs-xsl/pdf/lfs-mixed.xsl b/stylesheets/lfs-xsl/pdf/lfs-mixed.xsl
new file mode 100644
index 000000000..99fcc4092
--- /dev/null
+++ b/stylesheets/lfs-xsl/pdf/lfs-mixed.xsl
@@ -0,0 +1,360 @@
+<?xml version='1.0' encoding='ISO-8859-1'?>
+
+<!--
+$LastChangedBy$
+$Date$
+-->
+
+<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
+ xmlns:fo="http://www.w3.org/1999/XSL/Format"
+ version="1.0">
+
+ <!-- This stylesheet contains misc params, attribute sets and templates
+ for output formating.
+ This file is for that templates that don't fit in other files. -->
+
+ <!-- What space do you want between normal paragraphs. -->
+ <xsl:attribute-set name="normal.para.spacing">
+ <xsl:attribute name="space-before.optimum">0.6em</xsl:attribute>
+ <xsl:attribute name="space-before.minimum">0.4em</xsl:attribute>
+ <xsl:attribute name="space-before.maximum">0.8em</xsl:attribute>
+ <xsl:attribute name="orphans">3</xsl:attribute>
+ <xsl:attribute name="widows">3</xsl:attribute>
+ </xsl:attribute-set>
+
+ <!-- Properties associated with verbatim text. -->
+ <xsl:attribute-set name="verbatim.properties">
+ <xsl:attribute name="keep-with-previous.within-column">always</xsl:attribute>
+ <xsl:attribute name="space-before.optimum">0.6em</xsl:attribute>
+ <xsl:attribute name="space-before.minimum">0.4em</xsl:attribute>
+ <xsl:attribute name="space-before.maximum">0.8em</xsl:attribute>
+ <xsl:attribute name="space-after.optimum">0.6em</xsl:attribute>
+ <xsl:attribute name="space-after.minimum">0.4em</xsl:attribute>
+ <xsl:attribute name="space-after.maximum">0.8em</xsl:attribute>
+ <xsl:attribute name="hyphenate">false</xsl:attribute>
+ <xsl:attribute name="wrap-option">no-wrap</xsl:attribute>
+ <xsl:attribute name="white-space-collapse">false</xsl:attribute>
+ <xsl:attribute name="white-space-treatment">preserve</xsl:attribute>
+ <xsl:attribute name="linefeed-treatment">preserve</xsl:attribute>
+ <xsl:attribute name="text-align">start</xsl:attribute>
+ </xsl:attribute-set>
+
+ <!-- Should verbatim environments be shaded? 1 =yes, 0 = no -->
+ <xsl:param name="shade.verbatim" select="1"/>
+
+ <!-- Properties that specify the style of shaded verbatim listings -->
+ <xsl:attribute-set name="shade.verbatim.style">
+ <xsl:attribute name="background-color">#E9E9E9</xsl:attribute>
+ <xsl:attribute name="border-style">solid</xsl:attribute>
+ <xsl:attribute name="border-width">0.5pt</xsl:attribute>
+ <xsl:attribute name="border-color">#888</xsl:attribute>
+ <xsl:attribute name="padding-start">5pt</xsl:attribute>
+ <xsl:attribute name="padding-top">2pt</xsl:attribute>
+ <xsl:attribute name="padding-bottom">2pt</xsl:attribute>
+ </xsl:attribute-set>
+
+ <!-- para:
+ Skip empty "Home page" in packages.xml.
+ Allow forced line breaks inside paragraphs emulating literallayout.
+ Removed vertical space in variablelist. -->
+ <!-- The original template is in {docbook-xsl}/fo/block.xsl -->
+ <xsl:template match="para">
+ <xsl:choose>
+ <xsl:when test="child::ulink[@url=' ']"/>
+ <xsl:when test="./@remap='verbatim'">
+ <fo:block xsl:use-attribute-sets="verbatim.properties">
+ <xsl:call-template name="anchor"/>
+ <xsl:apply-templates/>
+ </fo:block>
+ </xsl:when>
+ <xsl:when test="ancestor::variablelist">
+ <fo:block>
+ <xsl:attribute name="space-before.optimum">0.1em</xsl:attribute>
+ <xsl:attribute name="space-before.minimum">0em</xsl:attribute>
+ <xsl:attribute name="space-before.maximum">0.2em</xsl:attribute>
+ <xsl:call-template name="anchor"/>
+ <xsl:apply-templates/>
+ </fo:block>
+ </xsl:when>
+ <xsl:otherwise>
+ <fo:block xsl:use-attribute-sets="normal.para.spacing">
+ <xsl:call-template name="anchor"/>
+ <xsl:apply-templates/>
+ </fo:block>
+ </xsl:otherwise>
+ </xsl:choose>
+ </xsl:template>
+
+ <!-- screen, literallayout:
+ Self-made template that creates a fo:block wrapper with keep-together
+ processing instruction support around the output generated by
+ original screen templates. -->
+ <xsl:template match="screen|literallayout">
+ <xsl:variable name="keep.together">
+ <xsl:call-template name="pi.dbfo_keep-together"/>
+ </xsl:variable>
+ <fo:block>
+ <xsl:attribute name="keep-together.within-column">
+ <xsl:choose>
+ <xsl:when test="$keep.together != ''">
+ <xsl:value-of select="$keep.together"/>
+ </xsl:when>
+ <xsl:otherwise>always</xsl:otherwise>
+ </xsl:choose>
+ </xsl:attribute>
+ <xsl:apply-imports/>
+ </fo:block>
+ </xsl:template>
+
+ <!-- literal:
+ Be sure that literal will use allways normal font weight. -->
+ <!-- The original template is in {docbook-xsl}/fo/inline.xsl -->
+ <xsl:template match="literal">
+ <fo:inline font-weight="normal">
+ <xsl:call-template name="inline.monoseq"/>
+ </fo:inline>
+ </xsl:template>
+
+ <!-- inline.monoseq:
+ Added hyphenate-url support to classname, exceptionname, interfacename,
+ methodname, computeroutput, constant, envar, filename, function, code,
+ literal, option, promt, systemitem, varname, sgmltag, tag, and uri -->
+ <!-- The original template is in {docbook-xsl}/fo/inline.xsl -->
+ <xsl:template name="inline.monoseq">
+ <xsl:param name="content">
+ <xsl:call-template name="simple.xlink">
+ <xsl:with-param name="content">
+ <xsl:choose>
+ <xsl:when test="ancestor::para and not(ancestor::screen)
+ and not(descendant::ulink)">
+ <xsl:call-template name="hyphenate-url">
+ <xsl:with-param name="url">
+ <xsl:apply-templates/>
+ </xsl:with-param>
+ </xsl:call-template>
+ </xsl:when>
+ <xsl:otherwise>
+ <xsl:apply-templates/>
+ </xsl:otherwise>
+ </xsl:choose>
+ </xsl:with-param>
+ </xsl:call-template>
+ </xsl:param>
+ <fo:inline xsl:use-attribute-sets="monospace.properties">
+ <xsl:if test="@dir">
+ <xsl:attribute name="direction">
+ <xsl:choose>
+ <xsl:when test="@dir = 'ltr' or @dir = 'lro'">ltr</xsl:when>
+ <xsl:otherwise>rtl</xsl:otherwise>
+ </xsl:choose>
+ </xsl:attribute>
+ </xsl:if>
+ <xsl:copy-of select="$content"/>
+ </fo:inline>
+ </xsl:template>
+
+ <!-- inline.italicmonoseq:
+ Added hyphenate-url support to parameter, replaceable, structfield,
+ function/parameter, and function/replaceable -->
+ <!-- The original template is in {docbook-xsl}/fo/inline.xsl -->
+ <xsl:template name="inline.italicmonoseq">
+ <xsl:param name="content">
+ <xsl:call-template name="simple.xlink">
+ <xsl:with-param name="content">
+ <xsl:choose>
+ <xsl:when test="ancestor::para and not(ancestor::screen)
+ and not(descendant::ulink)">
+ <xsl:call-template name="hyphenate-url">
+ <xsl:with-param name="url">
+ <xsl:apply-templates/>
+ </xsl:with-param>
+ </xsl:call-template>
+ </xsl:when>
+ <xsl:otherwise>
+ <xsl:apply-templates/>
+ </xsl:otherwise>
+ </xsl:choose>
+ </xsl:with-param>
+ </xsl:call-template>
+ </xsl:param>
+ <fo:inline font-style="italic" xsl:use-attribute-sets="monospace.properties">
+ <xsl:call-template name="anchor"/>
+ <xsl:if test="@dir">
+ <xsl:attribute name="direction">
+ <xsl:choose>
+ <xsl:when test="@dir = 'ltr' or @dir = 'lro'">ltr</xsl:when>
+ <xsl:otherwise>rtl</xsl:otherwise>
+ </xsl:choose>
+ </xsl:attribute>
+ </xsl:if>
+ <xsl:copy-of select="$content"/>
+ </fo:inline>
+ </xsl:template>
+
+ <!-- Show external URLs in italic font -->
+ <xsl:attribute-set name="xref.properties">
+ <xsl:attribute name="font-style">
+ <xsl:choose>
+ <xsl:when test="self::ulink">italic</xsl:when>
+ <xsl:otherwise>inherit</xsl:otherwise>
+ </xsl:choose>
+ </xsl:attribute>
+ </xsl:attribute-set>
+
+ <!-- Center table title. -->
+ <xsl:attribute-set name="formal.title.properties">
+ <xsl:attribute name="text-align">
+ <xsl:choose>
+ <xsl:when test="local-name(.) = 'table'">center</xsl:when>
+ <xsl:otherwise>left</xsl:otherwise>
+ </xsl:choose>
+ </xsl:attribute>
+ </xsl:attribute-set>
+
+ <!-- table.layout:
+ We want all tables centered. Based on a hack posted
+ by Ellen Juhlin on docbook-apps mailing list. -->
+ <!-- The original template is in {docbook-xsl}/fo/table.xsl -->
+ <xsl:template name="table.layout">
+ <xsl:param name="table.content" select="NOTANODE"/>
+ <fo:table table-layout="fixed" width="100%">
+ <fo:table-column column-width ="proportional-column-width(1)"/>
+ <fo:table-column>
+ <!-- Set center column width equal to table width -->
+ <xsl:attribute name="column-width">
+ <xsl:call-template name="table.width"/>
+ </xsl:attribute>
+ </fo:table-column>
+ <fo:table-column column-width ="proportional-column-width(1)"/>
+ <fo:table-body>
+ <fo:table-row>
+ <fo:table-cell column-number="2">
+ <xsl:copy-of select="$table.content"/>
+ </fo:table-cell>
+ </fo:table-row>
+ </fo:table-body>
+ </fo:table>
+ </xsl:template>
+
+
+ <!-- Revision History -->
+
+ <!-- revhistory titlepage:
+ Self-made template to add missing support on bookinfo. -->
+ <xsl:template match="revhistory" mode="book.titlepage.verso.auto.mode">
+ <fo:block space-before.optimum="2em"
+ space-before.minimum="1.5em"
+ space-before.maximum="2.5em">
+ <xsl:apply-templates select="." mode="book.titlepage.verso.mode"/>
+ </fo:block>
+ </xsl:template>
+
+ <!-- revhitory title properties -->
+ <xsl:attribute-set name="revhistory.title.properties">
+ <xsl:attribute name="text-align">center</xsl:attribute>
+ <xsl:attribute name="font-weight">bold</xsl:attribute>
+ </xsl:attribute-set>
+
+ <!-- revhistory/revision mode titlepage.mode:
+ Removed authorinitials | author support placing
+ revremark | revdescription instead on that table-cell. -->
+ <!-- The original template is in {docbook-xsl}/fo/titlepage.xsl -->
+ <xsl:template match="revhistory/revision" mode="titlepage.mode">
+ <xsl:variable name="revnumber" select="revnumber"/>
+ <xsl:variable name="revdate" select="date"/>
+ <xsl:variable name="revremark" select="revremark|revdescription"/>
+ <fo:table-row>
+ <fo:table-cell xsl:use-attribute-sets="revhistory.table.cell.properties">
+ <fo:block>
+ <xsl:if test="$revnumber">
+ <xsl:call-template name="gentext">
+ <xsl:with-param name="key" select="'Revision'"/>
+ </xsl:call-template>
+ <xsl:call-template name="gentext.space"/>
+ <xsl:apply-templates select="$revnumber[1]" mode="titlepage.mode"/>
+ </xsl:if>
+ </fo:block>
+ </fo:table-cell>
+ <fo:table-cell xsl:use-attribute-sets="revhistory.table.cell.properties">
+ <fo:block>
+ <xsl:apply-templates select="$revdate[1]"/>
+ </fo:block>
+ </fo:table-cell>
+ <fo:table-cell xsl:use-attribute-sets="revhistory.table.cell.properties">
+ <fo:block>
+ <xsl:apply-templates select="$revremark[1]"/>
+ </fo:block>
+ </fo:table-cell>
+ </fo:table-row>
+ </xsl:template>
+
+
+ <!-- Dummy sect1 -->
+
+ <!-- sect1:
+ Self-made template to skip dummy sect1 pages generation. -->
+ <xsl:template match="sect1">
+ <xsl:choose>
+ <xsl:when test="@role = 'dummy'"/>
+ <xsl:otherwise>
+ <xsl:apply-imports/>
+ </xsl:otherwise>
+ </xsl:choose>
+ </xsl:template>
+
+ <!-- sect1 mode fop1.outline:
+ Self-made template to skip dummy sect1 bookmarks generation. -->
+ <xsl:template match="sect1" mode="fop1.outline">
+ <xsl:choose>
+ <xsl:when test="@role = 'dummy'"/>
+ <xsl:otherwise>
+ <xsl:apply-imports/>
+ </xsl:otherwise>
+ </xsl:choose>
+ </xsl:template>
+
+ <!-- toc.line:
+ For dummy sect1 output only the title. -->
+ <!-- The original template is in {docbook-xsl}/fo/autotoc.xsl -->
+ <xsl:template name="toc.line">
+ <xsl:param name="toc-context" select="NOTANODE"/>
+ <xsl:variable name="id">
+ <xsl:call-template name="object.id"/>
+ </xsl:variable>
+ <xsl:variable name="label">
+ <xsl:apply-templates select="." mode="label.markup"/>
+ </xsl:variable>
+ <xsl:choose>
+ <xsl:when test="@role = 'dummy'">
+ <fo:block text-align="left">
+ <xsl:apply-templates select="." mode="titleabbrev.markup"/>
+ </fo:block>
+ </xsl:when>
+ <xsl:otherwise>
+ <fo:block xsl:use-attribute-sets="toc.line.properties">
+ <fo:inline keep-with-next.within-line="always">
+ <fo:basic-link internal-destination="{$id}">
+ <xsl:if test="$label != ''">
+ <xsl:copy-of select="$label"/>
+ <xsl:value-of select="$autotoc.label.separator"/>
+ </xsl:if>
+ <xsl:apply-templates select="." mode="titleabbrev.markup"/>
+ </fo:basic-link>
+ </fo:inline>
+ <fo:inline keep-together.within-line="always">
+ <xsl:text> </xsl:text>
+ <fo:leader leader-pattern="dots"
+ leader-pattern-width="3pt"
+ leader-alignment="reference-area"
+ keep-with-next.within-line="always"/>
+ <xsl:text> </xsl:text>
+ <fo:basic-link internal-destination="{$id}">
+ <fo:page-number-citation ref-id="{$id}"/>
+ </fo:basic-link>
+ </fo:inline>
+ </fo:block>
+ </xsl:otherwise>
+ </xsl:choose>
+ </xsl:template>
+
+</xsl:stylesheet>
diff --git a/stylesheets/lfs-xsl/pdf/lfs-pagesetup.xsl b/stylesheets/lfs-xsl/pdf/lfs-pagesetup.xsl
new file mode 100644
index 000000000..ae30a4cd9
--- /dev/null
+++ b/stylesheets/lfs-xsl/pdf/lfs-pagesetup.xsl
@@ -0,0 +1,249 @@
+<?xml version='1.0' encoding='ISO-8859-1'?>
+
+<!--
+$LastChangedBy$
+$Date$
+-->
+
+<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
+ xmlns:fo="http://www.w3.org/1999/XSL/Format"
+ version="1.0">
+
+ <!-- This stylesheet controls page margins, sections page break,
+ header content and titles size. -->
+
+ <!-- The inner page margin. -->
+ <xsl:param name="page.margin.inner" select="'0.32in'"/>
+
+ <!-- The outer page margin. -->
+ <xsl:param name="page.margin.outer" select="'0.32in'"/>
+
+ <!-- The bottom margin of the page. -->
+ <xsl:param name="page.margin.bottom" select="'0.35in'"/>
+
+ <!-- The top margin of the page. -->
+ <xsl:param name="page.margin.top" select="'0.35in'"/>
+
+ <!-- The bottom margin of the body text. -->
+ <xsl:param name="body.margin.bottom" select="'0.4in'"/>
+
+ <!-- The top margin of the body text. -->
+ <xsl:param name="body.margin.top" select="'0.4in'"/>
+
+ <!-- Specifies the height of the header. -->
+ <xsl:param name="region.before.extent" select="'0.25in'"/>
+
+ <!-- Specifies the height of the footer. -->
+ <xsl:param name="region.after.extent" select="'0.25in'"/>
+
+ <!-- The start-indent for the body text. -->
+ <xsl:param name="body.start.indent" select="'0pc'"/>
+
+ <!-- Adjust the left margin for titles. -->
+ <xsl:param name="title.margin.left">-0.8pc</xsl:param>
+
+ <!-- Default table width on tables that do not specify an alternate
+ width using the dbfo processing instruction.
+ This value is used also on bookinfo/revhistory table. -->
+ <xsl:param name="default.table.width" select="'70%'"/>
+
+ <!-- Properties for component titles -->
+ <xsl:attribute-set name="component.title.properties">
+ <xsl:attribute name="keep-with-next.within-column">always</xsl:attribute>
+ <xsl:attribute name="space-before.optimum">
+ <xsl:value-of select="concat($body.font.master, 'pt')"/>
+ </xsl:attribute>
+ <xsl:attribute name="space-before.minimum">
+ <xsl:value-of select="concat($body.font.master, 'pt * 0.8')"/>
+ </xsl:attribute>
+ <xsl:attribute name="space-before.maximum">
+ <xsl:value-of select="concat($body.font.master, 'pt * 1.2')"/>
+ </xsl:attribute>
+ <xsl:attribute name="hyphenate">false</xsl:attribute>
+ <xsl:attribute name="text-align">
+ <xsl:choose>
+ <xsl:when test="((parent::article | parent::articleinfo |
+ parent::info/parent::article)
+ and not(ancestor::book) and not(self::bibliography))
+ or (parent::slides | parent::slidesinfo)
+ or self::index">center</xsl:when>
+ <xsl:otherwise>left</xsl:otherwise>
+ </xsl:choose>
+ </xsl:attribute>
+ <xsl:attribute name="start-indent">
+ <xsl:value-of select="$title.margin.left"/>
+ </xsl:attribute>
+ </xsl:attribute-set>
+
+ <!-- Rule under headers? 1 =yes, 0 = no -->
+ <xsl:param name="header.rule" select="0"/>
+
+ <!-- Rule over footers? 1 =yes, 0 = no -->
+ <xsl:param name="footer.rule" select="0"></xsl:param>
+
+ <!-- Control depth of sections shown in running headers or footers.
+ Be sure that no unneeded fo:marker are generated. -->
+ <xsl:param name="marker.section.level" select="-1"></xsl:param>
+
+ <!-- Force package's sect1 onto a new page -->
+ <xsl:attribute-set name="section.level1.properties">
+ <xsl:attribute name="break-before">
+ <xsl:choose>
+ <!--<xsl:when test="not(. = //*/sect1[1])">
+ <xsl:text>page</xsl:text>
+ </xsl:when>-->
+ <xsl:when test="preceding-sibling::sect1[position()=1]/sect2/@role='package'
+ or self::sect1/sect2/@role='package'">page</xsl:when>
+ <xsl:otherwise>
+ <xsl:text>auto</xsl:text>
+ </xsl:otherwise>
+ </xsl:choose>
+ </xsl:attribute>
+ </xsl:attribute-set>
+
+ <!-- part/partintro:
+ Be sure that partintro is on a new page. -->
+ <!-- The original template is in {docbook-xsl}/fo/divisions.xsl -->
+ <xsl:template match="part/partintro">
+ <xsl:apply-templates select=".." mode="part.titlepage.mode">
+ <xsl:with-param name="additional.content">
+ <fo:block break-before="page"/>
+ <xsl:if test="title">
+ <xsl:call-template name="partintro.titlepage"/>
+ </xsl:if>
+ <xsl:apply-templates/>
+ </xsl:with-param>
+ </xsl:apply-templates>
+ <xsl:call-template name="generate.part.toc">
+ <xsl:with-param name="part" select=".."/>
+ </xsl:call-template>
+ </xsl:template>
+
+ <!-- book title:
+ Centered the title and removed unused code.
+ Removed book.titlepage.separator. -->
+ <!-- The original template is in {docbook-xsl}/fo/titlepage.templates.xsl -->
+ <xsl:template name="book.titlepage">
+ <fo:block margin-top="3in">
+ <fo:block>
+ <xsl:call-template name="book.titlepage.before.recto"/>
+ <xsl:call-template name="book.titlepage.recto"/>
+ </fo:block>
+ <fo:block>
+ <xsl:call-template name="book.titlepage.before.verso"/>
+ <xsl:call-template name="book.titlepage.verso"/>
+ </fo:block>
+ </fo:block>
+ </xsl:template>
+
+ <!-- book titlepage verso:
+ Added missing bibliosource and revhistory support.
+ Removed unused code. -->
+ <!-- The original template is in {docbook-xsl}/fo/titlepage.templates.xsl -->
+ <xsl:template name="book.titlepage.verso">
+ <xsl:apply-templates mode="book.titlepage.verso.auto.mode" select="bookinfo/title"/>
+ <xsl:apply-templates mode="book.titlepage.verso.auto.mode" select="bookinfo/corpauthor"/>
+ <xsl:apply-templates mode="book.titlepage.verso.auto.mode" select="bookinfo/authorgroup"/>
+ <xsl:apply-templates mode="book.titlepage.verso.auto.mode" select="bookinfo/author"/>
+ <xsl:apply-templates mode="book.titlepage.verso.auto.mode" select="bookinfo/othercredit"/>
+ <xsl:apply-templates mode="book.titlepage.verso.auto.mode" select="bookinfo/releaseinfo"/>
+ <xsl:apply-templates mode="book.titlepage.verso.auto.mode" select="bookinfo/pubdate"/>
+ <xsl:apply-templates mode="book.titlepage.verso.auto.mode" select="bookinfo/copyright"/>
+ <xsl:apply-templates mode="book.titlepage.verso.auto.mode" select="bookinfo/bibliosource"/>
+ <xsl:apply-templates mode="book.titlepage.verso.auto.mode" select="bookinfo/abstract"/>
+ <xsl:apply-templates mode="book.titlepage.verso.auto.mode" select="bookinfo/revhistory"/>
+ <xsl:apply-templates mode="book.titlepage.verso.auto.mode" select="bookinfo/legalnotice"/>
+ </xsl:template>
+
+ <!-- bibliosource:
+ Self-made template to handle bibliosource when inside bookinfo. -->
+ <xsl:template match="bibliosource" mode="book.titlepage.verso.auto.mode">
+ <fo:block font-size="8pt">
+ <xsl:apply-templates/>
+ </fo:block>
+ </xsl:template>
+
+ <!-- part title:
+ Centered the title and removed unused code. -->
+ <!-- The original template is in {docbook-xsl}/fo/titlepage.templates.xsl -->
+ <xsl:template name="part.titlepage">
+ <fo:block>
+ <fo:block margin-top="3.5in">
+ <xsl:call-template name="part.titlepage.before.recto"/>
+ <xsl:call-template name="part.titlepage.recto"/>
+ </fo:block>
+ <fo:block>
+ <xsl:call-template name="part.titlepage.before.verso"/>
+ <xsl:call-template name="part.titlepage.verso"/>
+ </fo:block>
+ <xsl:call-template name="part.titlepage.separator"/>
+ </fo:block>
+ </xsl:template>
+
+ <!-- chapter title:
+ Small font size and left alignament. -->
+ <!-- The original template is in {docbook-xsl}/fo/titlepage.templates.xsl -->
+ <xsl:template match="title" mode="chapter.titlepage.recto.auto.mode">
+ <fo:block xsl:use-attribute-sets="chapter.titlepage.recto.style"
+ font-size="21pt" font-weight="bold" text-align="left">
+ <xsl:call-template name="component.title">
+ <xsl:with-param name="node" select="ancestor-or-self::chapter[1]"/>
+ </xsl:call-template>
+ </fo:block>
+ </xsl:template>
+
+ <!-- sect2 title:
+ Skip sect2.titlepage run when title is empty.
+ Removed unused code. -->
+ <!-- The original template is in {docbook-xsl}/fo/sections.xsl -->
+ <xsl:template match="sect2">
+ <xsl:variable name="id">
+ <xsl:call-template name="object.id"/>
+ </xsl:variable>
+ <fo:block xsl:use-attribute-sets="section.level2.properties">
+ <xsl:attribute name="id">
+ <xsl:value-of select="$id"/>
+ </xsl:attribute>
+ <xsl:if test="not(string-length(title)=0)">
+ <xsl:call-template name="sect2.titlepage"/>
+ </xsl:if>
+ <xsl:apply-templates/>
+ </fo:block>
+ </xsl:template>
+
+ <!-- header.table:
+ Re-made template to not generate a fo:table in the header,
+ allowing a more simple header.content customization. -->
+ <!-- The original template is in {docbook-xsl}/fo/pagesetup.xsl -->
+ <xsl:template name="header.table">
+ <xsl:param name="sequence" select="''"/>
+ <xsl:param name="gentext-key" select="''"/>
+ <xsl:choose>
+ <xsl:when test="$gentext-key = 'book' or $sequence = 'blank'"/>
+ <xsl:otherwise>
+ <xsl:call-template name="header.content">
+ <xsl:with-param name="sequence" select="$sequence"/>
+ </xsl:call-template>
+ </xsl:otherwise>
+ </xsl:choose>
+ </xsl:template>
+
+ <!-- header.content
+ Re-made template to show the book title and version on all pages. -->
+ <!-- The original template is in {docbook-xsl}/fo/pagesetup.xsl -->
+ <xsl:template name="header.content">
+ <xsl:param name="sequence" select="''"/>
+ <fo:block>
+ <xsl:attribute name="text-align">
+ <xsl:choose>
+ <xsl:when test="$sequence = 'first' or $sequence = 'odd'">right</xsl:when>
+ <xsl:otherwise>left</xsl:otherwise>
+ </xsl:choose>
+ </xsl:attribute>
+ <xsl:value-of select="/book/bookinfo/title"/>
+ <xsl:text> - </xsl:text>
+ <xsl:value-of select="/book/bookinfo/subtitle"/>
+ </fo:block>
+ </xsl:template>
+
+</xsl:stylesheet>
diff --git a/stylesheets/lfs-xsl/pdf/lfs-xref.xsl b/stylesheets/lfs-xsl/pdf/lfs-xref.xsl
new file mode 100644
index 000000000..a3aaa07bb
--- /dev/null
+++ b/stylesheets/lfs-xsl/pdf/lfs-xref.xsl
@@ -0,0 +1,169 @@
+<?xml version='1.0' encoding='ISO-8859-1'?>
+
+<!--
+$LastChangedBy$
+$Date$
+-->
+
+<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
+ xmlns:xlink="http://www.w3.org/1999/xlink"
+ xmlns:fo="http://www.w3.org/1999/XSL/Format"
+ exclude-result-prefixes="xlink"
+ version="1.0">
+
+
+ <!-- This stylesheet fixes English punctuation in xref links
+ (as was requested by the publisher) via adding @role propagation
+ in xref tags.
+ This hack may not work with xref flavours not used in the book.
+ For other languages, just remove the xref @role attributes
+ in the book XML sources and/or comment-out the inclusion of
+ this file in lfs-pdf.xsl -->
+
+ <!-- xref:
+ Added role variable and use it when calling mode xref-to.-->
+ <!-- The original template is in {docbook-xsl}/fo/xref.xsl -->
+ <xsl:template match="xref" name="xref">
+ <xsl:param name="xhref" select="@xlink:href"/>
+ <!-- is the @xlink:href a local idref link? -->
+ <xsl:param name="xlink.idref">
+ <xsl:if test="starts-with($xhref,'#')
+ and (not(contains($xhref,'&#40;'))
+ or starts-with($xhref, '#xpointer&#40;id&#40;'))">
+ <xsl:call-template name="xpointer.idref">
+ <xsl:with-param name="xpointer" select="$xhref"/>
+ </xsl:call-template>
+ </xsl:if>
+ </xsl:param>
+ <xsl:param name="xlink.targets" select="key('id',$xlink.idref)"/>
+ <xsl:param name="linkend.targets" select="key('id',@linkend)"/>
+ <xsl:param name="target" select="($xlink.targets | $linkend.targets)[1]"/>
+ <xsl:param name="refelem" select="local-name($target)"/>
+ <!-- Added role variable -->
+ <xsl:variable name="role" select="@role"/>
+ <xsl:variable name="xrefstyle">
+ <xsl:choose>
+ <xsl:when test="@role and not(@xrefstyle)
+ and $use.role.as.xrefstyle != 0">
+ <xsl:value-of select="@role"/>
+ </xsl:when>
+ <xsl:otherwise>
+ <xsl:value-of select="@xrefstyle"/>
+ </xsl:otherwise>
+ </xsl:choose>
+ </xsl:variable>
+ <xsl:variable name="content">
+ <fo:inline xsl:use-attribute-sets="xref.properties">
+ <xsl:choose>
+ <xsl:when test="@endterm">
+ <xsl:variable name="etargets" select="key('id',@endterm)"/>
+ <xsl:variable name="etarget" select="$etargets[1]"/>
+ <xsl:choose>
+ <xsl:when test="count($etarget) = 0">
+ <xsl:message>
+ <xsl:value-of select="count($etargets)"/>
+ <xsl:text>Endterm points to nonexistent ID: </xsl:text>
+ <xsl:value-of select="@endterm"/>
+ </xsl:message>
+ <xsl:text>???</xsl:text>
+ </xsl:when>
+ <xsl:otherwise>
+ <xsl:apply-templates select="$etarget" mode="endterm"/>
+ </xsl:otherwise>
+ </xsl:choose>
+ </xsl:when>
+ <xsl:when test="$target/@xreflabel">
+ <xsl:call-template name="xref.xreflabel">
+ <xsl:with-param name="target" select="$target"/>
+ </xsl:call-template>
+ </xsl:when>
+ <xsl:when test="$target">
+ <xsl:if test="not(parent::citation)">
+ <xsl:apply-templates select="$target" mode="xref-to-prefix"/>
+ </xsl:if>
+ <xsl:apply-templates select="$target" mode="xref-to">
+ <xsl:with-param name="referrer" select="."/>
+ <xsl:with-param name="xrefstyle" select="$xrefstyle"/>
+ <!-- Propagate role -->
+ <xsl:with-param name="role" select="$role"/>
+ </xsl:apply-templates>
+ <xsl:if test="not(parent::citation)">
+ <xsl:apply-templates select="$target" mode="xref-to-suffix"/>
+ </xsl:if>
+ </xsl:when>
+ <xsl:otherwise>
+ <xsl:message>
+ <xsl:text>ERROR: xref linking to </xsl:text>
+ <xsl:value-of select="@linkend|@xlink:href"/>
+ <xsl:text> has no generated link text.</xsl:text>
+ </xsl:message>
+ <xsl:text>???</xsl:text>
+ </xsl:otherwise>
+ </xsl:choose>
+ </fo:inline>
+ </xsl:variable>
+ <!-- Convert it into an active link -->
+ <xsl:call-template name="simple.xlink">
+ <xsl:with-param name="content" select="$content"/>
+ </xsl:call-template>
+ <!-- Add standard page reference? -->
+ <xsl:choose>
+ <xsl:when test="not($target)">
+ <!-- page numbers only for local targets -->
+ </xsl:when>
+ <xsl:when test="starts-with(normalize-space($xrefstyle), 'select:')
+ and contains($xrefstyle, 'nopage')">
+ <!-- negative xrefstyle in instance turns it off -->
+ </xsl:when>
+ <!-- positive xrefstyle already handles it -->
+ <xsl:when test="not(starts-with(normalize-space($xrefstyle), 'select:')
+ and (contains($xrefstyle, 'page')
+ or contains($xrefstyle, 'Page')))
+ and ( $insert.xref.page.number = 'yes'
+ or $insert.xref.page.number = '1')
+ or local-name($target) = 'para'">
+ <xsl:apply-templates select="$target" mode="page.citation">
+ <xsl:with-param name="id" select="$target/@id|$target/@xml:id"/>
+ </xsl:apply-templates>
+ </xsl:when>
+ </xsl:choose>
+ </xsl:template>
+
+ <!-- sect* mode xref-to:
+ Propagate role to mode object.xref.markup (see ../lfs-common.xsl) -->
+ <!-- The original template is in {docbook-xsl}/fo/xref.xsl -->
+ <xsl:template match="section|simplesect|sect1|sect2|sect3|sect4|sect5
+ |refsect1|refsect2|refsect3|refsection" mode="xref-to">
+ <xsl:param name="referrer"/>
+ <xsl:param name="xrefstyle"/>
+ <xsl:param name="verbose" select="1"/>
+ <xsl:param name="role"/>
+ <xsl:apply-templates select="." mode="object.xref.markup">
+ <xsl:with-param name="purpose" select="'xref'"/>
+ <xsl:with-param name="xrefstyle" select="$xrefstyle"/>
+ <xsl:with-param name="referrer" select="$referrer"/>
+ <xsl:with-param name="verbose" select="$verbose"/>
+ <xsl:with-param name="role" select="$role"/>
+ </xsl:apply-templates>
+ </xsl:template>
+
+ <!-- insert.title.markup:
+ Apply the role value. -->
+ <!-- The original template is in {docbook-xsl}/fo/xref.xsl -->
+ <xsl:template match="*" mode="insert.title.markup">
+ <xsl:param name="purpose"/>
+ <xsl:param name="xrefstyle"/>
+ <xsl:param name="title"/>
+ <xsl:param name="role"/>
+ <xsl:choose>
+ <xsl:when test="$purpose = 'xref' and titleabbrev">
+ <xsl:apply-templates select="." mode="titleabbrev.markup"/>
+ </xsl:when>
+ <xsl:otherwise>
+ <xsl:copy-of select="$title"/>
+ <xsl:value-of select="$role"/>
+ </xsl:otherwise>
+ </xsl:choose>
+ </xsl:template>
+
+</xsl:stylesheet>