|Part of Yhc|
You need a C compiler - both gcc and MS Visual C are known to be OK.
You need scons, which in turn requires Python to be installed.
The process of building Yhc requires ghc-6.4 or later, Subversion and darcs.
2 Getting the Code
The source code is stored in a darcs repo, to get the code do:
darcs get --partial http://www.cs.york.ac.uk/fp/darcs/yhc-devel/
You can browse the code and its history on-line through a darcsweb interface.
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.
4 Scons Options
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=0) - 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.
- debug=1 (default=0) - enables debug information in the Yhi binary
- threads=0 (default=1, except on ppc where the default is 0) - disables threading