The Amsterdam Compiler Kit
Go to file
2007-04-23 23:41:50 +00:00
bin Added the appropriate #! magic at the beginning of shell scripts. (Some modern shells don't like scripts to be without it.) 2006-07-18 16:45:57 +00:00
distr Performed major renovations to make the script work on OpenBSD. 2007-02-25 20:56:41 +00:00
doc Modified to no longer build LLgen, as it is now distributed separately. 2006-07-19 14:03:33 +00:00
emtest Replaced references to /usr/tmp with references to /tmp. 2005-06-24 22:08:47 +00:00
etc em_table is now in /h; new_table is now in util/data. 2007-02-25 12:58:41 +00:00
examples Added the 'Star Trek' example game. 2007-04-21 23:20:11 +00:00
fast use stdarg when compiling with ANSI C compiler 1995-08-17 14:36:05 +00:00
fcc use stdarg when compiling with ANSI C compiler 1995-08-18 07:26:18 +00:00
first Updated .distr files for the new release. 2007-02-25 12:51:55 +00:00
h Adapted for ANSI C and our pseudo-Posix syscall interface. 2007-04-21 23:18:14 +00:00
include Updated .distr files for the new release. 2007-02-25 12:51:55 +00:00
lang Adapted for ANSI C and our pseudo-Posix syscall interface. 2007-04-21 23:18:14 +00:00
lib Disabled the K&R C compiler in favour of the ANSI one. 2007-04-21 23:03:35 +00:00
mach Updated to work with the linux386 platform. 2007-04-21 22:57:51 +00:00
man Header --> Id 1994-06-24 14:02:31 +00:00
modules Modified to allow a space between the sign and the first digit of a constant. 2007-04-23 23:24:46 +00:00
plat Now fetches argc, argv, env correctly from the host OS. 2007-04-23 23:24:03 +00:00
util Modified to run ncgg input files through the ANSI preprocessor rather than the K&R one. 2007-04-23 23:40:59 +00:00
.distr Updated .distr files for the new release. 2007-02-25 12:51:55 +00:00
Action Modified to no longer build LLgen, as it is now distributed seperately. 2006-07-18 17:34:30 +00:00
config.pm Adjusted some of the default parameters and their names. 2007-02-25 12:52:32 +00:00
Copyright new copyright notice in repository 2005-05-26 06:47:43 +00:00
DistrAction corrected for new TakeAction 1988-07-27 13:17:15 +00:00
Makefile Initial revision 1984-06-29 11:00:55 +00:00
NEW Added some new readmes at the top level. 2005-06-24 23:20:41 +00:00
pm Applied a patch to support OpenBSD. 2007-02-25 22:07:11 +00:00
pmfile Added support for the linux386 platform. Disabled building of the K&R C, Basic and Occam compilers. 2007-04-23 23:41:50 +00:00
README Added some OpenBSD-related comments. 2007-02-25 22:09:15 +00:00
TakeAction Added the appropriate #! magic at the beginning of shell scripts. (Some modern shells don't like scripts to be without it.) 2006-07-18 17:20:46 +00:00
TODO Added some new readmes at the top level. 2005-06-24 23:20:41 +00:00

# $Source$
# $State$
# $Revision$

                     THE AMSTERDAM COMPILER KIT V6.0pre1
                     ===================================

                  © 1987-2005 Vrije Universiteit, Amsterdam
                                2007-02-25


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.

This is an early prerelease of the upcoming version 6.0 release. Not a
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:

ANSI C, K&R C, Pascal, Modula 2, Occam 1, and a Basic variant.

Platforms:

pc86          produces bootable floppy disk images for 8086 PCs


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
  about two minutes on my 1.6GHz Athlon Linux machine and about 30 on my
  166MHz Pentium OpenBSD machine.
  
- Run:

    ./pm install
    
  ...from the command line (possibly with sudo). This will install the built
  ACK into whatever directory you nominated in PREFIX.
  
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.


GOTCHAS
=======

There are some things you should be aware of.

- The only platform supported so far is pc86, which generates 8086 tiny mode
  executables that will work as floppy disk boot images. So, to run, simply dd
  the output file (pc86.img by default) onto a floppy disk and boot from it.
  Be aware that very little functionality is supported and that the entire
  program, heap and stack and code and all, must fit within 64kB. See
  plat/pc86/README for more information.
  
- By default, the ack tool will compile K&R C. Practically all C source these
  days is ANSI C --- use the -ansi switch to enable ANSI mode. No, the ACK is
  not C99 compatible.
  
- 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.

- BSD systems may need to up the number of file descriptors (e.g.
  'ulimit -n 200') before the ACK will compile.
  
- The ACK uses its own .o format. You won't be able to mix the ACK's object
  files and another compiler's.


DISCLAIMER
==========

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
2007-02-25