| 1 | As of GC6.0alpha8, we attempt to support GNU-style builds based on automake,
|
|---|
| 2 | autoconf and libtool. This is based almost entirely on Tom Tromey's work
|
|---|
| 3 | with gcj.
|
|---|
| 4 |
|
|---|
| 5 | To build and install libraries use
|
|---|
| 6 |
|
|---|
| 7 | configure; make; make install
|
|---|
| 8 |
|
|---|
| 9 | The advantages of this process are:
|
|---|
| 10 |
|
|---|
| 11 | 1) It should eventually do a better job of automatically determining the
|
|---|
| 12 | right compiler to use, etc. It probably already does in some cases.
|
|---|
| 13 |
|
|---|
| 14 | 2) It tries to automatically set a good set of default GC parameters for
|
|---|
| 15 | the platform (e.g. thread support). It provides an easier way to configure
|
|---|
| 16 | some of the others.
|
|---|
| 17 |
|
|---|
| 18 | 3) It integrates better with other projects using a GNU-style build process.
|
|---|
| 19 |
|
|---|
| 20 | 4) It builds both dynamic and static libraries.
|
|---|
| 21 |
|
|---|
| 22 | The known disadvantages are:
|
|---|
| 23 |
|
|---|
| 24 | 1) The build scripts are much more complex and harder to debug (though largely
|
|---|
| 25 | standard). I don't understand them all, and there's probably lots of redundant
|
|---|
| 26 | stuff.
|
|---|
| 27 |
|
|---|
| 28 | 2) It probably doesn't work on all Un*x-like platforms yet. It probably will
|
|---|
| 29 | never work on the rest.
|
|---|
| 30 |
|
|---|
| 31 | 3) The scripts are not yet complete. Some of the standard GNU targets don't
|
|---|
| 32 | yet work. (Corrections/additions are very welcome.)
|
|---|
| 33 |
|
|---|
| 34 | The distribution should contain all files needed to run "configure" and "make",
|
|---|
| 35 | as well as the sources needed to regenerate the derived files. (If I missed
|
|---|
| 36 | some, please let me know.)
|
|---|
| 37 |
|
|---|
| 38 | Note that the distribution comes with a "Makefile" which will be overwritten
|
|---|
| 39 | by "configure" with one that is not at all equiavelent to the original. The
|
|---|
| 40 | distribution contains a copy of the original "Makefile" in "Makefile.direct".
|
|---|
| 41 |
|
|---|
| 42 | Important options to configure:
|
|---|
| 43 |
|
|---|
| 44 | --prefix=PREFIX install architecture-independent files in PREFIX
|
|---|
| 45 | [/usr/local]
|
|---|
| 46 | --exec-prefix=EPREFIX install architecture-dependent files in EPREFIX
|
|---|
| 47 | [same as prefix]
|
|---|
| 48 | --enable-threads=TYPE choose threading package
|
|---|
| 49 | --enable-parallel-mark parallelize marking and free list construction
|
|---|
| 50 | --enable-full-debug include full support for pointer backtracing etc.
|
|---|
| 51 |
|
|---|
| 52 | Unless --prefix is set (or --exec-prefix or one of the more obscure options),
|
|---|
| 53 | make install will install libgc.a and libgc.so in /usr/local/bin, which
|
|---|
| 54 | would typically require the "make install" to be run as root.
|
|---|
| 55 |
|
|---|
| 56 | Most commonly --enable-threads=posix or will be needed. --enable-parallel-mark
|
|---|
| 57 | is recommended for multiprocessors if it is supported on the platform.
|
|---|
| 58 |
|
|---|
| 59 |
|
|---|