[project @ 2004-06-02 08:53:54 by panne]
authorpanne <unknown>
Wed, 2 Jun 2004 08:53:54 +0000 (08:53 +0000)
committerpanne <unknown>
Wed, 2 Jun 2004 08:53:54 +0000 (08:53 +0000)
Make the Building Guide almost valid DocBook XML V4.2 (to get the real thing,
simply add an XML prolog and change "artheader" to "articleinfo"). Things that
had to be changed:

 * XML tags are case-sensitive, so lowercase must be used for tags/attributes

 * Make "xref" an empty element.

 * "constant" is not allowed within "filename"

 * Move "indexterm" to a valid place.

 * Change some "&" to "&amp;"

 * The "_" character in titles makes some trouble in the TeX backend => avoid it

docs/building/building.sgml

index 0e2b254..ecac376 100644 (file)
@@ -1,13 +1,13 @@
 <!DOCTYPE Article PUBLIC "-//OASIS//DTD DocBook V3.1//EN">
 
-<Article id="building-guide">
+<article id="building-guide">
 
-<ArtHeader>
+<artheader>
 
-<Title>Building the Glasgow Functional Programming Tools Suite</Title>
-<Author><OtherName>The GHC Team</OtherName></Author>
-<Address><Email>glasgow-haskell-&lcub;users,bugs&rcub;@haskell.org</Email></Address>
-<PubDate>November 2001</PubDate>
+<title>Building the Glasgow Functional Programming Tools Suite</title>
+<author><othername>The GHC Team</othername></author>
+<address><email>glasgow-haskell-&lcub;users,bugs&rcub;@haskell.org</email></address>
+<pubdate>November 2001</pubdate>
 
     <abstract>
       <para>The Glasgow fptools suite is a collection of Functional
       installation system.</para>
 
       <para>This guide is intended for people who want to build or
-      modify programs from the Glasgow <Literal>fptools</Literal>
+      modify programs from the Glasgow <literal>fptools</literal>
       suite (as distinct from those who merely want to
-      <Emphasis>run</Emphasis> them). Installation instructions are
+      <emphasis>run</emphasis> them). Installation instructions are
       now provided in the user guide.</para>
 
       <para>The bulk of this guide applies to building on Unix
-      systems; see <XRef LinkEnd="winbuild"> for Windows notes.</para>
+      systems; see <xref linkend="winbuild"/> for Windows notes.</para>
     </abstract>
 
-  </artheader>
+</artheader>
 
 
   <sect1 id="sec-getting">
@@ -64,9 +64,7 @@
       </varlistentry>
 
       <varlistentry>
-       <term>The CVS repository.</term>
-       <indexterm><primary>CVS repository</primary>
-       </indexterm>
+       <term>The CVS repository.<indexterm><primary>CVS repository</primary></indexterm></term>
        <listitem>
          <para>We make releases infrequently.  If you want more
           up-to-the minute (but less tested) source code then you need
@@ -84,7 +82,7 @@
           scratch.</para>
 
          <para>More information about our CVS repository can be found
-          in <xref linkend="sec-cvs">.</para>
+          in <xref linkend="sec-cvs"/>.</para>
        </listitem>
       </varlistentry>
     </variablelist>
       <title>Getting access to the CVS Repository</title>
 
       <para>You can access the repository in one of two ways:
-      read-only (<xref linkend="cvs-read-only">), or read-write (<xref
-      linkend="cvs-read-write">).</para>
+      read-only (<xref linkend="cvs-read-only"/>), or read-write (<xref
+      linkend="cvs-read-write"/>).</para>
 
       <sect3 id="cvs-read-only">
        <title>Remote Read-only CVS Access</title>
          </listitem>
 
          <listitem>
-           <para>Now go to <xref linkend="cvs-first">.</para>
+           <para>Now go to <xref linkend="cvs-first"/>.</para>
          </listitem>
        </orderedlist>
       </sect3>
 
 
        <para>
-       <emphasis>Windows users: see the notes in <xref linkend="configure-ssh"> about <command>ssh</command> wrinkles!</emphasis>
+       <emphasis>Windows users: see the notes in <xref linkend="configure-ssh"/> about <command>ssh</command> wrinkles!</emphasis>
          </para>
 
 
 
          <listitem>
            <para>Set the following environment variables:</para>
-          <ItemizedList>
+          <itemizedlist>
           <listitem>
           <para>
           <constant>$HOME</constant>: points to your home directory.  This is where CVS
        </para>
        </listitem>
 
-       </ItemizedList>
+       </itemizedlist>
 
 
          </listitem>
          Put the following in <filename>$HOME/.cvsrc</filename>:
          </para>
          
-         <ProgramListing>
+         <programlisting>
          checkout -P
          release -d
          update -P
          diff -u
-         </ProgramListing>
+         </programlisting>
          
          <para>
          These are the default options for the specified CVS commands,
           some other junk. </para>
 
 <para>[Windows users.]  The following messages appear to be harmless:
-<Screen>
+<screen>
 setsockopt IPTOS_LOWDELAY: Invalid argument
 setsockopt IPTOS_THROUGHPUT: Invalid argument
-</Screen>
+</screen>
 </para>
 
 
@@ -437,7 +435,7 @@ setsockopt IPTOS_THROUGHPUT: Invalid argument
           you need at least the <literal>ghc</literal>,
           <literal>hslibs</literal> and <literal>libraries</literal>
           modules (for a full list of the projects available, see
-          <xref linkend="projects">).</para>
+          <xref linkend="projects"/>).</para>
 
          <para>Remember that if you do not have
           <literal>happy</literal> and/or <literal>Alex</literal>
@@ -726,9 +724,10 @@ $ cvs checkout nofib/spectral
 
     <variablelist>
       <varlistentry>
-       <term><literal>alex</literal></term>
-       <indexterm><primary><literal>alex</literal></primary>
-       <secondary>project</secondary></indexterm>
+       <term>
+          <literal>alex</literal>
+          <indexterm><primary><literal>alex</literal></primary><secondary>project</secondary></indexterm>
+        </term>
        <listitem>
          <para>The <ulink
          url="http://www.haskell.org/alex/">Alex</ulink> lexical
@@ -737,9 +736,11 @@ $ cvs checkout nofib/spectral
       </varlistentry>
 
       <varlistentry>
-       <term><literal>ghc</literal></term>
-       <indexterm><primary><literal>ghc</literal></primary>
-       <secondary>project</secondary></indexterm>
+       <term>
+          <literal>ghc</literal>
+          <indexterm><primary><literal>ghc</literal></primary>
+          <secondary>project</secondary></indexterm>
+        </term>
        <listitem>
          <para>The <ulink url="http://www.haskell.org/ghc/">Glasgow
          Haskell Compiler</ulink> (minus libraries).  Absolutely
@@ -748,8 +749,10 @@ $ cvs checkout nofib/spectral
       </varlistentry>
 
       <varlistentry>
-       <term><literal>glafp-utils</literal></term>
-       <indexterm><primary><literal>glafp-utils</literal></primary><secondary>project</secondary></indexterm>
+       <term>
+          <literal>glafp-utils</literal>
+          <indexterm><primary><literal>glafp-utils</literal></primary><secondary>project</secondary></indexterm>
+        </term>
        <listitem>
          <para>Utility programs, some of which are used by the
          build/installation system.  Required for pretty much
@@ -758,8 +761,10 @@ $ cvs checkout nofib/spectral
       </varlistentry>
 
       <varlistentry>
-       <term><literal>greencard</literal></term>
-       <indexterm><primary><literal>greencard</literal></primary><secondary>project</secondary></indexterm>
+       <term>
+          <literal>greencard</literal>
+         <indexterm><primary><literal>greencard</literal></primary><secondary>project</secondary></indexterm>
+        </term>
        <listitem>
          <para>The <ulink
          url="http://www.haskell.org/greencard/">GreenCard</ulink>
@@ -769,8 +774,10 @@ $ cvs checkout nofib/spectral
       </varlistentry>
 
       <varlistentry>
-       <term><literal>haggis</literal></term>
-       <indexterm><primary><literal>haggis</literal></primary><secondary>project</secondary></indexterm>
+       <term>
+          <literal>haggis</literal>
+         <indexterm><primary><literal>haggis</literal></primary><secondary>project</secondary></indexterm>
+        </term>
        <listitem>
          <para>The <ulink
          url="http://www.dcs.gla.ac.uk/fp/software/haggis/">Haggis</ulink>
@@ -779,8 +786,10 @@ $ cvs checkout nofib/spectral
       </varlistentry>
 
       <varlistentry>
-       <term><literal>haddock</literal></term>
-       <indexterm><primary><literal>haddock</literal></primary><secondary>project</secondary></indexterm>
+       <term>
+          <literal>haddock</literal>
+         <indexterm><primary><literal>haddock</literal></primary><secondary>project</secondary></indexterm>
+        </term>
        <listitem>
          <para>The <ulink
          url="http://www.haskell.org/haddock/">Haddock</ulink>
@@ -789,8 +798,10 @@ $ cvs checkout nofib/spectral
       </varlistentry>
 
       <varlistentry>
-       <term><literal>happy</literal></term>
-       <indexterm><primary><literal>happy</literal></primary><secondary>project</secondary></indexterm>
+       <term>
+          <literal>happy</literal>
+          <indexterm><primary><literal>happy</literal></primary><secondary>project</secondary></indexterm>
+        </term>
        <listitem>
          <para>The <ulink
          url="http://www.haskell.org/happy/">Happy</ulink> Parser
@@ -799,8 +810,10 @@ $ cvs checkout nofib/spectral
       </varlistentry>
 
       <varlistentry>
-       <term><literal>hdirect</literal></term>
-       <indexterm><primary><literal>hdirect</literal></primary><secondary>project</secondary></indexterm>
+       <term>
+          <literal>hdirect</literal>
+          <indexterm><primary><literal>hdirect</literal></primary><secondary>project</secondary></indexterm>
+        </term>
        <listitem>
          <para>The <ulink
          url="http://www.haskell.org/hdirect/">H/Direct</ulink>
@@ -809,8 +822,10 @@ $ cvs checkout nofib/spectral
       </varlistentry>
 
       <varlistentry>
-       <term><literal>hood</literal></term>
-       <indexterm><primary><literal>hood</literal></primary><secondary>project</secondary></indexterm>
+       <term>
+          <literal>hood</literal>
+          <indexterm><primary><literal>hood</literal></primary><secondary>project</secondary></indexterm>
+        </term>
        <listitem>
          <para>The <ulink url="http://www.haskell.org/hood/">Haskell
          Object Observation Debugger</ulink>.</para>
@@ -818,8 +833,10 @@ $ cvs checkout nofib/spectral
       </varlistentry>
 
       <varlistentry>
-       <term><literal>hslibs</literal></term>
-       <indexterm><primary><literal>hslibs</literal></primary><secondary>project</secondary></indexterm>
+       <term>
+          <literal>hslibs</literal>
+          <indexterm><primary><literal>hslibs</literal></primary><secondary>project</secondary></indexterm>
+        </term>
        <listitem>
          <para>Supplemental libraries for GHC
          (<emphasis>required</emphasis> for building GHC).</para>
@@ -827,8 +844,10 @@ $ cvs checkout nofib/spectral
       </varlistentry>
 
       <varlistentry>
-       <term><literal>libraries</literal></term>
-       <indexterm><primary><literal></literal></primary><secondary>project</secondary></indexterm>
+       <term>
+          <literal>libraries</literal>
+          <indexterm><primary><literal></literal></primary><secondary>project</secondary></indexterm>
+        </term>
        <listitem>
          <para>Hierarchical Haskell library suite
          (<emphasis>required</emphasis> for building GHC).</para>
@@ -836,16 +855,20 @@ $ cvs checkout nofib/spectral
       </varlistentry>
 
       <varlistentry>
-       <term><literal>mhms</literal></term>
-       <indexterm><primary><literal></literal></primary><secondary>project</secondary></indexterm>
+       <term>
+          <literal>mhms</literal>
+          <indexterm><primary><literal></literal></primary><secondary>project</secondary></indexterm>
+        </term>
        <listitem>
          <para>The Modular Haskell Metric System.</para>
        </listitem>
       </varlistentry>
 
       <varlistentry>
-       <term><literal>nofib</literal></term>
-       <indexterm><primary><literal>nofib</literal></primary><secondary>project</secondary></indexterm>
+       <term>
+          <literal>nofib</literal>
+          <indexterm><primary><literal>nofib</literal></primary><secondary>project</secondary></indexterm>
+        </term>
        <listitem>
          <para>The NoFib suite: A collection of Haskell programs used
          primarily for benchmarking.</para>
@@ -853,8 +876,10 @@ $ cvs checkout nofib/spectral
       </varlistentry>
 
       <varlistentry>
-       <term><literal>testsuite</literal></term>
-       <indexterm><primary><literal>testsuite</literal></primary><secondary>project</secondary></indexterm>
+       <term>
+          <literal>testsuite</literal>
+          <indexterm><primary><literal>testsuite</literal></primary><secondary>project</secondary></indexterm>
+        </term>
        <listitem>
          <para>A testing framework, including GHC's regression test
          suite.</para>
@@ -876,9 +901,8 @@ $ cvs checkout nofib/spectral
 
     <orderedlist>
 
-      <listitem>
-       <indexterm><primary>Disk space needed</primary></indexterm>
-       <para>Disk space needed: from about 100Mb for a basic GHC
+      <listitem><para><indexterm><primary>Disk space needed</primary></indexterm>Disk
+        space needed: from about 100Mb for a basic GHC
        build, up to probably 500Mb for a GHC build with everything
        included (libraries built several different ways,
        etc.).</para>
@@ -886,23 +910,23 @@ $ cvs checkout nofib/spectral
 
       <listitem>
        <para>Use an appropriate machine / operating system.  <xref
-       linkend="sec-port-info"> lists the supported platforms; if
+       linkend="sec-port-info"/> lists the supported platforms; if
        yours isn't amongst these then you can try porting GHC (see
-       <xref linkend="sec-porting-ghc">).</para>
+       <xref linkend="sec-porting-ghc"/>).</para>
       </listitem>
 
       <listitem>
        <para>Be sure that the &ldquo;pre-supposed&rdquo; utilities are
-        installed.  <Xref LinkEnd="sec-pre-supposed">
+        installed.  <xref linkend="sec-pre-supposed"/>
         elaborates.</para>
       </listitem>
 
       <listitem>
        <para>If you have any problem when building or installing the
-        Glasgow tools, please check the &ldquo;known pitfalls&rdquo; (<Xref
-        LinkEnd="sec-build-pitfalls">).  Also check the FAQ for the
+        Glasgow tools, please check the &ldquo;known pitfalls&rdquo; (<xref
+        linkend="sec-build-pitfalls"/>).  Also check the FAQ for the
         version you're building, which is part of the User's Guide and
-        available on the <ulink URL="http://www.haskell.org/ghc/" >GHC web
+        available on the <ulink url="http://www.haskell.org/ghc/" >GHC web
         site</ulink>.</para>
 
        <indexterm><primary>bugs</primary><secondary>known</secondary></indexterm>
@@ -978,13 +1002,13 @@ $ cvs checkout nofib/spectral
 
       <variablelist>
        <varlistentry>
-         <term>alpha-dec-{osf,linux,freebsd,openbsd,netbsd}:</term>
+         <term>alpha-dec-{osf,linux,freebsd,openbsd,netbsd}:
          <indexterm><primary>alpha-dec-osf</primary></indexterm>
          <indexterm><primary>alpha-dec-linux</primary></indexterm>
          <indexterm><primary>alpha-dec-freebsd</primary></indexterm>
          <indexterm><primary>alpha-dec-openbsd</primary></indexterm>
          <indexterm><primary>alpha-dec-netbsd</primary></indexterm>
-         
+          </term>
          <listitem>
            <para>The OSF port is currently working (as of GHC version
            5.02.1) and well supported.  The native code generator is
@@ -994,8 +1018,9 @@ $ cvs checkout nofib/spectral
        </varlistentry>
 
        <varlistentry>
-         <term>sparc-sun-sunos4</term>
-         <indexterm><primary>sparc-sun-sunos4</primary></indexterm>
+         <term>sparc-sun-sunos4
+           <indexterm><primary>sparc-sun-sunos4</primary></indexterm>
+          </term>
          <listitem>
            <para>Probably works with minor tweaks, hasn't been tested
            for a while.</para>
@@ -1003,8 +1028,9 @@ $ cvs checkout nofib/spectral
        </varlistentry>
 
        <varlistentry>
-         <term>sparc-sun-solaris2</term>
-         <indexterm><primary>sparc-sun-solaris2</primary></indexterm>
+         <term>sparc-sun-solaris2
+            <indexterm><primary>sparc-sun-solaris2</primary></indexterm>
+          </term>
          <listitem>
            <para>Fully supported (at least for Solaris 2.7 and 2.6),
            including native-code generator.</para>
@@ -1012,8 +1038,9 @@ $ cvs checkout nofib/spectral
        </varlistentry>
 
        <varlistentry>
-         <term>sparc-unknown-openbsd</term>
-         <indexterm><primary>sparc-unknown-openbsd</primary></indexterm>
+         <term>sparc-unknown-openbsd
+            <indexterm><primary>sparc-unknown-openbsd</primary></indexterm>
+          </term>
          <listitem>
            <para>Supported, including native-code generator. The
            same should also be true of NetBSD</para>
@@ -1021,8 +1048,9 @@ $ cvs checkout nofib/spectral
        </varlistentry>
 
        <varlistentry>
-         <term>hppa1.1-hp-hpux (HP-PA boxes running HPUX 9.x)</term>
-         <indexterm><primary>hppa1.1-hp-hpux</primary></indexterm>
+         <term>hppa1.1-hp-hpux (HP-PA boxes running HPUX 9.x)
+            <indexterm><primary>hppa1.1-hp-hpux</primary></indexterm>
+          </term>
          <listitem>
            <para>A registerised port is available for version 4.08,
            but GHC hasn't been built on that platform since (as far
@@ -1031,11 +1059,12 @@ $ cvs checkout nofib/spectral
        </varlistentry>
 
        <varlistentry>
-         <term>i386-unknown-linux (PCs running Linux, ELF binary format)</term>
-         <indexterm><primary>i386-*-linux</primary></indexterm>
+         <term>i386-unknown-linux (PCs running Linux, ELF binary format)
+            <indexterm><primary>i386-*-linux</primary></indexterm>
+          </term>
          <listitem>
            <para>GHC works registerised and has a native code
-            generator.  You <Emphasis>must</Emphasis> have GCC 2.7.x
+            generator.  You <emphasis>must</emphasis> have GCC 2.7.x
             or later.  NOTE about <literal>glibc</literal> versions:
             GHC binaries built on a system running <literal>glibc
             2.0</literal> won't work on a system running
@@ -1047,9 +1076,9 @@ $ cvs checkout nofib/spectral
        </varlistentry>
 
        <varlistentry>
-         <term>i386-unknown-freebsd (PCs running FreeBSD 2.2 or
-         higher)</term>
-         <indexterm><primary>i386-unknown-freebsd</primary></indexterm>
+         <term>i386-unknown-freebsd (PCs running FreeBSD 2.2 or higher)
+            <indexterm><primary>i386-unknown-freebsd</primary></indexterm>
+          </term>
          <listitem>
            <para>GHC works registerised.  Pre-built packages are
             available in the native package format, so if you just
@@ -1060,8 +1089,9 @@ $ cvs checkout nofib/spectral
        </varlistentry>
 
        <varlistentry>
-         <term>i386-unknown-openbsd (PCs running OpenBSD)</term>
-         <indexterm><primary>i386-unknown-openbsd</primary></indexterm> 
+         <term>i386-unknown-openbsd (PCs running OpenBSD)
+            <indexterm><primary>i386-unknown-openbsd</primary></indexterm> 
+          </term>
          <listitem>
            <para>Supported, with native code generator.  Packages are
            available through the ports system in the native package
@@ -1070,8 +1100,9 @@ $ cvs checkout nofib/spectral
        </varlistentry>
 
        <varlistentry>
-         <term>i386-unknown-netbsd (PCs running NetBSD)</term>
-           <indexterm><primary>i386-unknown-netbsd</primary></indexterm>
+         <term>i386-unknown-netbsd (PCs running NetBSD)
+            <indexterm><primary>i386-unknown-netbsd</primary></indexterm>
+          </term>
          <listitem>
            <para>Will require some minor porting effort, but should
            work registerised.</para>
@@ -1079,8 +1110,9 @@ $ cvs checkout nofib/spectral
        </varlistentry>
 
        <varlistentry>
-         <term>i386-unknown-mingw32 (PCs running Windows)</term>
-         <indexterm><primary>i386-unknown-mingw32</primary></indexterm>
+         <term>i386-unknown-mingw32 (PCs running Windows)
+            <indexterm><primary>i386-unknown-mingw32</primary></indexterm>
+          </term>
          <listitem>
            <para>Fully supported under Win9x, WinNT, Win2k, and
             WinXP.  Includes a native code generator.  Building from
@@ -1091,8 +1123,9 @@ $ cvs checkout nofib/spectral
        </varlistentry>
 
        <varlistentry>
-         <term>ia64-unknown-linux</term>
-         <indexterm><primary>ia64-unknown-linux</primary></indexterm>
+         <term>ia64-unknown-linux
+            <indexterm><primary>ia64-unknown-linux</primary></indexterm>
+          </term>
          <listitem>
            <para>Supported, except there is no native code
            generator.</para>
@@ -1100,8 +1133,9 @@ $ cvs checkout nofib/spectral
        </varlistentry>
 
        <varlistentry>
-         <term>x86_64-unknown-linux</term>
-         <indexterm><primary>x86_64-unknown-linux</primary></indexterm>
+         <term>x86_64-unknown-linux
+            <indexterm><primary>x86_64-unknown-linux</primary></indexterm>
+          </term>
          <listitem>
            <para>GHC currently works unregisterised.  A registerised
            port is in progress.</para>
@@ -1109,8 +1143,9 @@ $ cvs checkout nofib/spectral
        </varlistentry>
 
        <varlistentry>
-         <term>amd64-unknown-openbsd</term>
-         <indexterm><primary>amd64-unknown-linux</primary></indexterm>
+         <term>amd64-unknown-openbsd
+            <indexterm><primary>amd64-unknown-linux</primary></indexterm>
+          </term>
          <listitem>
             <para>(This is the same as x86_64-unknown-openbsd). GHC
                 currently works unregisterised.  A registerised port is in
@@ -1119,8 +1154,9 @@ $ cvs checkout nofib/spectral
        </varlistentry>
 
        <varlistentry>
-         <term>mips-sgi-irix5</term>
-         <indexterm><primary>mips-sgi-irix[5-6]</primary></indexterm>
+         <term>mips-sgi-irix5
+            <indexterm><primary>mips-sgi-irix[5-6]</primary></indexterm>
+          </term>
          <listitem>
            <para>Port has worked in the past, but hasn't been tested
             for some time (and will certainly have rotted in various
@@ -1131,16 +1167,18 @@ $ cvs checkout nofib/spectral
        </varlistentry>
 
        <varlistentry>
-         <term>mips64-sgi-irix6</term>
-         <indexterm><primary>mips-sgi-irix6</primary></indexterm>
+         <term>mips64-sgi-irix6
+            <indexterm><primary>mips-sgi-irix6</primary></indexterm>
+          </term>
          <listitem>
            <para>GHC currently works unregisterised.</para>
          </listitem>
        </varlistentry>
 
        <varlistentry>
-         <term>powerpc-ibm-aix</term>
-         <indexterm><primary>powerpc-ibm-aix</primary></indexterm>
+         <term>powerpc-ibm-aix
+            <indexterm><primary>powerpc-ibm-aix</primary></indexterm>
+          </term>
          <listitem>
            <para>Port currently doesn't work, needs some minimal
             porting effort.  As usual, we don't have access to
@@ -1150,8 +1188,9 @@ $ cvs checkout nofib/spectral
        </varlistentry>
 
        <varlistentry>
-         <term>powerpc-apple-darwin</term>
-         <indexterm><primary>powerpc-apple-darwin</primary></indexterm> 
+         <term>powerpc-apple-darwin
+            <indexterm><primary>powerpc-apple-darwin</primary></indexterm> 
+          </term>
          <listitem>
            <para>Supported registerised.  Native code generator is
            almost working.</para>
@@ -1159,8 +1198,9 @@ $ cvs checkout nofib/spectral
        </varlistentry>
 
        <varlistentry>
-         <term>powerpc-apple-linux</term>
-         <indexterm><primary>powerpc-apple-linux</primary></indexterm> 
+         <term>powerpc-apple-linux
+            <indexterm><primary>powerpc-apple-linux</primary></indexterm> 
+          </term>
          <listitem>
            <para>Not supported (yet).</para>
          </listitem>
@@ -1199,14 +1239,15 @@ $ cvs checkout nofib/spectral
     <variablelist>
 
       <varlistentry>
-       <term>GHC</term>
-       <indexterm><primary>pre-supposed: GHC</primary></indexterm>
-       <indexterm><primary>GHC, pre-supposed</primary></indexterm>
+       <term>GHC
+          <indexterm><primary>pre-supposed: GHC</primary></indexterm>
+          <indexterm><primary>GHC, pre-supposed</primary></indexterm>
+        </term>
        <listitem>
          <para>GHC is required to build many of the tools, including
          GHC itself.  If you need to port GHC to your platform
          because there isn't a binary distribution of GHC available,
-         then see <xref linkend="sec-porting-ghc">.</para>
+         then see <xref linkend="sec-porting-ghc"/>.</para>
 
          <para>Which version of GHC you need will depend on the
          packages you intend to build.  GHC itself will normally
@@ -1216,9 +1257,10 @@ $ cvs checkout nofib/spectral
       </varlistentry>
 
       <varlistentry>
-       <term>Perl</term>
-       <indexterm><primary>pre-supposed: Perl</primary></indexterm>
-       <indexterm><primary>Perl, pre-supposed</primary></indexterm>
+       <term>Perl
+          <indexterm><primary>pre-supposed: Perl</primary></indexterm>
+          <indexterm><primary>Perl, pre-supposed</primary></indexterm>
+        </term>
        <listitem>
          <para><emphasis>You have to have Perl to proceed!</emphasis>
           Perl version 5 at least is required.  GHC has been known to
@@ -1240,10 +1282,10 @@ $ cvs checkout nofib/spectral
       </varlistentry>
 
       <varlistentry>
-       <term>GNU C (<command>gcc</command>)</term>
-       <indexterm><primary>pre-supposed: GCC (GNU C
-       compiler)</primary></indexterm> <indexterm><primary>GCC (GNU C
-       compiler), pre-supposed</primary></indexterm>
+       <term>GNU C (<command>gcc</command>)
+          <indexterm><primary>pre-supposed: GCC (GNU C compiler)</primary></indexterm>
+          <indexterm><primary>GCC (GNU C compiler), pre-supposed</primary></indexterm>
+        </term>
        <listitem>
          <para>We recommend using GCC version 2.95.2 on all
           platforms.  Failing that, version 2.7.2 is stable on most
@@ -1265,9 +1307,9 @@ $ cvs checkout nofib/spectral
       </varlistentry>
 
       <varlistentry>
-       <term>GNU Make</term>
-       <indexterm><primary>make</primary><secondary>GNU</secondary>
-       </indexterm>
+       <term>GNU Make
+          <indexterm><primary>make</primary><secondary>GNU</secondary></indexterm>
+        </term>
        <listitem>
          <para>The fptools build system makes heavy use of features
          specific to GNU <command>make</command>, so you must have
@@ -1277,8 +1319,9 @@ $ cvs checkout nofib/spectral
       </varlistentry>
 
       <varlistentry>
-       <term>Happy</term>
-       <indexterm><primary>Happy</primary></indexterm>
+       <term>Happy
+          <indexterm><primary>Happy</primary></indexterm>
+        </term>
        <listitem>
          <para>Happy is a parser generator tool for Haskell, and is
           used to generate GHC's parsers.  Happy is written in
@@ -1294,8 +1337,9 @@ $ cvs checkout nofib/spectral
       </varlistentry>
 
       <varlistentry>
-       <term>Alex</term>
-       <indexterm><primary>Alex</primary></indexterm>
+       <term>Alex
+          <indexterm><primary>Alex</primary></indexterm>
+        </term>
        <listitem>
          <para>Alex is a lexical-analyser generator for Haskell,
          which GHC uses to generate its lexer.  Like Happy, Alex is
@@ -1307,9 +1351,10 @@ $ cvs checkout nofib/spectral
       </varlistentry>
 
       <varlistentry>
-       <term>autoconf</term>
-       <indexterm><primary>pre-supposed: autoconf</primary></indexterm>
-       <indexterm><primary>autoconf, pre-supposed</primary></indexterm>
+       <term>autoconf
+          <indexterm><primary>pre-supposed: autoconf</primary></indexterm>
+          <indexterm><primary>autoconf, pre-supposed</primary></indexterm>
+        </term>
        <listitem>
          <para>GNU autoconf is needed if you intend to build from the
           CVS sources, it is <emphasis>not</emphasis> needed if you
@@ -1329,9 +1374,10 @@ $ cvs checkout nofib/spectral
       </varlistentry>
 
       <varlistentry>
-       <term><command>sed</command></term>
-       <indexterm><primary>pre-supposed: sed</primary></indexterm>
-       <indexterm><primary>sed, pre-supposed</primary></indexterm>
+       <term><command>sed</command>
+          <indexterm><primary>pre-supposed: sed</primary></indexterm>
+          <indexterm><primary>sed, pre-supposed</primary></indexterm>
+        </term>
        <listitem>
          <para>You need a working <command>sed</command> if you are
           going to build from sources.  The build-configuration stuff
@@ -1355,9 +1401,10 @@ $ cvs checkout nofib/spectral
 
       <variablelist>
        <varlistentry>
-         <term>PVM version 3:</term>
+         <term>PVM version 3:
          <indexterm><primary>pre-supposed: PVM3 (Parallel Virtual Machine)</primary></indexterm>
-         <indexterm><primary>PVM3 (Parallel Virtual Machine), pre-supposed</primary></indexterm>
+            <indexterm><primary>PVM3 (Parallel Virtual Machine), pre-supposed</primary></indexterm>
+          </term>
          <listitem>
            <para>PVM is the Parallel Virtual Machine on which
             Parallel Haskell programs run.  (You only need this if you
@@ -1379,8 +1426,9 @@ $ cvs checkout nofib/spectral
        </varlistentry>
 
        <varlistentry>
-         <term><command>bash</command>:</term>
-         <indexterm><primary>bash, presupposed (Parallel Haskell only)</primary></indexterm>
+         <term><command>bash</command>:
+            <indexterm><primary>bash, presupposed (Parallel Haskell only)</primary></indexterm>
+          </term>
          <listitem>
            <para>Sadly, the <command>gr2ps</command> script, used to
             convert &ldquo;parallelism profiles&rdquo; to PostScript,
@@ -1396,9 +1444,10 @@ $ cvs checkout nofib/spectral
 
       <variablelist>
        <varlistentry>
-         <term>Flex</term>
-         <indexterm><primary>pre-supposed: flex</primary></indexterm> 
-         <indexterm><primary>flex, pre-supposed</primary></indexterm>
+         <term>Flex
+            <indexterm><primary>pre-supposed: flex</primary></indexterm> 
+            <indexterm><primary>flex, pre-supposed</primary></indexterm>
+          </term>
          <listitem>
            <para>This is a quite-a-bit-better-than-Lex lexer.  Used
             to build a couple of utilities in
@@ -1411,7 +1460,7 @@ $ cvs checkout nofib/spectral
 
       <para>More tools are required if you want to format the documentation
       that comes with GHC and other fptools projects.  See <xref
-      linkend="building-docs">.</para>
+      linkend="building-docs"/>.</para>
     </sect2>
   </sect1>
 
@@ -1533,8 +1582,8 @@ $ make install
       are two (If you don't have either, the source distribution
       includes sources for the X11
       <command>lndir</command>&mdash;check out
-      <filename>fptools/glafp-utils/lndir</filename>). See <Xref
-      LinkEnd="sec-storysofar"> for a typical invocation.</para>
+      <filename>fptools/glafp-utils/lndir</filename>). See <xref
+      linkend="sec-storysofar"/> for a typical invocation.</para>
 
       <para>The build tree does not need to be anywhere near the
       source tree in the file system.  Indeed, one advantage of
@@ -1542,8 +1591,8 @@ $ make install
       can be placed in a non-backed-up partition, saving your systems
       support people from backing up untold megabytes of
       easily-regenerated, and rapidly-changing, gubbins.  The golden
-      rule is that (with a single exception&mdash;<XRef
-      LinkEnd="sec-build-config">) <emphasis>absolutely everything in
+      rule is that (with a single exception&mdash;<xref
+      linkend="sec-build-config"/>) <emphasis>absolutely everything in
       the build tree is either a symbolic link to the source tree, or
       else is mechanically generated</emphasis>.  It should be
       perfectly OK for your build tree to vanish overnight; an hour or
@@ -1578,7 +1627,7 @@ $ make install
       <constant>&dollar;(FPTOOLS&lowbar;TOP)</constant> unless
       otherwise stated.  For example, the file
       <filename>ghc/mk/target.mk</filename> is actually
-      <filename><constant>&dollar;(FPTOOLS&lowbar;TOP)</constant>/ghc/mk/target.mk</filename>.</para>
+      <filename>&dollar;(FPTOOLS&lowbar;TOP)/ghc/mk/target.mk</filename>.</para>
     </sect2>
 
     <sect2 id="sec-build-config">
@@ -1617,15 +1666,15 @@ $ make install
            <para>Change directory to
             <constant>&dollar;(FPTOOLS&lowbar;TOP)</constant> and
             issue the command</para>
-<ProgramListing>
+<programlisting>
 autoreconf
-</ProgramListing>
+</programlisting>
             <indexterm><primary>autoreconf</primary></indexterm>
             <para>(with no arguments). This GNU program (recursively) converts
-            <filename><constant>&dollar;(FPTOOLS&lowbar;TOP)</constant>/configure.ac</filename> and
-            <filename><constant>&dollar;(FPTOOLS&lowbar;TOP)</constant>/aclocal.m4</filename>
+            <filename>&dollar;(FPTOOLS&lowbar;TOP)/configure.ac</filename> and
+            <filename>&dollar;(FPTOOLS&lowbar;TOP)/aclocal.m4</filename>
             to a shell script called
-            <filename><constant>&dollar;(FPTOOLS&lowbar;TOP)</constant>/configure</filename>.
+            <filename>&dollar;(FPTOOLS&lowbar;TOP)/configure</filename>.
              If <command>autoreconf</command> bleats that it can't write the file <filename>configure</filename>,
              then delete the latter and try again.  Note that you must use <command>autoreconf</command>,
              and not the old <command>autoconf</command>!  If you erroneously use the latter, you'll get 
@@ -1635,7 +1684,7 @@ autoreconf
            <para>Some projects, including GHC, have their own configure script.
             <command>autoreconf</command> takes care of that, too, so all you have
              to do is calling <command>autoreconf</command> in the top-level directory
-            <constant>&dollar;(FPTOOLS&lowbar;TOP)</constant>.</para>
+            <filename>&dollar;(FPTOOLS&lowbar;TOP)</filename>.</para>
 
            <para>These steps are completely platform-independent; they just mean
             that the human-written files (<filename>configure.ac</filename> and
@@ -1651,14 +1700,14 @@ autoreconf
            <para>Runs the newly-created <command>configure</command>
            script, thus:</para>
 
-<ProgramListing>
+<programlisting>
 ./configure <optional><parameter>args</parameter></optional>
-</ProgramListing>
+</programlisting>
 
            <para><command>configure</command>'s mission is to scurry
             round your computer working out what architecture it has,
             what operating system, whether it has the
-            <Function>vfork</Function> system call, where
+            <function>vfork</function> system call, where
             <command>tar</command> is kept, whether
             <command>gcc</command> is available, where various obscure
             <literal>&num;include</literal> files are, whether it's a
@@ -1703,9 +1752,9 @@ autoreconf
 
            <variablelist>
              <varlistentry>
-               <term><literal>--with-ghc=<parameter>path</parameter></literal></term>
-               <indexterm><primary><literal>--with-ghc</literal></primary>
-               </indexterm>
+               <term><literal>--with-ghc=<parameter>path</parameter></literal>
+                  <indexterm><primary><literal>--with-ghc</literal></primary></indexterm>
+                </term>
                <listitem>
                  <para>Specifies the path to an installed GHC which
                  you would like to use.  This compiler will be used
@@ -1720,9 +1769,9 @@ autoreconf
              </varlistentry>
              
              <varlistentry>
-               <term><literal>--with-hc=<parameter>path</parameter></literal></term>
-               <indexterm><primary><literal>--with-hc</literal></primary>
-               </indexterm>
+               <term><literal>--with-hc=<parameter>path</parameter></literal>
+                  <indexterm><primary><literal>--with-hc</literal></primary></indexterm>
+                </term>
                <listitem>
                  <para>Specifies the path to any installed Haskell
                  compiler.  This compiler will be used for compiling
@@ -1732,9 +1781,9 @@ autoreconf
              </varlistentry>
              
              <varlistentry>
-               <term><literal>--with-gcc=<parameter>path</parameter></literal></term>
-               <indexterm><primary><literal>--with-gcc</literal></primary>
-               </indexterm>
+               <term><literal>--with-gcc=<parameter>path</parameter></literal>
+                  <indexterm><primary><literal>--with-gcc</literal></primary></indexterm>
+                </term>
                <listitem>
                  <para>Specifies the path to the installed GCC. This
                  compiler will be used to compile all C files,
@@ -1795,9 +1844,9 @@ autoreconf
       <para>For example, <filename>config.mk.in</filename> contains
       the definition:</para>
 
-<ProgramListing>
+<programlisting>
 GhcHcOpts=-O -Rghc-timing
-</ProgramListing>
+</programlisting>
 
       <para>The accompanying comment explains that this is the list of
       flags passed to GHC when building GHC itself.  For doing
@@ -1807,9 +1856,9 @@ GhcHcOpts=-O -Rghc-timing
       
       <para>or, if you prefer,</para>
 
-<ProgramListing>
+<programlisting>
 GhcHcOpts += -DDEBUG
-</ProgramListing>
+</programlisting>
 
       <para>GNU <command>make</command> allows existing definitions to
       have new text appended using the &ldquo;<literal>+=</literal>&rdquo;
@@ -1820,9 +1869,9 @@ GhcHcOpts += -DDEBUG
       lot quicker), you can just override
       <literal>GhcLibHcOpts</literal> altogether:</para>
 
-<ProgramListing>
+<programlisting>
 GhcHcOpts=-DDEBUG -Rghc-timing
-</ProgramListing>
+</programlisting>
 
       <para>When reading <filename>config.mk.in</filename>, remember
       that anything between &ldquo;@...@&rdquo; signs is going to be substituted
@@ -1831,9 +1880,9 @@ GhcHcOpts=-DDEBUG -Rghc-timing
       you want, but you need to be a bit surer what you are doing.
       For example, there's a line that says:</para>
 
-<ProgramListing>
+<programlisting>
 TAR = @TarCmd@
-</ProgramListing>
+</programlisting>
 
       <para>This defines the Make variables <constant>TAR</constant>
       to the pathname for a <command>tar</command> that
@@ -1841,9 +1890,9 @@ TAR = @TarCmd@
       own pet <command>tar</command> you want to use instead, that's
       fine. Just add this line to <filename>mk/build.mk</filename>:</para>
 
-<ProgramListing>
+<programlisting>
 TAR = mytar
-</ProgramListing>
+</programlisting>
 
       <para>You do not <emphasis>have</emphasis> to have a
       <filename>mk/build.mk</filename> file at all; if you don't,
@@ -1874,8 +1923,8 @@ TAR = mytar
           or source distribution).  Say you call the root directory
           <filename>myfptools</filename> (it does not have to be
           called <filename>fptools</filename>).  Make sure that you
-          have the essential files (see <XRef
-          LinkEnd="sec-source-tree">).</para>
+          have the essential files (see <xref
+          linkend="sec-source-tree"/>).</para>
        </listitem>
 
        <listitem>
@@ -2207,8 +2256,8 @@ $ emacs mk/build.mk
          <listitem>
            <para>is only available in the root directory
             <constant>&dollar;(FPTOOLS&lowbar;TOP)</constant>; it has
-            been discussed in <XRef
-            LinkEnd="sec-build-config">.</para>
+            been discussed in <xref
+            linkend="sec-build-config"/>.</para>
          </listitem>
        </varlistentry>
 
@@ -2224,9 +2273,9 @@ $ emacs mk/build.mk
             generated <filename>.depend</filename> file will contain
             the dependency:</para>
 
-<ProgramListing>
+<programlisting>
 Foo.o : Baz.hi
-</ProgramListing>
+</programlisting>
 
            <para>which says that the object file
             <filename>Foo.o</filename> depends on the interface file
@@ -2293,9 +2342,9 @@ Foo.o : Baz.hi
       <command>make</command> is going to rebuild everything anyway,
       the following hack may be useful:</para>
 
-<ProgramListing>
+<programlisting>
 gmake FAST=YES 
-</ProgramListing>
+</programlisting>
 
       <para>This tells the make system to ignore dependencies and just
       build what you tell it to.  In other words, it's equivalent to
@@ -2364,7 +2413,7 @@ gmake FAST=YES
 
 <indexterm><primary>Makefile, minimal</primary></indexterm>
 
-<ProgramListing>
+<programlisting>
 #     Makefile for fptools project "small"
 
 TOP = ..
@@ -2374,7 +2423,7 @@ SRCS = $(wildcard *.lhs) $(wildcard *.c)
 HS_PROG = small
 
 include $(TOP)/target.mk
-</ProgramListing>
+</programlisting>
 
       <para>this <filename>Makefile</filename> has three
       sections:</para>
@@ -2393,11 +2442,11 @@ directive.
 
           a file of &ldquo;boilerplate&rdquo; code from the level
           above (which in this case will be
-          <filename><constant>FPTOOLS&lowbar;TOP</constant>/mk/boilerplate.mk</filename><indexterm><primary>boilerplate.mk</primary></indexterm>).
+          <filename>FPTOOLS&lowbar;TOP/mk/boilerplate.mk</filename><indexterm><primary>boilerplate.mk</primary></indexterm>).
           As its name suggests, <filename>boilerplate.mk</filename>
           consists of a large quantity of standard
           <filename>Makefile</filename> code.  We discuss this
-          boilerplate in more detail in <XRef LinkEnd="sec-boiler">.
+          boilerplate in more detail in <xref linkend="sec-boiler"/>.
           <indexterm><primary>include, directive in
           Makefiles</primary></indexterm> <indexterm><primary>Makefile
           inclusion</primary></indexterm></para>
@@ -2409,9 +2458,9 @@ directive.
           directory in which the <filename>boilerplate.mk</filename>
           file is.  It is <emphasis>not</emphasis> OK to simply say</para>
 
-<ProgramListing>
+<programlisting>
 include ../mk/boilerplate.mk  # NO NO NO
-</ProgramListing>
+</programlisting>
 
 
           <para>Why?  Because the <filename>boilerplate.mk</filename>
@@ -2424,7 +2473,7 @@ include ../mk/boilerplate.mk  # NO NO NO
           <literal>include</literal>d sits.)  In general,
           <emphasis>every file <filename>foo.mk</filename> assumes
           that
-          <filename><constant>&dollar;(TOP)</constant>/mk/foo.mk</filename>
+          <filename>&dollar;(TOP)/mk/foo.mk</filename>
           refers to itself.</emphasis> It is up to the
           <filename>Makefile</filename> doing the
           <literal>include</literal> to ensure this is the case.</para>
@@ -2449,8 +2498,8 @@ include ../mk/boilerplate.mk  # NO NO NO
           <constant>HS&lowbar;PROG</constant><indexterm><primary>HS&lowbar;PROG</primary></indexterm>
           (the executable binary to be built).  We will discuss in
           more detail what the &ldquo;standard variables&rdquo; are,
-          and how they affect what happens, in <XRef
-          LinkEnd="sec-targets">.</para>
+          and how they affect what happens, in <xref
+          linkend="sec-targets"/>.</para>
 
          <para>The definition for <constant>SRCS</constant> uses the
           useful GNU <command>make</command> construct
@@ -2469,12 +2518,12 @@ include ../mk/boilerplate.mk  # NO NO NO
           code, called
           <filename>target.mk</filename><indexterm><primary>target.mk</primary></indexterm>.
           It contains the rules that tell <command>gmake</command> how
-          to make the standard targets (<Xref
-          LinkEnd="sec-standard-targets">).  Why, you ask, can't this
+          to make the standard targets (<xref
+          linkend="sec-standard-targets"/>).  Why, you ask, can't this
           standard code be part of
           <filename>boilerplate.mk</filename>?  Good question.  We
-          discuss the reason later, in <Xref
-          LinkEnd="sec-boiler-arch">.</para>
+          discuss the reason later, in <xref
+          linkend="sec-boiler-arch"/>.</para>
 
           <para>You do not <emphasis>have</emphasis> to
           <literal>include</literal> the
@@ -2483,8 +2532,8 @@ include ../mk/boilerplate.mk  # NO NO NO
           though, you will find quite a big payoff from using the
           canned rules in <filename>target.mk</filename>; the price
           tag is that you have to understand what canned rules get
-          enabled, and what they do (<Xref
-          LinkEnd="sec-targets">).</para>
+          enabled, and what they do (<xref
+          linkend="sec-targets"/>).</para>
        </listitem>
       </orderedlist>
 
@@ -2540,7 +2589,7 @@ include ../mk/boilerplate.mk  # NO NO NO
       rare.)  To give you the idea, here's part of the directory
       structure for the (rather large) GHC project:</para>
 
-<Screen>
+<screen>
 $(FPTOOLS_TOP)/ghc/
   Makefile
   mk/
@@ -2557,14 +2606,14 @@ $(FPTOOLS_TOP)/ghc/
     parser/...source files for parser...
     renamer/...source files for renamer...
     ...etc...
-</Screen>
+</screen>
 
       <para>The sub-directories <filename>docs</filename>,
       <filename>driver</filename>, <filename>compiler</filename>, and
       so on, each contains a sub-component of GHC, and each has its
       own <filename>Makefile</filename>.  There must also be a
       <filename>Makefile</filename> in
-      <filename><constant>&dollar;(FPTOOLS&lowbar;TOP)</constant>/ghc</filename>.
+      <filename>&dollar;(FPTOOLS&lowbar;TOP)/ghc</filename>.
       It does most of its work by recursively invoking
       <command>gmake</command> on the <filename>Makefile</filename>s
       in the sub-directories.  We say that
@@ -2666,9 +2715,9 @@ $(FPTOOLS_TOP)/ghc/
           <emphasis>augment</emphasis> them. For example, a
           <filename>Makefile</filename> might say:</para>
 
-<ProgramListing>
+<programlisting>
 SRC_HC_OPTS += -O
-</ProgramListing>
+</programlisting>
 
          <para>thereby adding &ldquo;<option>-O</option>&rdquo; to
          the end of
@@ -2678,7 +2727,7 @@ SRC_HC_OPTS += -O
        <listitem>
          <para><filename>target.mk</filename> contains
           <command>make</command> rules for the standard targets
-          described in <Xref LinkEnd="sec-standard-targets">.  These
+          described in <xref linkend="sec-standard-targets"/>.  These
           rules are selectively included, depending on the setting of
           certain <command>make</command> variables.  These variables
           are usually set in the middle section of the
@@ -2695,13 +2744,13 @@ SRC_HC_OPTS += -O
 
              <para><command>gmake</command> commits target and
               dependency lists earlier than it should.  For example,
-              <FIlename>target.mk</FIlename> has a rule that looks
+              <filename>target.mk</filename> has a rule that looks
               like this:</para>
 
-<ProgramListing>
+<programlisting>
 $(HS_PROG) : $(OBJS)
       $(HC) $(LD_OPTS) $&#60; -o $@
-</ProgramListing>
+</programlisting>
 
              <para>If this rule was in
               <filename>boilerplate.mk</filename> then
@@ -2742,23 +2791,25 @@ $(HS_PROG) : $(OBJS)
       <indexterm><primary>boilerplate.mk</primary></indexterm>
 
       <para>If you look at
-      <filename><constant>&dollar;(FPTOOLS&lowbar;TOP)</constant>/mk/boilerplate.mk</filename>
+      <filename>&dollar;(FPTOOLS&lowbar;TOP)/mk/boilerplate.mk</filename>
       you will find that it consists of the following sections, each
       held in a separate file:</para>
 
       <variablelist>
        <varlistentry>
-         <term><filename>config.mk</filename></term>
-         <indexterm><primary>config.mk</primary></indexterm>
+         <term><filename>config.mk</filename>
+            <indexterm><primary>config.mk</primary></indexterm>
+          </term>
          <listitem>
            <para>is the build configuration file we discussed at
-            length in <Xref LinkEnd="sec-build-config">.</para>
+            length in <xref linkend="sec-build-config"/>.</para>
          </listitem>
        </varlistentry>
 
        <varlistentry>
-         <term><filename>paths.mk</filename></term>
-         <indexterm><primary>paths.mk</primary></indexterm>
+         <term><filename>paths.mk</filename>
+            <indexterm><primary>paths.mk</primary></indexterm>
+          </term>
          <listitem>
            <para>defines <command>make</command> variables for
             pathnames and file lists.  This file contains code for
@@ -2774,9 +2825,9 @@ $(HS_PROG) : $(OBJS)
 
            <variablelist>
              <varlistentry>
-               <term><literal>ALL_DIRS</literal></term>
-               <indexterm><primary><literal>ALL_DIRS</literal></primary>
-               </indexterm>
+               <term><literal>ALL_DIRS</literal>
+                  <indexterm><primary><literal>ALL_DIRS</literal></primary></indexterm>
+                </term>
                <listitem>
                  <para>Set to a list of directories to search in
                  addition to the current directory for source
@@ -2785,9 +2836,9 @@ $(HS_PROG) : $(OBJS)
              </varlistentry>
 
              <varlistentry>
-               <term><literal>EXCLUDE_SRCS</literal></term>
-               <indexterm><primary><literal>EXCLUDE_SRCS</literal></primary>
-               </indexterm>
+               <term><literal>EXCLUDE_SRCS</literal>
+                  <indexterm><primary><literal>EXCLUDE_SRCS</literal></primary></indexterm>
+                </term>
                <listitem>
                  <para>Set to a list of source files (relative to the
                  current directory) to omit from the automatic
@@ -2803,9 +2854,9 @@ $(HS_PROG) : $(OBJS)
              </varlistentry>
 
              <varlistentry>
-               <term><literal>EXTRA_SRCS</literal></term>
-               <indexterm><primary><literal>EXCLUDE_SRCS</literal></primary>
-               </indexterm>
+               <term><literal>EXTRA_SRCS</literal>
+                  <indexterm><primary><literal>EXCLUDE_SRCS</literal></primary></indexterm>
+                </term>
                  <listitem>
                  <para>Set to a list of extra source files (perhaps
                  in directories not listed in
@@ -2820,8 +2871,9 @@ $(HS_PROG) : $(OBJS)
 
            <variablelist>
              <varlistentry>
-               <term><literal>SRCS</literal></term>
-               <indexterm><primary><literal>SRCS</literal></primary></indexterm>
+               <term><literal>SRCS</literal>
+                  <indexterm><primary><literal>SRCS</literal></primary></indexterm>
+                </term>
                <listitem>
                  <para>All source files found, sorted and without
                  duplicates, including those which might not exist
@@ -2833,8 +2885,9 @@ $(HS_PROG) : $(OBJS)
              </varlistentry>
 
              <varlistentry>
-               <term><literal>HS_SRCS</literal></term>
-               <indexterm><primary><literal>HS_SRCS</literal></primary></indexterm>
+               <term><literal>HS_SRCS</literal>
+                  <indexterm><primary><literal>HS_SRCS</literal></primary></indexterm>
+                </term>
                <listitem>
                  <para>all Haskell source files in the current
                   directory, including those derived from other source
@@ -2844,8 +2897,9 @@ $(HS_PROG) : $(OBJS)
              </varlistentry>
 
              <varlistentry>
-               <term><literal>HS_OBJS</literal></term>
-               <indexterm><primary><literal>HS_OBJS</literal></primary></indexterm>
+               <term><literal>HS_OBJS</literal>
+                  <indexterm><primary><literal>HS_OBJS</literal></primary></indexterm>
+                </term>
                <listitem>
                  <para>Object files derived from
                  <literal>HS_SRCS</literal>.</para>
@@ -2853,8 +2907,9 @@ $(HS_PROG) : $(OBJS)
              </varlistentry>
 
              <varlistentry>
-               <term><literal>HS_IFACES</literal></term>
-               <indexterm><primary><literal>HS_IFACES</literal></primary></indexterm>
+               <term><literal>HS_IFACES</literal>
+                  <indexterm><primary><literal>HS_IFACES</literal></primary></indexterm>
+                </term>
                <listitem>
                  <para>Interface files (<literal>.hi</literal> files)
                  derived from <literal>HS_SRCS</literal>.</para>
@@ -2862,16 +2917,18 @@ $(HS_PROG) : $(OBJS)
              </varlistentry>
 
              <varlistentry>
-               <term><literal>C_SRCS</literal></term>
+               <term><literal>C_SRCS</literal>
                <indexterm><primary><literal>C_SRCS</literal></primary></indexterm>
+                </term>
                <listitem>
                  <para>All C source files found.</para>
                </listitem>
              </varlistentry>
 
              <varlistentry>
-               <term><literal>C_OBJS</literal></term>
+               <term><literal>C_OBJS</literal>
                <indexterm><primary><literal>C_OBJS</literal></primary></indexterm>
+                </term>
                <listitem>
                  <para>Object files derived from
                  <literal>C_SRCS</literal>.</para>
@@ -2879,8 +2936,9 @@ $(HS_PROG) : $(OBJS)
              </varlistentry>
 
              <varlistentry>
-               <term><literal>SCRIPT_SRCS</literal></term>
+               <term><literal>SCRIPT_SRCS</literal>
                <indexterm><primary><literal>SCRIPT_SRCS</literal></primary></indexterm>
+                </term>
                <listitem>
                  <para>All script source files found
                  (<literal>.lprl</literal> files).</para>
@@ -2888,8 +2946,9 @@ $(HS_PROG) : $(OBJS)
              </varlistentry>
 
              <varlistentry>
-               <term><literal>SCRIPT_OBJS</literal></term>
+               <term><literal>SCRIPT_OBJS</literal>
                <indexterm><primary><literal>SCRIPT_OBJS</literal></primary></indexterm>
+                </term>
                <listitem>
                  <para><quote>object</quote> files derived from
                  <literal>SCRIPT_SRCS</literal>
@@ -2898,8 +2957,9 @@ $(HS_PROG) : $(OBJS)
              </varlistentry>
 
              <varlistentry>
-               <term><literal>HSC_SRCS</literal></term>
+               <term><literal>HSC_SRCS</literal>
                <indexterm><primary><literal>HSC_SRCS</literal></primary></indexterm>
+                </term>
                <listitem>
                  <para>All <literal>hsc2hs</literal> source files
                  (<literal>.hsc</literal> files).</para>
@@ -2907,8 +2967,9 @@ $(HS_PROG) : $(OBJS)
              </varlistentry>
 
              <varlistentry>
-               <term><literal>HAPPY_SRCS</literal></term>
+               <term><literal>HAPPY_SRCS</literal>
                <indexterm><primary><literal>HAPPY_SRCS</literal></primary></indexterm>
+                </term>
                <listitem>
                  <para>All <literal>happy</literal> source files
                  (<literal>.y</literal> or <literal>.hy</literal> files).</para>
@@ -2916,8 +2977,9 @@ $(HS_PROG) : $(OBJS)
              </varlistentry>
 
              <varlistentry>
-               <term><literal>OBJS</literal></term>
+               <term><literal>OBJS</literal>
                <indexterm><primary>OBJS</primary></indexterm>
+                </term>
                <listitem>
                  <para>the concatenation of
                  <literal>&dollar;(HS_OBJS)</literal>,
@@ -2943,23 +3005,25 @@ $(HS_PROG) : $(OBJS)
        </varlistentry>
 
        <varlistentry>
-         <term><filename>opts.mk</filename></term>
-         <indexterm><primary>opts.mk</primary></indexterm>
+         <term><filename>opts.mk</filename>
+            <indexterm><primary>opts.mk</primary></indexterm>
+          </term>
          <listitem>
            <para>defines <command>make</command> variables for option
             strings to pass to each program. For example, it defines
             <constant>HC&lowbar;OPTS</constant><indexterm><primary>HC&lowbar;OPTS</primary></indexterm>,
             the option strings to pass to the Haskell compiler.  See
-            <Xref LinkEnd="sec-suffix">.</para>
+            <xref linkend="sec-suffix"/>.</para>
          </listitem>
        </varlistentry>
 
        <varlistentry>
-         <term><filename>suffix.mk</filename></term>
-         <indexterm><primary>suffix.mk</primary></indexterm>
+         <term><filename>suffix.mk</filename>
+            <indexterm><primary>suffix.mk</primary></indexterm>
+          </term>
          <listitem>
-           <para>defines standard pattern rules&mdash;see <Xref
-           LinkEnd="sec-suffix">.</para>
+           <para>defines standard pattern rules&mdash;see <xref
+           linkend="sec-suffix"/>.</para>
          </listitem>
        </varlistentry>
       </variablelist>
@@ -2988,11 +3052,11 @@ $(HS_PROG) : $(OBJS)
 
       <para>Almost all the rules look something like this:</para>
 
-<ProgramListing>
+<programlisting>
 %.o : %.c
       $(RM) $@
       $(CC) $(CC_OPTS) -c $&#60; -o $@
-</ProgramListing>
+</programlisting>
 
       <para>Here's how to understand the rule.  It says that
       <emphasis>something</emphasis><filename>.o</filename> (say
@@ -3020,9 +3084,10 @@ $(HS_PROG) : $(OBJS)
       defined in <filename>mk/opts.mk</filename>.  Almost all of them
       are defined like this:</para>
 
-<ProgramListing>
-CC_OPTS = $(SRC_CC_OPTS) $(WAY$(_way)_CC_OPTS) $($*_CC_OPTS) $(EXTRA_CC_OPTS)
-</ProgramListing>
+<programlisting>
+CC_OPTS = \
+  $(SRC_CC_OPTS) $(WAY$(_way)_CC_OPTS) $($*_CC_OPTS) $(EXTRA_CC_OPTS)
+</programlisting>
 
       <para>The four variables from which
        <constant>CC&lowbar;OPTS</constant> is built have the following
@@ -3046,7 +3111,7 @@ CC_OPTS = $(SRC_CC_OPTS) $(WAY$(_way)_CC_OPTS) $($*_CC_OPTS) $(EXTRA_CC_OPTS)
             <literal>mp</literal>.  The variable
             <constant>WAY&lowbar;CC&lowbar;OPTS</constant> holds
             options to pass to the C compiler when compiling the
-            standard way.  (<Xref LinkEnd="sec-ways"> dicusses
+            standard way.  (<xref linkend="sec-ways"/> dicusses
             multi-way compilation.)</para>
          </listitem>
        </varlistentry>
@@ -3068,9 +3133,9 @@ CC_OPTS = $(SRC_CC_OPTS) $(WAY$(_way)_CC_OPTS) $($*_CC_OPTS) $(EXTRA_CC_OPTS)
            <para>extra options to pass to all C compilations.  This
             is intended for command line use, thus:</para>
 
-<ProgramListing>
+<programlisting>
 gmake libHS.a EXTRA_CC_OPTS="-v"
-</ProgramListing>
+</programlisting>
          </listitem>
        </varlistentry>
       </variablelist>
@@ -3081,8 +3146,8 @@ gmake libHS.a EXTRA_CC_OPTS="-v"
       <indexterm><primary>target.mk</primary></indexterm>
 
       <para><filename>target.mk</filename> contains canned rules for
-      all the standard targets described in <Xref
-      LinkEnd="sec-standard-targets">.  It is complicated by the fact
+      all the standard targets described in <xref
+      linkend="sec-standard-targets"/>.  It is complicated by the fact
       that you don't want all of these rules to be active in every
       <filename>Makefile</filename>.  Rather than have a plethora of
       tiny files which you can include selectively, there is a single
@@ -3176,10 +3241,10 @@ gmake libHS.a EXTRA_CC_OPTS="-v"
       <para>All of these rules are &ldquo;double-colon&rdquo; rules,
       thus</para>
 
-<ProgramListing>
+<programlisting>
 install :: $(HS_PROG)
       ...how to install it...
-</ProgramListing>
+</programlisting>
 
       <para>GNU <command>make</command> treats double-colon rules as
       separate entities.  If there are several double-colon rules for
@@ -3210,7 +3275,7 @@ install :: $(HS_PROG)
 
       <para>When <constant>SUBDIRS</constant> is defined,
       <filename>target.mk</filename> includes a rather neat rule for
-      the standard targets (<Xref LinkEnd="sec-standard-targets"> that
+      the standard targets (<xref linkend="sec-standard-targets"/> that
       simply invokes <command>make</command> recursively in each of
       the sub-directories.</para>
 
@@ -3299,8 +3364,8 @@ install :: $(HS_PROG)
           <filename>Makefile</filename> to the list of way tags you
           want these targets built for.  The mechanism here is very
           much like the recursive invocation of
-          <command>make</command> in sub-directories (<Xref
-          LinkEnd="sec-subdirs">).  It is up to you to set
+          <command>make</command> in sub-directories (<xref
+          linkend="sec-subdirs"/>).  It is up to you to set
           <constant>WAYS</constant> in your
           <filename>Makefile</filename>; this is how you control what
           ways will get built.</para>
@@ -3320,10 +3385,10 @@ install :: $(HS_PROG)
           file will match</emphasis>.  The key pattern rules (in
           <filename>suffix.mk</filename>) look like this:
 
-<ProgramListing>
+<programlisting>
 %.$(way_)o : %.lhs
       $(HC) $(HC_OPTS) $&#60; -o $@
-</ProgramListing>
+</programlisting>
 
           Neat, eh?</para>
        </listitem>
@@ -3371,9 +3436,10 @@ $ make way=p
       
       <variablelist>
        <varlistentry>
-         <term>DocBook</term>
-         <indexterm><primary>pre-supposed: DocBook</primary></indexterm>
-         <indexterm><primary>DocBook, pre-supposed</primary></indexterm>
+         <term>DocBook
+            <indexterm><primary>pre-supposed: DocBook</primary></indexterm>
+            <indexterm><primary>DocBook, pre-supposed</primary></indexterm>
+          </term>
          <listitem>
            <para>Much of our documentation is written in SGML, using
             the DocBook DTD.  Instructions on installing and
@@ -3382,9 +3448,10 @@ $ make way=p
        </varlistentry>
 
        <varlistentry>
-         <term>TeX</term>
-         <indexterm><primary>pre-supposed: TeX</primary></indexterm>
-         <indexterm><primary>TeX, pre-supposed</primary></indexterm>
+         <term>TeX
+            <indexterm><primary>pre-supposed: TeX</primary></indexterm>
+            <indexterm><primary>TeX, pre-supposed</primary></indexterm>
+          </term>
          <listitem>
            <para>A decent TeX distribution is required if you want to
             produce printable documentation.  We recomment teTeX,
@@ -3393,9 +3460,9 @@ $ make way=p
        </varlistentry>
 
        <varlistentry>
-         <term>Haddock</term>
-         <indexterm><primary>Haddock</primary>
-         </indexterm>
+         <term>Haddock
+            <indexterm><primary>Haddock</primary></indexterm>
+          </term>
          <listitem>
            <para>Haddock is a Haskell documentation tool that we use
            for automatically generating documentation from the
@@ -3422,21 +3489,21 @@ $ make way=p
 
        <para>If you don't have DocBook tools installed, and you are
         using a system that can handle RedHat RPM packages, you can
-        probably use the <ULink
-        URL="http://sourceware.cygnus.com/docbook-tools/">Cygnus
-        DocBook tools</ULink>, which is the most shrink-wrapped SGML
+        probably use the <ulink
+        url="http://sourceware.cygnus.com/docbook-tools/">Cygnus
+        DocBook tools</ulink>, which is the most shrink-wrapped SGML
         suite that we could find. You need all the RPMs except for
-        psgml (i.e.  <Filename>docbook</Filename>,
-        <Filename>jade</Filename>, <Filename>jadetex</Filename>,
-        <Filename>sgmlcommon</Filename> and
-        <Filename>stylesheets</Filename>). Note that most of these
+        psgml (i.e.  <filename>docbook</filename>,
+        <filename>jade</filename>, <filename>jadetex</filename>,
+        <filename>sgmlcommon</filename> and
+        <filename>stylesheets</filename>). Note that most of these
         RPMs are architecture neutral, so are likely to be found in a
-        <Filename>noarch</Filename> directory. The SuSE RPMs also
-        work; the RedHat ones <Emphasis>don't</Emphasis> in RedHat 6.2
+        <filename>noarch</filename> directory. The SuSE RPMs also
+        work; the RedHat ones <emphasis>don't</emphasis> in RedHat 6.2
         (7.0 and later should be OK), but they are easy to fix: just
         make a symlink from
-        <Filename>/usr/lib/sgml/stylesheets/nwalsh-modular/lib/dblib.dsl</Filename>
-        to <Filename>/usr/lib/sgml/lib/dblib.dsl</Filename>. </para>
+        <filename>/usr/lib/sgml/stylesheets/nwalsh-modular/lib/dblib.dsl</filename>
+        to <filename>/usr/lib/sgml/lib/dblib.dsl</filename>. </para>
       </sect3>
     
       <sect3>
@@ -3460,17 +3527,17 @@ $ make way=p
       <sect3>
        <title>Installing from binaries on Windows</title>
        
-       <Para>It's a good idea to use Norman Walsh's <ULink
-        URL="http://nwalsh.com/docbook/dsssl/doc/install.html">installation
-        notes</ULink> as a guide. You should get version 3.1 of
-        DocBook, and note that his file <Filename>test.sgm</Filename>
+       <para>It's a good idea to use Norman Walsh's <ulink
+        url="http://nwalsh.com/docbook/dsssl/doc/install.html">installation
+        notes</ulink> as a guide. You should get version 3.1 of
+        DocBook, and note that his file <filename>test.sgm</filename>
         won't work, as it needs version 3.0. You should unpack Jade
-        into <Filename>\Jade</Filename>, along with the entities,
-        DocBook into <Filename>\docbook</Filename>, and the DocBook
-        stylesheets into <Filename>\docbook\stylesheets</Filename> (so
+        into <filename>\Jade</filename>, along with the entities,
+        DocBook into <filename>\docbook</filename>, and the DocBook
+        stylesheets into <filename>\docbook\stylesheets</filename> (so
         they actually end up in
-        <Filename>\docbook\stylesheets\docbook</Filename>).</para>
-      </Sect3>
+        <filename>\docbook\stylesheets\docbook</filename>).</para>
+      </sect3>
 
 
       <sect3>
@@ -3479,58 +3546,58 @@ $ make way=p
        <sect4>
          <title>Jade</title>
 
-         <para>Install <ULink
-          URL="http://openjade.sourceforge.net/">OpenJade</ULink>
+         <para>Install <ulink
+          url="http://openjade.sourceforge.net/">OpenJade</ulink>
           (Windows binaries are available as well as sources). If you
           want DVI, PS, or PDF then install JadeTeX from the
-          <Filename>dsssl</Filename> subdirectory. (If you get the
+          <filename>dsssl</filename> subdirectory. (If you get the
           error:
 
 <screen>
 ! LaTeX Error: Unknown option implicit=false' for package hyperref'.
 </screen>
 
-          your version of <Command>hyperref</Command> is out of date;
+          your version of <command>hyperref</command> is out of date;
           download it from CTAN
-          (<Filename>macros/latex/contrib/supported/hyperref</Filename>),
+          (<filename>macros/latex/contrib/supported/hyperref</filename>),
           and make it, ensuring that you have first removed or renamed
           your old copy. If you start getting file not found errors
-          when making the test for <Command>hyperref</Command>, you
+          when making the test for <command>hyperref</command>, you
           can abort at that point and proceed straight to
-          <Command>make install</Command>, or enter them as
-          <Filename>../</Filename><Emphasis>filename</Emphasis>.)</para>
+          <command>make install</command>, or enter them as
+          <filename>../</filename><emphasis>filename</emphasis>.)</para>
 
-         <para>Make links from <Filename>virtex</Filename> to
-          <Filename>jadetex</Filename> and
-          <Filename>pdfvirtex</Filename> to
-          <Filename>pdfjadetex</Filename> (otherwise DVI, PostScript
+         <para>Make links from <filename>virtex</filename> to
+          <filename>jadetex</filename> and
+          <filename>pdfvirtex</filename> to
+          <filename>pdfjadetex</filename> (otherwise DVI, PostScript
           and PDF output will not work). Copy
-          <Filename>dsssl/*.{dtd,dsl}</Filename> and
-          <Filename>catalog</Filename> to
-          <Filename>/usr/[local/]lib/sgml</Filename>.</para>
+          <filename>dsssl/*.{dtd,dsl}</filename> and
+          <filename>catalog</filename> to
+          <filename>/usr/[local/]lib/sgml</filename>.</para>
        </sect4>
 
        <sect4>
          <title>DocBook and the DocBook stylesheets</title>
 
-         <para>Get a Zip of <ULink
-          URL="http://www.oasis-open.org/docbook/sgml/3.1/index.html">DocBook</ULink>
+         <para>Get a Zip of <ulink
+          url="http://www.oasis-open.org/docbook/sgml/3.1/index.html">DocBook</ulink>
           and install the contents in
-          <Filename>/usr/[local/]/lib/sgml</Filename>.</para>
+          <filename>/usr/[local/]/lib/sgml</filename>.</para>
 
-         <para>Get the <ULink
-          URL="http://nwalsh.com/docbook/dsssl/">DocBook
-          stylesheets</ULink> and install in
-          <Filename>/usr/[local/]lib/sgml/stylesheets</Filename>
+         <para>Get the <ulink
+          url="http://nwalsh.com/docbook/dsssl/">DocBook
+          stylesheets</ulink> and install in
+          <filename>/usr/[local/]lib/sgml/stylesheets</filename>
           (thereby creating a subdirectory docbook). For indexing,
-          copy or link <Filename>collateindex.pl</Filename> from the
-          DocBook stylesheets archive in <Filename>bin</Filename> into
-          a directory on your <Constant>PATH</Constant>.</para>
-
-         <para>Download the <ULink
-          URL="http://www.oasis-open.org/cover/ISOEnts.zip">ISO
-          entities</ULink> into
-          <Filename>/usr/[local/]lib/sgml</Filename>.</para>
+          copy or link <filename>collateindex.pl</filename> from the
+          DocBook stylesheets archive in <filename>bin</filename> into
+          a directory on your <constant>PATH</constant>.</para>
+
+         <para>Download the <ulink
+          url="http://www.oasis-open.org/cover/ISOEnts.zip">ISO
+          entities</ulink> into
+          <filename>/usr/[local/]lib/sgml</filename>.</para>
        </sect4>
       </sect3>
     </sect2>
@@ -3538,7 +3605,7 @@ $ make way=p
     <sect2>
       <title>Configuring the DocBook tools</title>
 
-      <Para>Once the DocBook tools are installed, the configure script
+      <para>Once the DocBook tools are installed, the configure script
       will detect them and set up the build system accordingly. If you
       have a system that isn't supported, let us know, and we'll try
       to help.</para>
@@ -3550,12 +3617,12 @@ $ make way=p
       <para>If you install from source, you'll get a pile of warnings
       of the form
 
-<Screen>DTDDECL catalog entries are not supported</Screen>
+<screen>DTDDECL catalog entries are not supported</screen>
 
       every time you build anything. These can safely be ignored, but
       if you find them tedious you can get rid of them by removing all
-      the <Constant>DTDDECL</Constant> entries from
-      <Filename>docbook.cat</Filename>.</para>
+      the <constant>DTDDECL</constant> entries from
+      <filename>docbook.cat</filename>.</para>
     </sect2>
 
     <sect2>
@@ -3633,14 +3700,14 @@ $ make install-docs
        supported (or perhaps has been supported in the past, but
        currently isn't).  This is the easiest type of porting job,
        but it still requires some careful bootstrapping.  Proceed to
-       <xref linkend="sec-booting-from-hc">.</para>
+       <xref linkend="sec-booting-from-hc"/>.</para>
       </listitem>
       
       <listitem>
        <para>Your system's hardware architecture isn't supported by
        GHC.  This will be a more difficult port (though by comparison
        perhaps not as difficult as porting gcc).  Proceed to <xref
-       linkend="unregisterised-porting">.</para>
+       linkend="unregisterised-porting"/>.</para>
       </listitem>
     </itemizedlist>
     
@@ -3666,7 +3733,7 @@ $ make install-docs
       supplied on the GHC download page, otherwise you'll have to
       compile some up yourself, or start from
       <emphasis>unregisterised</emphasis> HC files - see <xref
-      linkend="unregisterised-porting">.</para>
+      linkend="unregisterised-porting"/>.</para>
 
       <para>The following steps should result in a working GHC build
       with full libraries:</para>
@@ -3693,9 +3760,9 @@ $ make install-docs
           command will execute the whole build process (it won't
           install yet):</para>
 
-<Screen>
+<screen>
 foo% distrib/hc-build --prefix=<replaceable>dir</replaceable>
-</Screen>
+</screen>
 <indexterm><primary>--hc-build</primary></indexterm>
 
          <para>By default, the installation directory is
@@ -3708,9 +3775,9 @@ foo% distrib/hc-build --prefix=<replaceable>dir</replaceable>
           build process, you can install the resulting system, as
           normal, with</para>
 
-<Screen>
+<screen>
 foo% make install
-</Screen>
+</screen>
        </listitem>
       </itemizedlist>
     </sect2>
@@ -3891,8 +3958,8 @@ $ touch <replaceable>H</replaceable>/ghc/includes/config.h</screen>
            <listitem>
                <para>Now build the compiler:</para>
 <screen>
-$ cd <replaceable>H</replaceable>/glafp-utils && make boot && make
-$ cd <replaceable>H</replaceable>/ghc && make boot && make
+$ cd <replaceable>H</replaceable>/glafp-utils &amp;&amp; make boot &amp;&amp; make
+$ cd <replaceable>H</replaceable>/ghc &amp;&amp; make boot &amp;&amp; make
 </screen>
              <para>Don't worry if the build falls over in the RTS, we
               don't need the RTS yet.</para>
@@ -3901,14 +3968,14 @@ $ cd <replaceable>H</replaceable>/ghc && make boot && make
            <listitem>
 <screen>
 $ cd <replaceable>H</replaceable>/libraries
-$& make boot && make
+$ make boot &amp;&amp; make
 </screen>
            </listitem>
 
            <listitem>
 <screen>
 $ cd <replaceable>H</replaceable>/ghc
-$ make boot stage=2 && make stage=2
+$ make boot stage=2 &amp;&amp; make stage=2
 </screen>
            </listitem>
            
@@ -3943,7 +4010,7 @@ $ make hc-file-bundle Project=Ghc
            from the intermediate C files we generated above.  The
            process of bootstrapping from C files is automated by the
            script in <literal>distrib/hc-build</literal>, and is
-           described in <xref linkend="sec-booting-from-hc">.</para>
+           described in <xref linkend="sec-booting-from-hc"/>.</para>
 
 <screen>
 $ ./distrib/hc-build --enable-hc-boot-unregisterised
@@ -3993,9 +4060,9 @@ Hello World!
 
        <variablelist>
          <varlistentry>
-           <term><filename>ghc/includes/MachRegs.h</filename></term>
-           <indexterm><primary><filename>MachRegs.h</filename></primary>
-           </indexterm>
+           <term><filename>ghc/includes/MachRegs.h</filename>
+           <indexterm><primary><filename>MachRegs.h</filename></primary></indexterm>
+            </term>
            <listitem>
              <para>Defines the STG-register to machine-register
              mapping.  You need to know your platform's C calling
@@ -4005,19 +4072,19 @@ Hello World!
            </listitem>
          </varlistentry>
          <varlistentry>
-           <term><filename>ghc/includes/TailCalls.h</filename></term>
-           <indexterm><primary><filename>TailCalls.h</filename></primary>
-           </indexterm>
+           <term><filename>ghc/includes/TailCalls.h</filename>
+           <indexterm><primary><filename>TailCalls.h</filename></primary></indexterm>
+            </term>
            <listitem>
              <para>Macros that cooperate with the mangler (see <xref
-             linkend="sec-mangler">) to make proper tail-calls
+             linkend="sec-mangler"/>) to make proper tail-calls
              work.</para>
            </listitem>
          </varlistentry>
          <varlistentry>
-           <term><filename>ghc/rts/Adjustor.c</filename></term>
-           <indexterm><primary><filename>Adjustor.c</filename></primary>
-           </indexterm>
+           <term><filename>ghc/rts/Adjustor.c</filename>
+           <indexterm><primary><filename>Adjustor.c</filename></primary></indexterm>
+            </term>
            <listitem>
              <para>Support for
              <literal>foreign&nbsp;import&nbsp;"wrapper"</literal>
@@ -4028,9 +4095,9 @@ Hello World!
            </listitem>
          </varlistentry>
          <varlistentry>
-           <term><filename>ghc/rts/StgCRun.c</filename></term>
-           <indexterm><primary><filename>StgCRun.c</filename></primary>
-           </indexterm>
+           <term><filename>ghc/rts/StgCRun.c</filename>
+           <indexterm><primary><filename>StgCRun.c</filename></primary></indexterm>
+            </term>
            <listitem>
              <para>The little assembly layer between the C world and
              the Haskell world.  See the comments and code for the
@@ -4038,12 +4105,12 @@ Hello World!
            </listitem>
          </varlistentry>
          <varlistentry>
-           <term><filename>ghc/rts/MBlock.h</filename></term>
-           <term><filename>ghc/rts/MBlock.c</filename></term>
-           <indexterm><primary><filename>MBlock.h</filename></primary>
-           </indexterm>
-           <indexterm><primary><filename>MBlock.c</filename></primary>
-           </indexterm>
+           <term><filename>ghc/rts/MBlock.h</filename>
+              <indexterm><primary><filename>MBlock.h</filename></primary></indexterm>
+            </term>
+           <term><filename>ghc/rts/MBlock.c</filename>
+              <indexterm><primary><filename>MBlock.c</filename></primary></indexterm>
+            </term>
            <listitem>
              <para>These files are really OS-specific rather than
              architecture-specific.  In <filename>MBlock.h</filename>
@@ -4137,7 +4204,7 @@ WARNINGS about pitfalls and known &ldquo;problems&rdquo;:
 
 <para>
 
-<OrderedList>
+<orderedlist>
 <listitem>
 
 <para>
@@ -4153,9 +4220,9 @@ of choice).
 
 The best way around it is to say
 
-<ProgramListing>
+<programlisting>
 export TMPDIR=&#60;dir&#62;
-</ProgramListing>
+</programlisting>
 
 in your <filename>build.mk</filename> file.
 Then GHC and the other <literal>fptools</literal> programs will use the appropriate directory
@@ -4187,11 +4254,11 @@ incompatible pointer type&rdquo; out of GCC.  Harmless.
 Similarly, <command>ar</command>chiving warning messages like the following are not
 a problem:
 
-<Screen>
+<screen>
 ar: filename GlaIOMonad__1_2s.o truncated to GlaIOMonad_
 ar: filename GlaIOMonad__2_2s.o truncated to GlaIOMonad_
 ...
-</Screen>
+</screen>
 
 
 </para>
@@ -4231,15 +4298,15 @@ above.
 </itemizedlist>
 
 
-and try again: <command>gmake</command>.  (see <Xref LinkEnd="sec-suffix"> for information about
+and try again: <command>gmake</command>.  (see <xref linkend="sec-suffix"/> for information about
 <constant>&lt;module&gt;&lowbar;HC&lowbar;OPTS</constant>.)
 
 Alternatively, just cut to the chase:
 
-<Screen>
+<screen>
 % cd ghc/compiler
 % make EXTRA_HC_OPTS=-optCrts-M128M
-</Screen>
+</screen>
 
 
 </para>
@@ -4263,13 +4330,13 @@ this bug also suggests that you have an old GCC.
 You <emphasis>may</emphasis> need to re-<command>ranlib</command><indexterm><primary>ranlib</primary></indexterm> your libraries (on Sun4s).
 
 
-<Screen>
+<screen>
 % cd $(libdir)/ghc-x.xx/sparc-sun-sunos4
 % foreach i ( `find . -name '*.a' -print` ) # or other-shell equiv...
 ?    ranlib $i
 ?    # or, on some machines: ar s $i
 ? end
-</Screen>
+</screen>
 
 
 We'd be interested to know if this is still necessary.
@@ -4285,18 +4352,18 @@ a bit from one Unix to another.  One particular gotcha is macro calls
 like this:
 
 
-<ProgramListing>
+<programlisting>
 SLIT("Hello, world")
-</ProgramListing>
+</programlisting>
 
 
 Some <command>cpp</command>s treat the comma inside the string as separating two macro
 arguments, so you get
 
 
-<Screen>
+<screen>
 :731: macro `SLIT' used with too many (2) args
-</Screen>
+</screen>
 
 
 Alas, <command>cpp</command> doesn't tell you the offending file!
@@ -4305,20 +4372,20 @@ Workaround: don't put weird things in string args to <command>cpp</command> macr
 </para>
 </listitem>
 
-</OrderedList>
+</orderedlist>
 
 </para>
 
 </sect1>
 
 
-<Sect1 id="platforms"><Title>Platforms, scripts, and file names</Title>
+<sect1 id="platforms"><title>Platforms, scripts, and file names</title>
 <para>
 GHC is designed both to be built, and to run, on both Unix and Windows.  This flexibility
 gives rise to a good deal of brain-bending detail, which we have tried to collect in this chapter.
 </para>
 
-<sect2 id="cygwin-and-mingw"><Title>Windows platforms: Cygwin, MSYS, and MinGW</Title>
+<sect2 id="cygwin-and-mingw"><title>Windows platforms: Cygwin, MSYS, and MinGW</title>
 
 <para> The build system is built around Unix-y makefiles.  Because it's not native,
 the Windows situation for building GHC is particularly confusing.  This section
@@ -4410,14 +4477,14 @@ that Haskell programs compiled by GHC-cygwin can import the (Haskell) Posix libr
 how GHC is <emphasis>built</emphasis>.  We use both MSYS and Cygwin as build environments for
 GHC; both work fine, though MSYS is rather lighter weight.</para>
 
-<para>In your build tree, you build a compiler called <Command>ghc-inplace</Command>.  It
-uses the <Command>gcc</Command> that you specify using the
+<para>In your build tree, you build a compiler called <command>ghc-inplace</command>.  It
+uses the <command>gcc</command> that you specify using the
 <option>--with-gcc</option> flag when you run
-<Command>configure</Command> (see below).
-The makefiles are careful to use <Command>ghc-inplace</Command> (not <Command>gcc</Command>)
-to compile any C files, so that it will in turn invoke the correct <Command>gcc</Command> rather that
-whatever one happens to be in your path.  However, the makefiles do use whatever <Command>ld</Command> 
-and <Command>ar</Command> happen to be in your path. This is a bit naughty, but (a) they are only
+<command>configure</command> (see below).
+The makefiles are careful to use <command>ghc-inplace</command> (not <command>gcc</command>)
+to compile any C files, so that it will in turn invoke the correct <command>gcc</command> rather that
+whatever one happens to be in your path.  However, the makefiles do use whatever <command>ld</command> 
+and <command>ar</command> happen to be in your path. This is a bit naughty, but (a) they are only
 used to glom together .o files into a bigger .o file, or a .a file, 
 so they don't ever get libraries (which would be bogus; they might be the wrong libraries), and (b)
 Cygwin and MinGW use the same .o file format.  So its ok.
@@ -4452,7 +4519,7 @@ Cygwin programs have a more complicated mount table, and map the lettered drives
 </para>
 </sect3>
 
-<sect3><title>HOST_OS vs TARGET_OS</title>
+<sect3><title>Host System vs Target System</title>
 
 <para>
 In the source code you'll find various ifdefs looking like:
@@ -4470,12 +4537,12 @@ and
 These macros are set by the configure script (via the file config.h).
 Which is which?  The criterion is this.  In the ifdefs in GHC's source code:
 <itemizedlist>
-  <listitem> <para>
-  The "host" system is the one on which GHC itself will be run.
-  </para> </listitem>
-  <listitem> <para>
-  The "target" system is the one for which the program compiled by GHC will be run.
-  </para> </listitem>
+  <listitem>
+    <para>The "host" system is the one on which GHC itself will be run.</para>
+  </listitem>
+  <listitem>
+    <para>The "target" system is the one for which the program compiled by GHC will be run.</para>
+  </listitem>
 </itemizedlist>
 For a stage-2 compiler, in which GHCi is available, the "host" and "target" systems must be the same.
 So then it doesn't really matter whether you use the HOST_OS or TARGET_OS cpp macros.
@@ -4523,7 +4590,7 @@ shortcomings of the native Windows <command>cmd</command> shell.
 
 </sect1>
 
-<Sect1 id="winbuild"><Title>Instructions for building under Windows</Title>
+<sect1 id="winbuild"><title>Instructions for building under Windows</title>
 
 <para>
 This section gives detailed instructions for how to build 
@@ -4532,13 +4599,13 @@ installing and running GHC may be found in the user guide. In general,
 Win95/Win98 behave the same, and WinNT/Win2k behave the same.
 </para>
 <para>
-Make sure you read the preceding section on platforms (<xref linkend="platforms">)
+Make sure you read the preceding section on platforms (<xref linkend="platforms"/>)
 before reading section.
 You don't need Cygwin or MSYS to <emphasis>use</emphasis> GHC, 
 but you do need one or the other to <emphasis>build</emphasis> GHC.</para>
 
 
-<Sect2 id=msys-install><Title>Installing and configuring MSYS</Title>
+<sect2 id="msys-install"><title>Installing and configuring MSYS</title>
 
 <para>
 MSYS is a lightweight alternative to Cygwin.  
@@ -4621,10 +4688,10 @@ bzip'd dump.</para></listitem>
 </para>
 </sect2>
 
-<Sect2><Title>Installing and configuring Cygwin</Title>
+<sect2><title>Installing and configuring Cygwin</title>
 
 <para> Install Cygwin from <ulink url="http://www.cygwin.com/">http://www.cygwin.com/</ulink>.
-The installation process is straightforward; we install it in <Filename>c:/cygwin</Filename>.
+The installation process is straightforward; we install it in <filename>c:/cygwin</filename>.
 During the installation dialogue, make sure that you select all of the following:
              <command>cvs</command>, 
              <command>openssh</command>,
@@ -4646,17 +4713,17 @@ stage of Cygwin's installation dialogue, until the view says "Full".  The defaul
 
 <listitem>
 <para>
-Set <constant>MAKE_MODE</constant> to <Literal>UNIX</Literal>. If you
+Set <constant>MAKE_MODE</constant> to <literal>UNIX</literal>. If you
 don't do this you get very weird messages when you type
-<Command>make</Command>, such as:
-<Screen>
+<command>make</command>, such as:
+<screen>
 /c: /c: No such file or directory
-</Screen>
+</screen>
 </para>
 </listitem>
 
 <listitem><para> Set <constant>SHELL</constant> to
-<Filename>c:/cygwin/bin/bash</Filename>. When you invoke a shell in Emacs, this
+<filename>c:/cygwin/bin/bash</filename>. When you invoke a shell in Emacs, this
 <constant>SHELL</constant> is what you get.
 </para></listitem>
 
@@ -4689,21 +4756,21 @@ you can't rename a running program!
 
 <listitem>
 <para>
-Some script files used in the make system start with "<Command>#!/bin/perl</Command>",
-(and similarly for <Command>sh</Command>).  Notice the hardwired path!
-So you need to ensure that your <Filename>/bin</Filename> directory has the following
+Some script files used in the make system start with "<command>#!/bin/perl</command>",
+(and similarly for <command>sh</command>).  Notice the hardwired path!
+So you need to ensure that your <filename>/bin</filename> directory has the following
 binaries in it:
 <itemizedlist>
-<listitem> <para><Command>sh</Command></para></listitem>
-<listitem> <para><Command>perl</Command></para></listitem>
-<listitem> <para><Command>cat</Command></para></listitem>
+<listitem> <para><command>sh</command></para></listitem>
+<listitem> <para><command>perl</command></para></listitem>
+<listitem> <para><command>cat</command></para></listitem>
 </itemizedlist>
-All these come in Cygwin's <Filename>bin</Filename> directory, which you probably have
-installed as <Filename>c:/cygwin/bin</Filename>.  By default Cygwin mounts "<Filename>/</Filename>" as
-<Filename>c:/cygwin</Filename>, so if you just take the defaults it'll all work ok.
+All these come in Cygwin's <filename>bin</filename> directory, which you probably have
+installed as <filename>c:/cygwin/bin</filename>.  By default Cygwin mounts "<filename>/</filename>" as
+<filename>c:/cygwin</filename>, so if you just take the defaults it'll all work ok.
 (You can discover where your Cygwin
-root directory <Filename>/</Filename> is by typing <Command>mount</Command>.)
-Provided <Filename>/bin</Filename> points to the Cygwin <Filename>bin</Filename>
+root directory <filename>/</filename> is by typing <command>mount</command>.)
+Provided <filename>/bin</filename> points to the Cygwin <filename>bin</filename>
 directory, there's no need to copy anything.  If not, copy these binaries from the <filename>cygwin/bin</filename>
 directory (after fixing the <filename>sh.exe</filename> stuff mentioned in the previous bullet).
 </para>
@@ -4727,16 +4794,16 @@ they don't recognise symlinks.
 </para></listitem>
 
 <listitem> <para>
-See the notes in <xref linkend="msys-install"> about <command>find</command> and <command>bzip</command>,
+See the notes in <xref linkend="msys-install"/> about <command>find</command> and <command>bzip</command>,
 which apply to Cygwin too.
 </para></listitem>
 </itemizedlist>
 </para>
 
-</Sect2>
+</sect2>
 
 
-<Sect2 id="configure-ssh"><Title>Configuring SSH</Title>
+<sect2 id="configure-ssh"><title>Configuring SSH</title>
 
 <para><command>ssh</command> comes with Cygwin, provided you remember to ask for it when
 you install Cygwin.  (If not, the installer lets you update easily.)  Look for <command>openssh</command> 
@@ -4750,10 +4817,10 @@ you install Cygwin.  (If not, the installer lets you update easily.)  Look for <
        seem to lock up <command>bash</command> entirely if they try to get user input (e.g. if
        they ask for a password).  To solve this, start up <filename>cmd.exe</filename> 
        and run it as follows:
-       <Screen>
+       <screen>
        c:\tmp> set CYGWIN32=tty
        c:\tmp> c:/user/local/bin/ssh-keygen1
-       </Screen> </para>
+       </screen> </para>
 </listitem>
 
 <listitem><para> (Cygwin-only problem, I think.)
@@ -4803,7 +4870,7 @@ you do that, <command>ssh</command> uses the $HOME environment variable instead.
 </para>
 </sect2>
 
-<Sect2><Title>Other things you need to install</Title>
+<sect2><title>Other things you need to install</title>
 
 <para>You have to install the following other things to build GHC, listed below.</para>
 
@@ -4850,14 +4917,14 @@ Make sure the installation directory is in your
 
 <listitem>
 <para>GHC uses the <emphasis>mingw</emphasis> C compiler to
-generate code, so you have to install that (see <xref linkend="cygwin-and-mingw">). 
+generate code, so you have to install that (see <xref linkend="cygwin-and-mingw"/>). 
 Just pick up a mingw bundle at
 <ulink url="http://www.mingw.org/">http://www.mingw.org/</ulink>.
 We install it in <filename>c:/mingw</filename>.
 </para>
 <para>Do <emphasis>not</emphasis> add any of the <emphasis>mingw</emphasis> binaries to your  path.
 They are only going to get used by explicit access (via the --with-gcc flag you
-give to <Command>configure</Command> later).  If you do add them to your path
+give to <command>configure</command> later).  If you do add them to your path
 you are likely to get into a mess because their names overlap with Cygwin binaries.
 </para>
 </listitem>
@@ -4877,25 +4944,25 @@ so you will need to add <filename>emacs/bin</filename> to your <literal>PATH</li
 
 <listitem>
 <para> Finally, check out a copy of GHC sources from
-the CVS repository, following the instructions above (<xref linkend="cvs-access">).
+the CVS repository, following the instructions above (<xref linkend="cvs-access"/>).
 </para>
 </listitem>
 </itemizedlist>
 </para>
 </sect2>
 
-<Sect2><Title>Building GHC</Title>
+<sect2><title>Building GHC</title>
 
 <para>OK!  
-Now go read the documentation above on building from source (<xref linkend="sec-building-from-source">); 
+Now go read the documentation above on building from source (<xref linkend="sec-building-from-source"/>); 
 the bullets below only tell
 you about Windows-specific wrinkles.</para>
-<ItemizedList>
+<itemizedlist>
 <listitem>
 <para>
-If you used <Command>autoconf</Command> instead of <Command>autoreconf</Command>,
+If you used <command>autoconf</command> instead of <command>autoreconf</command>,
 you'll get an error when you run <filename>./configure</filename>:
-<Screen>
+<screen>
 ...lots of stuff...
 creating mk/config.h
 mk/config.h is unchanged
@@ -4903,7 +4970,7 @@ configuring in ghc
 running /bin/sh ./configure  --cache-file=.././config.cache --srcdir=.
 ./configure: ./configure: No such file or directory
 configure: error: ./configure failed for ghc
-</Screen>
+</screen>
 </para>
 </listitem>
 
@@ -4921,11 +4988,11 @@ Solution: delete <filename>configure</filename> first.
     After <command>autoreconf</command> run <command>./configure</command> in
     <filename>fptools/</filename> thus:
 
-<Screen>
+<screen>
   ./configure --host=i386-unknown-mingw32 --with-gcc=c:/mingw/bin/gcc
-</Screen>
+</screen>
 This is the point at which you specify that you are building GHC-mingw
-(see <xref linkend="ghc-mingw">). </para>
+(see <xref linkend="ghc-mingw"/>). </para>
 
 <para> Both these options are important! It's possible to get into
 trouble using the wrong C compiler!</para>
@@ -4942,7 +5009,7 @@ typically leaving you with this:
 <programlisting>
 make[4]: Leaving directory `/cygdrive/e/fptools-stage1/ghc/rts/gmp'
 ../../ghc/compiler/ghc-inplace -optc-mno-cygwin -optc-O 
-  -optc-Wall -optc-W  -optc-Wstrict-prototypes -optc-Wmissing-prototypes 
+  -optc-Wall -optc-W -optc-Wstrict-prototypes -optc-Wmissing-prototypes 
   -optc-Wmissing-declarations -optc-Winline -optc-Waggregate-return 
   -optc-Wbad-function-cast -optc-Wcast-align -optc-I../includes 
   -optc-I. -optc-Iparallel -optc-DCOMPILING_RTS 
@@ -4957,11 +5024,11 @@ Be warned!
 </para>
 
 <para>
-If you want to build GHC-cygwin (<xref linkend="ghc-cygwin">)
+If you want to build GHC-cygwin (<xref linkend="ghc-cygwin"/>)
 you'll have to do something more like:
-<Screen>
+<screen>
   ./configure --with-gcc=...the Cygwin gcc...
-</Screen>
+</screen>
 </para>
 </listitem>
 
@@ -4976,7 +5043,7 @@ can be really confusing.
 <programlisting>
   SplitObjs = NO
 </programlisting>
-in your <filename>build.mk</filename> configuration file (see <xref linkend="sec-build-config">).
+in your <filename>build.mk</filename> configuration file (see <xref linkend="sec-build-config"/>).
 This tells the build system not to split each library into a myriad of little object files, one
 for each function.  Doing so reduces binary sizes for statically-linked binaries, but on Windows
 it dramatically increases the time taken to build the libraries in the first place.
@@ -4986,10 +5053,10 @@ it dramatically increases the time taken to build the libraries in the first pla
 <listitem><para> Do not attempt to build the documentation.
 It needs all kinds of wierd Jade stuff that we haven't worked out for
 Win32.</para></listitem>
-</ItemizedList>
-</Sect2>
+</itemizedlist>
+</sect2>
 
 
 </sect1>
 
-</Article>
+</article>