[project @ 2004-08-15 20:37:22 by panne]
[ghc-hetmet.git] / ghc / docs / users_guide / debugging.sgml
diff --git a/ghc/docs/users_guide/debugging.sgml b/ghc/docs/users_guide/debugging.sgml
deleted file mode 100644 (file)
index 340d7d8..0000000
+++ /dev/null
@@ -1,522 +0,0 @@
-<sect1 id="options-debugging">
-  <title>Debugging the compiler</title>
-
-  <indexterm><primary>debugging options (for GHC)</primary></indexterm>
-
-  <para>HACKER TERRITORY. HACKER TERRITORY.  (You were warned.)</para>
-
-  <sect2 id="dumping-output">
-    <title>Dumping out compiler intermediate structures</title>
-    
-    <indexterm><primary>dumping GHC intermediates</primary></indexterm>
-    <indexterm><primary>intermediate passes, output</primary></indexterm>
-    
-    <variablelist>
-      <varlistentry>
-       <term><option>-ddump-</option><replaceable>pass</replaceable></term>
-       <indexterm><primary><option>-ddump</option> options</primary></indexterm>
-       <listitem>
-         <para>Make a debugging dump after pass
-        <literal>&lt;pass&gt;</literal> (may be common enough to need
-        a short form&hellip;).  You can get all of these at once
-        (<emphasis>lots</emphasis> of output) by using
-        <option>-v5</option>, or most of them with
-        <option>-v4</option>.  Some of the most useful ones
-        are:</para>
-
-         <variablelist>
-           <varlistentry>
-             <term><option>-ddump-parsed</option>:</term>
-             <listitem>
-               <para>parser output</para>
-             </listitem>
-           </varlistentry>
-
-           <varlistentry>
-             <term><option>-ddump-rn</option>:</term>
-             <listitem>
-               <para>renamer output</para>
-             </listitem>
-           </varlistentry>
-
-           <varlistentry>
-             <term><option>-ddump-tc</option>:</term>
-             <listitem>
-               <para>typechecker output</para>
-             </listitem>
-           </varlistentry>
-
-           <varlistentry>
-             <term><option>-ddump-types</option>:</term>
-             <listitem>
-               <para>Dump a type signature for each value defined at
-              the top level of the module.  The list is sorted
-              alphabetically.  Using <option>-dppr-debug</option>
-              dumps a type signature for all the imported and
-              system-defined things as well; useful for debugging the
-              compiler.</para>
-             </listitem>
-           </varlistentry>
-
-           <varlistentry>
-             <term><option>-ddump-deriv</option>:</term>
-             <listitem>
-               <para>derived instances</para>
-             </listitem>
-           </varlistentry>
-
-           <varlistentry>
-             <term><option>-ddump-ds</option>:</term>
-             <listitem>
-               <para>desugarer output</para>
-             </listitem>
-           </varlistentry>
-
-           <varlistentry>
-             <term><option>-ddump-spec</option>:</term>
-             <listitem>
-               <para>output of specialisation pass</para>
-             </listitem>
-           </varlistentry>
-
-           <varlistentry>
-             <term><option>-ddump-rules</option>:</term>
-             <listitem>
-               <para>dumps all rewrite rules (including those generated
-             by the specialisation pass)</para>
-             </listitem>
-           </varlistentry>
-
-           <varlistentry>
-             <term><option>-ddump-simpl</option>:</term>
-             <listitem>
-               <para>simplifer output (Core-to-Core passes)</para>
-             </listitem>
-           </varlistentry>
-
-           <varlistentry>
-             <term><option>-ddump-inlinings</option>:</term>
-             <listitem>
-               <para>inlining info from the simplifier</para>
-             </listitem>
-           </varlistentry>
-
-           <varlistentry>
-             <term><option>-ddump-usagesp</option>:</term>
-             <listitem>
-               <para>UsageSP inference pre-inf and output</para>
-             </listitem>
-           </varlistentry>
-
-           <varlistentry>
-             <term><option>-ddump-cpranal</option>:</term>
-             <listitem>
-               <para>CPR analyser output</para>
-             </listitem>
-           </varlistentry>
-
-           <varlistentry>
-             <term><option>-ddump-stranal</option>:</term>
-             <listitem>
-               <para>strictness analyser output</para>
-             </listitem>
-           </varlistentry>
-
-           <varlistentry>
-             <term><option>-ddump-cse</option>:</term>
-             <listitem>
-               <para>CSE pass output</para>
-             </listitem>
-           </varlistentry>
-
-           <varlistentry>
-             <term><option>-ddump-workwrap</option>:</term>
-             <listitem>
-               <para>worker/wrapper split output</para>
-             </listitem>
-           </varlistentry>
-
-           <varlistentry>
-             <term><option>-ddump-occur-anal</option>:</term>
-             <listitem>
-               <para>`occurrence analysis' output</para>
-             </listitem>
-           </varlistentry>
-
-           <varlistentry>
-             <term><option>-ddump-sat</option>:</term>
-             <listitem>
-               <para>output of &ldquo;saturate&rdquo; pass</para>
-             </listitem>
-           </varlistentry>
-
-           <varlistentry>
-             <term><option>-ddump-stg</option>:</term>
-             <listitem>
-               <para>output of STG-to-STG passes</para>
-             </listitem>
-           </varlistentry>
-
-           <varlistentry>
-             <term><option>-ddump-absC</option>:</term>
-             <listitem>
-               <para><emphasis>un</emphasis>flattened Abstract&nbsp;C</para>
-             </listitem>
-           </varlistentry>
-
-           <varlistentry>
-             <term><option>-ddump-flatC</option>:</term>
-             <listitem>
-               <para><emphasis>flattened</emphasis> Abstract&nbsp;C</para>
-             </listitem>
-           </varlistentry>
-
-           <varlistentry>
-             <term><option>-ddump-realC</option>:</term>
-             <listitem>
-               <para>same as what goes to the C compiler</para>
-             </listitem>
-           </varlistentry>
-
-           <varlistentry>
-             <term><option>-ddump-stix</option>:</term>
-             <listitem>
-               <para>native-code generator intermediate form</para>
-             </listitem>
-           </varlistentry>
-
-           <varlistentry>
-             <term><option>-ddump-asm</option>:</term>
-             <listitem>
-               <para>assembly language from the native-code generator</para>
-             </listitem>
-           </varlistentry>
-
-           <varlistentry>
-             <term><option>-ddump-bcos</option>:</term>
-             <listitem>
-               <para>byte code compiler output</para>
-             </listitem>
-           </varlistentry>
-
-           <varlistentry>
-             <term><option>-ddump-foreign</option>:</term>
-             <listitem>
-               <para>dump foreign export stubs</para>
-             </listitem>
-           </varlistentry>
-
-         </variablelist>
-
-         <indexterm><primary><option>-ddump-absC</option></primary></indexterm>
-         <indexterm><primary><option>-ddump-bcos</option></primary></indexterm>
-         <indexterm><primary><option>-ddump-cpranal</option></primary></indexterm>
-         <indexterm><primary><option>-ddump-cse</option></primary></indexterm>
-
-         <indexterm><primary><option>-ddump-deriv</option></primary></indexterm>
-         <indexterm><primary><option>-ddump-ds</option></primary></indexterm>
-         <indexterm><primary><option>-ddump-flatC</option></primary></indexterm>
-         <indexterm><primary><option>-ddump-foreign</option></primary></indexterm>
-         <indexterm><primary><option>-ddump-inlinings</option></primary></indexterm>
-         <indexterm><primary><option>-ddump-occur-anal</option></primary></indexterm>
-         <indexterm><primary><option>-ddump-parsed</option></primary></indexterm>
-         <indexterm><primary><option>-ddump-realC</option></primary></indexterm>
-         <indexterm><primary><option>-ddump-rn</option></primary></indexterm>
-         <indexterm><primary><option>-ddump-rules</option></primary></indexterm>
-         <indexterm><primary><option>-ddump-sat</option></primary></indexterm>
-         <indexterm><primary><option>-ddump-simpl</option></primary></indexterm>
-         <indexterm><primary><option>-ddump-spec</option></primary></indexterm>
-         <indexterm><primary><option>-ddump-stg</option></primary></indexterm>
-         <indexterm><primary><option>-ddump-stix</option></primary></indexterm>
-         <indexterm><primary><option>-ddump-stranal</option></primary></indexterm>
-         <indexterm><primary><option>-ddump-tc</option></primary></indexterm>
-
-         <indexterm><primary><option>-ddump-usagesp</option></primary></indexterm>
-         <indexterm><primary><option>-ddump-workwrap</option></primary></indexterm>
-       </listitem>
-      </varlistentry>
-      
-      <varlistentry>
-       <term><option>-dverbose-core2core</option></term>
-       <term><option>-dverbose-stg2stg</option></term>
-       <indexterm><primary><option>-dverbose-core2core</option></primary></indexterm>
-       <indexterm><primary><option>-dverbose-stg2stg</option></primary></indexterm>
-       <listitem>
-         <para>Show the output of the intermediate Core-to-Core and
-        STG-to-STG passes, respectively.  (<emphasis>Lots</emphasis>
-        of output!) So: when we're really desperate:</para>
-
-         <screen>
-% ghc -noC -O -ddump-simpl -dverbose-simpl -dcore-lint Foo.hs
-</screen>
-
-       </listitem>
-      </varlistentry>
-      
-      <varlistentry>
-       <term><option>-ddump-simpl-iterations</option>:</term>
-       <indexterm><primary><option>-ddump-simpl-iterations</option></primary></indexterm>
-       <listitem>
-         <para>Show the output of each <emphasis>iteration</emphasis>
-        of the simplifier (each run of the simplifier has a maximum
-        number of iterations, normally 4).  Used when even
-        <option>-dverbose-simpl</option> doesn't cut it.</para>
-       </listitem>
-      </varlistentry>
-
-      <varlistentry>
-       <term><option>-dppr-debug</option></term>
-       <indexterm><primary><option>-dppr-debug</option></primary></indexterm>
-       <listitem>
-         <para>Debugging output is in one of several
-          &ldquo;styles.&rdquo; Take the printing of types, for
-          example.  In the &ldquo;user&rdquo; style (the default), the
-          compiler's internal ideas about types are presented in
-          Haskell source-level syntax, insofar as possible.  In the
-          &ldquo;debug&rdquo; style (which is the default for
-          debugging output), the types are printed in with explicit
-          foralls, and variables have their unique-id attached (so you
-          can check for things that look the same but aren't).  This
-          flag makes debugging output appear in the more verbose debug
-          style.</para>
-       </listitem>
-      </varlistentry>
-
-      <varlistentry>
-       <term><option>-dppr-user-length</option></term>
-       <indexterm><primary><option>-dppr-user-length</option></primary></indexterm>
-       <listitem>
-         <para>In error messages, expressions are printed to a
-         certain &ldquo;depth&rdquo;, with subexpressions beyond the
-         depth replaced by ellipses.  This flag sets the
-         depth.</para>
-       </listitem>
-      </varlistentry>
-
-      <varlistentry>
-       <term><option>-ddump-simpl-stats</option></term>
-       <indexterm><primary><option>-ddump-simpl-stats option</option></primary></indexterm>
-       <listitem>
-         <para>Dump statistics about how many of each kind of
-        transformation too place.  If you add
-        <option>-dppr-debug</option> you get more detailed
-        information.</para>
-       </listitem>
-      </varlistentry>
-
-      <varlistentry>
-       <term><option>-ddump-rn-trace</option></term>
-       <indexterm><primary><option>-ddump-rn-trace</option></primary></indexterm>
-       <listitem>
-         <para>Make the renamer be *real* chatty about what it is
-       upto.</para>
-       </listitem>
-      </varlistentry>
-
-      <varlistentry>
-       <term><option>-ddump-rn-stats</option></term>
-       <indexterm><primary><option>-dshow-rn-stats</option></primary></indexterm>
-       <listitem>
-         <para>Print out summary of what kind of information the renamer
-        had to bring in.</para>
-       </listitem>
-      </varlistentry>
-
-      <varlistentry>
-       <term><option>-dshow-unused-imports</option></term>
-       <indexterm><primary><option>-dshow-unused-imports</option></primary></indexterm>
-       <listitem>
-         <para>Have the renamer report what imports does not
-       contribute.</para>
-       </listitem>
-      </varlistentry>
-    </variablelist>
-  </sect2>
-
-  <sect2 id="checking-consistency">
-    <title>Checking for consistency</title>
-
-    <indexterm><primary>consistency checks</primary></indexterm>
-    <indexterm><primary>lint</primary></indexterm>
-
-    <variablelist>
-
-      <varlistentry>
-       <term><option>-dcore-lint</option></term>
-       <indexterm><primary><option>-dcore-lint</option></primary></indexterm>
-       <listitem>
-         <para>Turn on heavyweight intra-pass sanity-checking within
-          GHC, at Core level.  (It checks GHC's sanity, not yours.)</para>
-       </listitem>
-      </varlistentry>
-
-      <varlistentry>
-       <term><option>-dstg-lint</option>:</term>
-       <indexterm><primary><option>-dstg-lint</option></primary></indexterm>
-       <listitem>
-         <para>Ditto for STG level. (NOTE: currently doesn't work).</para>
-       </listitem>
-      </varlistentry>
-
-      <varlistentry>
-       <term><option>-dusagesp-lint</option>:</term>
-       <indexterm><primary><option>-dstg-lint</option></primary></indexterm>
-       <listitem>
-         <para>Turn on checks around UsageSP inference
-          (<option>-fusagesp</option>).  This verifies various simple
-          properties of the results of the inference, and also warns
-          if any identifier with a used-once annotation before the
-          inference has a used-many annotation afterwards; this could
-          indicate a non-worksafe transformation is being
-          applied.</para>
-       </listitem>
-      </varlistentry>
-    </variablelist>
-  </sect2>
-
-  <sect2>
-    <title>How to read Core syntax (from some <option>-ddump</option>
-    flags)</title>
-
-    <indexterm><primary>reading Core syntax</primary></indexterm>
-    <indexterm><primary>Core syntax, how to read</primary></indexterm>
-
-    <para>Let's do this by commenting an example.  It's from doing
-    <option>-ddump-ds</option> on this code:
-
-<programlisting>
-skip2 m = m : skip2 (m+2)
-</programlisting>
-
-    Before we jump in, a word about names of things.  Within GHC,
-    variables, type constructors, etc., are identified by their
-    &ldquo;Uniques.&rdquo; These are of the form `letter' plus
-    `number' (both loosely interpreted).  The `letter' gives some idea
-    of where the Unique came from; e.g., <literal>&lowbar;</literal>
-    means &ldquo;built-in type variable&rdquo;; <literal>t</literal>
-    means &ldquo;from the typechecker&rdquo;; <literal>s</literal>
-    means &ldquo;from the simplifier&rdquo;; and so on.  The `number'
-    is printed fairly compactly in a `base-62' format, which everyone
-    hates except me (WDP).</para>
-
-    <para>Remember, everything has a &ldquo;Unique&rdquo; and it is
-    usually printed out when debugging, in some form or another.  So
-    here we go&hellip;</para>
-
-<programlisting>
-Desugared:
-Main.skip2{-r1L6-} :: _forall_ a$_4 =&#62;{{Num a$_4}} -&#62; a$_4 -&#62; [a$_4]
-
---# `r1L6' is the Unique for Main.skip2;
---# `_4' is the Unique for the type-variable (template) `a'
---# `{{Num a$_4}}' is a dictionary argument
-
-_NI_
-
---# `_NI_' means "no (pragmatic) information" yet; it will later
---# evolve into the GHC_PRAGMA info that goes into interface files.
-
-Main.skip2{-r1L6-} =
-    /\ _4 -&#62; \ d.Num.t4Gt -&#62;
-        let {
-          {- CoRec -}
-          +.t4Hg :: _4 -&#62; _4 -&#62; _4
-          _NI_
-          +.t4Hg = (+{-r3JH-} _4) d.Num.t4Gt
-
-          fromInt.t4GS :: Int{-2i-} -&#62; _4
-          _NI_
-          fromInt.t4GS = (fromInt{-r3JX-} _4) d.Num.t4Gt
-
---# The `+' class method (Unique: r3JH) selects the addition code
---# from a `Num' dictionary (now an explicit lamba'd argument).
---# Because Core is 2nd-order lambda-calculus, type applications
---# and lambdas (/\) are explicit.  So `+' is first applied to a
---# type (`_4'), then to a dictionary, yielding the actual addition
---# function that we will use subsequently...
-
---# We play the exact same game with the (non-standard) class method
---# `fromInt'.  Unsurprisingly, the type `Int' is wired into the
---# compiler.
-
-          lit.t4Hb :: _4
-          _NI_
-          lit.t4Hb =
-              let {
-                ds.d4Qz :: Int{-2i-}
-                _NI_
-                ds.d4Qz = I#! 2#
-              } in  fromInt.t4GS ds.d4Qz
-
---# `I# 2#' is just the literal Int `2'; it reflects the fact that
---# GHC defines `data Int = I# Int#', where Int# is the primitive
---# unboxed type.  (see relevant info about unboxed types elsewhere...)
-
---# The `!' after `I#' indicates that this is a *saturated*
---# application of the `I#' data constructor (i.e., not partially
---# applied).
-
-          skip2.t3Ja :: _4 -&#62; [_4]
-          _NI_
-          skip2.t3Ja =
-              \ m.r1H4 -&#62;
-                  let { ds.d4QQ :: [_4]
-                        _NI_
-                        ds.d4QQ =
-                    let {
-                      ds.d4QY :: _4
-                      _NI_
-                      ds.d4QY = +.t4Hg m.r1H4 lit.t4Hb
-                    } in  skip2.t3Ja ds.d4QY
-                  } in
-                  :! _4 m.r1H4 ds.d4QQ
-
-          {- end CoRec -}
-        } in  skip2.t3Ja
-</programlisting>
-
-    <para>(&ldquo;It's just a simple functional language&rdquo; is an
-    unregisterised trademark of Peyton Jones Enterprises, plc.)</para>
-
-  </sect2>
-
-  <sect2 id="unreg">
-    <title>Unregisterised compilation</title>
-    <indexterm><primary>unregisterised compilation</primary></indexterm>
-
-    <para>The term "unregisterised" really means "compile via vanilla
-    C", disabling some of the platform-specific tricks that GHC
-    normally uses to make programs go faster.  When compiling
-    unregisterised, GHC simply generates a C file which is compiled
-    via gcc.</para>
-
-    <para>Unregisterised compilation can be useful when porting GHC to
-    a new machine, since it reduces the prerequisite tools to
-    <command>gcc</command>, <command>as</command>, and
-    <command>ld</command> and nothing more, and furthermore the amount
-    of platform-specific code that needs to be written in order to get
-    unregisterised compilation going is usually fairly small.</para>
-
-    <variablelist>
-      <varlistentry>
-       <term><option>-unreg</option>:</term>
-       <indexterm><primary><option>-unreg</option></primary></indexterm>
-       <listitem>
-         <para>Compile via vanilla ANSI C only, turning off
-         platform-specific optimisations.  NOTE: in order to use
-         <option>-unreg</option>, you need to have a set of libraries
-         (including the RTS) built for unregisterised compilation.
-         This amounts to building GHC with way "u" enabled.</para>
-       </listitem>
-      </varlistentry>
-    </variablelist>
-  </sect2>
-
-</sect1>
-
-<!-- Emacs stuff:
-     ;;; Local Variables: ***
-     ;;; mode: sgml ***
-     ;;; sgml-parent-document: ("users_guide.sgml" "book" "chapter" "sect1") ***
-     ;;; End: ***
- -->