blob: 0fc147f68755a28944819f7f235eb3cd52f28a99 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
|
<?xml version="1.0" encoding="iso-8859-1"?>
<chapter id="runghc">
<title>Using runghc</title>
<indexterm><primary>runghc</primary></indexterm>
<para>runghc allows you to run Haskell programs without first having
to compile them.</para>
<sect1 id="runghc-introduction">
<title>Flags</title>
<para>The runghc command-line looks like:</para>
<screen>
runghc [runghc flags] [GHC flags] module [program args]
</screen>
<para>The runghc flags are
<literal>-f /path/to/ghc</literal>,
which tells runghc which GHC to use to run the program,
and <literal>--help</literal>, which prints usage information. If it is
not given then runghc will search for GHC in the directories in the
system search path.</para>
<para>runghc will try to work out where the boundaries between
<literal>[runghc flags]</literal> and
<literal>[GHC flags]</literal>, and
<literal>[program args]</literal> and
<literal>module</literal> are, but you can use a
<literal>--</literal> flag if it doesn't get it right. For example,
<literal>runghc -- -fwarn-unused-bindings Foo</literal> means runghc
won't try to use <literal>warn-unused-bindings</literal> as the path to GHC,
but instead will pass the flag to GHC. If a GHC flag doesn't start
with a dash then you need to prefix it with
<literal>--ghc-arg=</literal> or runghc will think that it is the
program to run, e.g.
<literal>runghc -package-db --ghc-arg=foo.conf Main.hs</literal>.
</para>
</sect1>
</chapter>
<!-- Emacs stuff:
;;; Local Variables: ***
;;; sgml-parent-document: ("users_guide.xml" "book" "chapter") ***
;;; ispell-local-dictionary: "british" ***
;;; End: ***
-->
|