|Part of Yhc|
You need a C compiler - both gcc and MS Visual C are known to be OK.
Getting the code
The source code is stored in a darcs repo, to get the code do:
darcs get --partial http://darcs.haskell.org/york-compiler98/
There is a buildbot script that runs on every change, the results of which are available here. If the build is busted, hopefully the developers will fix it soon. If your build is busted, but the buildbot succeeds, consider adding your machine as a buildbot slave - then it will never get broken again.
To build yhc simply type 'scons' into a console Window. This should automatically detect your build environment and place the Yhc binaries into inst/
To build parts of Yhc separately the following commands can be used:
- scons configure - Just configure.
- scons build - Don't update dependencies, just build.
- scons build yhi - Only build the interpretor.
- scons build yhc - Only build the compiler.
- scons build library - Only build the libraries.
Other commands available are:
- scons clean - Remove temporary files.
- scons fullclean - Completely wipe everything created by the build process.
- scons depends - Download or update the dependencies
- scons help - Show a help message
To test Yhc has been build correctly type 'scons test'.
Please report any problems you have to the mailing list.
Options can be given to scons by either passing the flags on the command line 'core=1' or by creating a file called options.txt in the root Yhc directory. The available flags are:
- core=1 (default=1) - generate Yhc Core files for each file in the libraries
- arch=X86 (default=calculated) - override the arch, useful for building 32 bit version on a 64 bit kernel.
- type=release/debug/normal (default=normal) - enables debug information or optimisation
- threads=0 (default=1, except on ppc where the default is 0) - disables threading
If something goes wrong
If the build fails for any reason, try the following steps:
; scons fullclean ; scons depends
Then try building again.
"scons help" shows some options for the build process.
To build with additional library/header paths, e.g. for GMP:
CCFLAGS="-I/.../include" LIBPATH=/.../lib scons