summaryrefslogtreecommitdiff
path: root/docs
diff options
context:
space:
mode:
authorSimon Peyton Jones <simonpj@microsoft.com>2012-04-30 16:43:02 +0100
committerSimon Peyton Jones <simonpj@microsoft.com>2012-04-30 16:43:02 +0100
commit2822e00d3e126e30c3ed2ca8dc90a075180e42ec (patch)
tree09bff554392ef121efd19f0264ba0b6487538778 /docs
parent081ee177f3727a4c1bfad5897cab51e30c209521 (diff)
downloadhaskell-2822e00d3e126e30c3ed2ca8dc90a075180e42ec.tar.gz
Document eta expansion under GHC bugs and infelicities
Diffstat (limited to 'docs')
-rw-r--r--docs/users_guide/bugs.xml26
1 files changed, 20 insertions, 6 deletions
diff --git a/docs/users_guide/bugs.xml b/docs/users_guide/bugs.xml
index c2abe45e73..49d6a8dca6 100644
--- a/docs/users_guide/bugs.xml
+++ b/docs/users_guide/bugs.xml
@@ -107,17 +107,31 @@ main = do args &lt;- getArgs
<sect3 id="infelicities-exprs-pats">
<title>Expressions and patterns</title>
- <para>None known.</para>
+ <para>In its default mode, GHC makes some programs sligtly more defined
+ than they should be. For example, consider
+ <programlisting>
+f :: [a] -> b -> b
+f [] = error "urk"
+f (x:xs) = \v -> v
+
+main = print (f [] `seq` True)
+ </programlisting>
+This should call <literal>error</literal> but actually prints <literal>True</literal>.
+Reason: GHC eta-expands <literal>f</literal> to
+ <programlisting>
+f :: [a] -> b -> b
+f [] v = error "urk"
+f (x:xs) v = v
+ </programlisting>
+This improves efficiency slightly but significantly for most programs, and
+is bad for only a few. To suppress this bogus "optimisation" use <option>-fpedantic-bottoms</option>.
+</para>
+
</sect3>
<sect3 id="infelicities-decls">
<title>Declarations and bindings</title>
- <para>GHC's typechecker makes all pattern bindings monomorphic
- by default; this behaviour can be disabled with
- <option>-XNoMonoPatBinds</option>. See <xref
- linkend="options-language" />.</para>
-
<para>In its default mode, GHC does not accept datatype contexts,
as it has been decided to remove them from the next version of the
language standard. This behaviour can be controlled with the