2010-08-04 18:04:07 +00:00
|
|
|
THE AMSTERDAM COMPILER KIT V6.0pre4
|
2007-02-25 12:53:55 +00:00
|
|
|
===================================
|
|
|
|
|
|
|
|
© 1987-2005 Vrije Universiteit, Amsterdam
|
2010-08-04 18:01:12 +00:00
|
|
|
2010-08-08
|
2007-02-25 12:53:55 +00:00
|
|
|
|
|
|
|
|
|
|
|
INTRODUCTION
|
|
|
|
============
|
|
|
|
|
|
|
|
The Amsterdam Compiler Kit is a complete compiler toolchain consisting of
|
|
|
|
front end compilers for a number of different languages, code generators,
|
|
|
|
support libraries, and all the tools necessary to go from source code to
|
|
|
|
executable on any of the platforms it supports.
|
|
|
|
|
2010-08-04 18:01:12 +00:00
|
|
|
This is an early prerelease of the apocryphal version 6.0 release. Not a
|
2007-02-25 12:53:55 +00:00
|
|
|
lot is supported, the build mechanism needs work, and a lot of things are
|
|
|
|
probably broken. However, what's there should be sufficient to get things
|
|
|
|
done and to evaluate how the full 6.0 release should work.
|
|
|
|
|
|
|
|
|
|
|
|
SUPPORT
|
|
|
|
=======
|
|
|
|
|
|
|
|
Languages:
|
|
|
|
|
2007-04-24 20:45:58 +00:00
|
|
|
ANSI C, Pascal, Modula 2. K&R is supported via the ANSI C compiler.
|
2007-02-25 12:53:55 +00:00
|
|
|
|
|
|
|
Platforms:
|
|
|
|
|
|
|
|
pc86 produces bootable floppy disk images for 8086 PCs
|
2007-04-24 20:45:58 +00:00
|
|
|
linux386 produces ELF executables for PC Linux systems
|
2007-04-29 23:09:24 +00:00
|
|
|
cpm produces i80 CP/M .COM files
|
2007-02-25 12:53:55 +00:00
|
|
|
|
|
|
|
|
|
|
|
INSTALLATION
|
|
|
|
============
|
|
|
|
|
|
|
|
The version 6.0 build mechanism has been completely rewritten and is based
|
|
|
|
around the Prime Mover build tool (see http://primemover.sf.net for more
|
|
|
|
information). Installation ought to be fairly straightforward.
|
|
|
|
|
|
|
|
Requirements:
|
|
|
|
|
|
|
|
- an ANSI C compiler. Currently, I'm afraid, it's hard-coded to use gcc.
|
|
|
|
To change, try changing the variable definitions in first/c.pm. This also
|
|
|
|
needs to be available as 'cc' from the shell.
|
|
|
|
|
|
|
|
- about 20MB free in /tmp (or some other temporary directory).
|
|
|
|
|
|
|
|
- about 6MB in the target directory.
|
|
|
|
|
|
|
|
Instructions:
|
|
|
|
|
|
|
|
- edit config.pm. There's a small section at the top containing some editable
|
|
|
|
variables. Probably the only one you may want to edit is PREFIX, which
|
|
|
|
changes where the ACK installs to.
|
|
|
|
|
|
|
|
- Run:
|
|
|
|
|
|
|
|
./pm configure
|
|
|
|
|
|
|
|
...from the command line. This will write out a configuration file.
|
|
|
|
|
|
|
|
- Run:
|
|
|
|
|
|
|
|
./pm
|
|
|
|
|
|
|
|
...from the command line. This will actually do the build. This takes
|
2007-02-25 22:09:15 +00:00
|
|
|
about two minutes on my 1.6GHz Athlon Linux machine and about 30 on my
|
|
|
|
166MHz Pentium OpenBSD machine.
|
2007-02-25 12:53:55 +00:00
|
|
|
|
|
|
|
- Run:
|
|
|
|
|
|
|
|
./pm install
|
|
|
|
|
2007-02-25 22:09:15 +00:00
|
|
|
...from the command line (possibly with sudo). This will install the built
|
|
|
|
ACK into whatever directory you nominated in PREFIX.
|
2007-02-25 12:53:55 +00:00
|
|
|
|
|
|
|
The ACK should now be ready to use.
|
|
|
|
|
|
|
|
|
|
|
|
USAGE
|
|
|
|
=====
|
|
|
|
|
|
|
|
Currently I haven't sorted out all the documentation --- it's supplied in the
|
|
|
|
distribution, but not all of it gets installed yet --- so here is a quickstart
|
|
|
|
guide.
|
|
|
|
|
|
|
|
The main command to use is 'ack'. This invokes the compiler and the linker.
|
|
|
|
Some useful options include:
|
|
|
|
|
|
|
|
-m<platform> build for the specified platform
|
|
|
|
-o <file> specifies the output file
|
|
|
|
-c produce a .o file
|
|
|
|
-c.s produce a .s assembly file
|
|
|
|
-O enable optimisation
|
|
|
|
-ansi compile ANSI C (when using the C compiler)
|
|
|
|
<file> build file
|
|
|
|
|
|
|
|
ack figures out which language to use from the file extension:
|
|
|
|
|
|
|
|
.c C (ANSI or K&R)
|
|
|
|
.b Basic
|
|
|
|
.mod Modula-2
|
|
|
|
.ocm Occam 1
|
|
|
|
.p Pascal
|
|
|
|
.o object files
|
|
|
|
.s assembly files
|
|
|
|
|
|
|
|
For further information, see the man page (which actually does get
|
|
|
|
installed, but is rather out of date).
|
|
|
|
|
|
|
|
There are some (known working) example programs in the 'examples' directory.
|
2007-04-24 20:45:58 +00:00
|
|
|
A sample command line is:
|
|
|
|
|
|
|
|
ack -mlinux386 -O examples/paranoia.c
|
2007-02-25 12:53:55 +00:00
|
|
|
|
|
|
|
|
|
|
|
GOTCHAS
|
|
|
|
=======
|
2005-06-24 23:20:41 +00:00
|
|
|
|
|
|
|
There are some things you should be aware of.
|
|
|
|
|
2007-04-29 23:09:24 +00:00
|
|
|
- Look at plat/<PLATFORMNAME>/README for information about the two supported
|
|
|
|
platforms.
|
2005-06-24 23:20:41 +00:00
|
|
|
|
2007-04-24 20:45:58 +00:00
|
|
|
- The library support is fairly limited; for C, it's at roughly the ANSI C
|
|
|
|
level, and for the other languages it's similar.
|
2005-06-24 23:20:41 +00:00
|
|
|
|
2007-02-25 12:53:55 +00:00
|
|
|
- When compiling languages other than C, the ACK will usually look at the
|
|
|
|
first character of the file. If it's a #, then the file will be run through
|
|
|
|
the C preprocessor anyway.
|
|
|
|
|
2007-02-25 22:09:15 +00:00
|
|
|
- BSD systems may need to up the number of file descriptors (e.g.
|
|
|
|
'ulimit -n 200') before the ACK will compile.
|
2005-06-24 23:20:41 +00:00
|
|
|
|
2007-02-25 22:09:15 +00:00
|
|
|
- The ACK uses its own .o format. You won't be able to mix the ACK's object
|
|
|
|
files and another compiler's.
|
|
|
|
|
|
|
|
|
2007-02-25 12:53:55 +00:00
|
|
|
DISCLAIMER
|
|
|
|
==========
|
2005-06-24 23:20:41 +00:00
|
|
|
|
|
|
|
The ACK is mature, well-tested software, but the environment in which it was
|
|
|
|
developed for and tested under is rather different from that available on
|
|
|
|
today's machines. There will probably be little in the way of logical bugs,
|
|
|
|
but there may be many compilation and API bugs.
|
|
|
|
|
|
|
|
If you wish to use the ACK, *please* join the mailing list. We are interested
|
|
|
|
in any reports of success and particularly, failure. If it does fail for you,
|
|
|
|
we would love to know why, in as much detail as possible. Bug fixes are even
|
|
|
|
more welcome.
|
|
|
|
|
|
|
|
The ACK is licensed under a BSD-like license. Please see the 'Copyright' file
|
|
|
|
for the full text.
|
|
|
|
|
|
|
|
You can find the mailing list on the project's web site:
|
|
|
|
|
|
|
|
http://tack.sourceforge.net/
|
|
|
|
|
|
|
|
Please enjoy.
|
|
|
|
|
|
|
|
David Given (dtrg on Sourceforge)
|
|
|
|
dg@cowlark.com
|
2010-08-04 18:01:12 +00:00
|
|
|
2010-08-08
|
|
|
|
|
|
|
|
# $Source$
|
|
|
|
# $State$
|
|
|
|
# $Revision$
|