The Amsterdam Compiler Kit
Find a file
2006-07-21 11:24:46 +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 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
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 Added the appropriate #! magic at the beginning of shell scripts. (Some modern shells don't like scripts to be without it.) 2006-07-19 14:09:25 +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 First version in CVS. 2006-07-20 23:24:28 +00:00
h Header --> Id 1994-06-24 11:31:16 +00:00
include Header --> Id 1994-06-24 14:02:31 +00:00
lang First version in CVS. 2006-07-20 23:24:28 +00:00
lib Updated to point at the ncg code generator instead of the cg one. 2006-07-20 22:37:57 +00:00
mach Removed duplicate (and incorrect) system function declarations. 2006-07-21 11:17:18 +00:00
man Header --> Id 1994-06-24 14:02:31 +00:00
modules Removed duplicate (and incorrect) system function declarations. 2006-07-21 11:17:18 +00:00
util Now resolves symlinks when creating releases (which avoids including a symlink to pm in the distribution, and not pm itself). 2006-07-21 11:24:46 +00:00
.distr Added some new readmes at the top level. 2005-06-24 23:20:41 +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 First version in CVS. 2006-07-20 22:57:46 +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 First version in CVS. 2006-07-20 22:57:46 +00:00
pmfile Fixed revision history. 2006-07-20 23:24:42 +00:00
README Added comment about the use of 'cc' rather than 'gcc'. 2006-07-18 17:21:34 +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$

Installing the ACK on a modern platform
=======================================

This document provides some very quick and dirty instructions for installing
the ACK on a modern platform. It is not intended as a substitute for the
real instructions, which can be found in doc/install.pr.

Let me repeat myself:

THE FULL INSTALLATION INSTRUCTIONS ARE IN doc/install.pr.

The ACK is a very large and complex package and has received minimal
maintenance for the best part of a decade. During that time, the Unix
world has moved on, and many APIs have changed. It compiles cleanly on
my, dtrg's, test machine, which is a Debian Ubuntu Linux system. Your
mileage may vary.

All disclaimers now done, now on to the good stuff:

Building the ACK
----------------

I'm assuming you're using Linux here, because that's what I use. If you
don't use Linux, please let me know if you have any trouble and I'll update
the instructions.

1. Prerequisites
   
   The ACK wants to be built with a C compiler called cc. From what I've seen
   so far of the build system, this can be changed, but not easily.
   
   Most platforms have their compiler set up so that 'cc' invokes it, whatever
   it is; however, some don't. So far the only one I've met that doesn't do
   this is Solaris with gcc installed, but without the Sun native compiler.
   
   If this is the case, the simplest thing to do is to place a symlink to gcc
   (or your favourite C compiler) in your path somewhere. For example:
   
      ln -s /usr/bin/gcc ~/bin/cc
   
2. Configure the build.

   To do this, run the first/first script. You will be asked several
   questions.
   
   * What is the root of the ACK source tree?
   
     This is the directory that you have unpacked the distribution into.
     For example, /home/dg/src/Ack-5.6.
     
   * What is the root of the configuration tree?
   
     This is the directory that the build process will use for temporary
     files. You'll only need this during the compilation process; it can
     be removed afterwards.
     For example, /tmp/ack-conf
     
   * What is the root of the ACK binaries?
   
     This is the ACK's installation path; where the binaries will live.
     This needs to be writable during the build process --- if you want
     to install in /usr/local, you either have to make /usr/local
     writable or compile as root. Sorry!
     
   * What is your system type?
   
     Linux isn't on the list. Choose ANY.
     
   * Is this the system you are running on?
   
     Yes.
     
   * Are you satisfied?
   
     Yes.
     
   * What default machine do you wish to compile for?
   
     The ACK wants to know what architecture to target if you don't manually
     specify an architecture. Unfortunately, it can't generate runnable
     binaries for Linux or any other modern system (except possible Solaris
     on Sparc). I'd recommend you choose em44. This will produce portable
     binaries using the ACK's intermediate format, which you can run using
     the int interpreter.
     
   * What kind of Unix are you running?
   
     Linux is a mixture, but I pick SYS_5 and it works.
     
   * Do you wish to limit the installation?
   
     No. If you pick Yes, the script will ask detailed questions about
     exactly what you want to build. Modern systems are fast enough that
     we may as well build everything.
     
   * Which system call library do you wish to use on the VAX?
   
     I don't have a VAX; the only person I know who has one uses it to vacuum
     his carpets. I pick libsysV_2 with no ill effects.
     
   If the configuration script is happy, it will generate a script called
   INSTALL.
   
3. Do the compilation.

   The configuration script will recommend a command line. Execute this. On
   modern systems, the compilation doesn't take long.
   
   Check the output of the configuration script for "Failed" lines. On my
   system there are two:
   
     $ grep Failed INSTALL.out
     Failed for Intel 8080 download programs, see dl/Out
     Failed for Intel 8080 support
   
   You can ignore these. They aren't important.
   
4. Use the ACK.

   Ensure that the ACK's binary directory is on your path; this is /bin in
   the directory you specified during the configuration process. In my
   example, this is /usr/local/bin. The /man subdirectory should go on your
   manpath.

   To test your path, do: ack
   
   This should return silently.
   
   To test your manpath, do: man ack
      
   This will produce the documentation for the main compiler driver.
   
   If this works, you can remove the conf tree (/tmp/ack-conf in my example).
   
Gotchas
-------

There are some things you should be aware of.

* The ACK's archiver tool is called 'arch'. This conflicts on Linux platforms
  with a utility that displays the current architecture. If your compilation
  occasionally fails obscurely and displays something like 'i686', you are
  running afoul of this. As a workaround, rearrange your path so the ACK's
  bin directory comes first --- but do be aware that some Linux system
  tools may stop working.
  
* 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.
  
* Not all combinations of optimisation and architectures work. This is
  perfectly normal, but the combinations are not well documented. Everything
  supports -O.
  
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
2005-06-24, 23:53

# Revision history
# $Log$
# Revision 2.3  2006-07-18 17:21:34  dtrg
# Added comment about the use of 'cc' rather than 'gcc'.
#
# Revision 2.2  2005/06/24 23:20:41  dtrg
# Added some new readmes at the top level.