So you've decided to hack on GHC, congratulations! We hope you have a rewarding experience. This file will point you in the direction of information to help you get started right away.
The home for GHC hackers is our Trac instance, located here:
http://ghc.haskell.org/trac/ghc
From here, you can file bugs (or look them up,) use the wiki, view the
git
history, among other things. Of particular note is the building
page, which has the high level overview of the build process and how
to get the source:
http://ghc.haskell.org/trac/ghc/wiki/Building
Make sure your system has the necessary tools to compile GHC. You can find an overview here:
http://ghc.haskell.org/trac/ghc/wiki/Building/Preparation
Next, clone the repository and all the associated libraries:
$ git clone --recursive git://git.haskell.org/ghc.git
On Windows, you need an extra repository containing some build tools. These can be downloaded for you by configure. This only needs to be done once by running:
$ ./configure --enable-tarballs-autodownload
First copy mk/build.mk.sample
to mk/build.mk
and ensure it has
your preferred build settings. (You probably want to at least set
BuildFlavour
to quick
):
$ cp mk/build.mk.sample mk/build.mk
$ ... double-check mk/build.mk ...
Now build. If you have multiple cores, you should always use them to speed up compilation:
$ ./boot
$ ./configure
$ make -jN # <N> is the number of cores you have.
You can use the ./inplace/bin/ghc-stage2
binary to play with the
newly built compiler.
Now, hack on your copy and rebuild (with make
) as necessary.
Then start by making your commits however you want. When you're done, you
can use git format-patch
to create a series of .patch
files you
can give to us. In this example, we'll assume I'm on a bugfix
branch
and want to submit my patches:
$ git branch
* bugfix
master
$ git format-patch master -o patches
...
$
Now create a trac ticket:
http://ghc.haskell.org/trac/ghc/newticket?type=bug
And attach the files in your patches/
directory. Set the status from
new to patch and we'll review it as soon as we can!
An overview of things like using git, the release process, filing bugs and more can be located here:
http://ghc.haskell.org/trac/ghc/wiki/WorkingConventions
You can find our coding conventions for the compiler and RTS here:
http://ghc.haskell.org/trac/ghc/wiki/Commentary/CodingStyle http://ghc.haskell.org/trac/ghc/wiki/Commentary/Rts/Conventions
A high level overview of the bug tracker:
http://ghc.haskell.org/trac/ghc/wiki/WorkingConventions/BugTracker
If you're going to contribute regularly, learning how to use the build system is important and will save you lots of time. You should read over this page carefully:
http://ghc.haskell.org/trac/ghc/wiki/Building/Using
GHC is a big project, so you'll surely need help. Luckily, we can provide plenty through a variety of means!
If you're an IRC user, be sure to drop by the official #ghc
channel
on freenode. Many (but not all) of the
developers and committers are actively there during a variety of
hours.
In the event IRC does not work or if you'd like a bigger audience, GHC has several mailing lists for this purpose. The most important one is ghc-devs, which is where the developers actively hang out and discuss incoming changes and problems.
There is no strict standard about where you post patches - either in
ghc-devs
or in the bug tracker. Ideally, please put it in the bug
tracker with test cases or relevant information in a ticket, and set
the ticket status to patch
. By doing this, we'll see the patch
quickly and be able to review. This will also ensure it doesn't get
lost. But if the change is small and self contained, feel free to
attach it to your email, and send it to ghc-devs
.
Furthermore, if you're a developer (or want to become one!) you're undoubtedly also interested in the other mailing lists:
- glasgow-haskell-users is where developers/users meet.
- ghc-tickets for email from Trac.
- ghc-builds for nightly build emails.
- ghc-commits for commit messages when someone pushes to the repository.
Happy Hacking! -- The GHC Team