Go to the first, previous, next, last section, table of contents.
GHC has to link your code with various libraries, possibly including:
user-supplied, GHC-supplied, and system-supplied (`-lm' math
library, for example).
- `-l<FOO>':
- Link in a library named `lib<FOO>.a' which resides somewhere on the
library directories path.
Because of the sad state of most UNIX linkers, the order of such
options does matter. Thus: `ghc -lbar *.o' is almost certainly
wrong, because it will search `libbar.a' before it has
collected unresolved symbols from the `*.o' files.
`ghc *.o -lbar' is probably better.
The linker will of course be informed about some GHC-supplied
libraries automatically; these are:
-l equivalent description
-------------------------------------------------------------
-lHSrts,-lHSclib basic runtime libraries
-lHS standard Prelude library
-lHS_cbits C support code for standard Prelude library
-lgmp GNU multi-precision library (for Integers)
- `-syslib <name>':
- If you are using a Haskell "system library" (e.g., the HBC
library), just use the `-syslib hbc' option, and the correct code
should be linked in.
- `-L<dir>':
- Where to find user-supplied libraries... Prepend the directory
`<dir>' to the library directories path.
- `-static':
- Tell the linker to avoid shared libraries.
- `-no-link-chk' and `-link-chk':
- By default, immediately after linking an executable, GHC verifies that
the pieces that went into it were compiled with compatible flags; a
"consistency check".
(This is to avoid mysterious failures caused by non-meshing of
incompatibly-compiled programs; e.g., if one `.o' file was compiled
for a parallel machine and the others weren't.) You may turn off this
check with `-no-link-chk'. You can turn it (back) on with
`-link-chk' (the default).
Go to the first, previous, next, last section, table of contents.