(That's hacking in the "tinkering with code" sense, not in the "breaking into other people's computer systems" sense).
This is currently a random collection of notes that need to be written down while I remember. With time it should evolve into a more coherent document. If you have any questions which this should answer but doesn't then ask me and I'll add them.
You can pick which network simplifications are attempted using "-z" with an argument listing code letters. So:
And you can combine these in any combination:
"-z=lpd" is the default (in 0.99 at least - more transformations may conceivably be added in future, although the simple common cases are already covered).
You'll need automake 1.5 or later (earlier versions don't support per-executable CFLAGS; 1.6 has been tested and works) and autoconf 2.50 or later (for AC_ARG_VAR). There seem to be problems with trying to use autoconf 2.53 - autoconf 2.52 is known to work.
For building the documentation you'll need sgmltools 2 or later, docbook-to-man, and w3m.
Currently I build this with a Linux hosted cross-compiler. I built this myself mostly following instructions from:
http://www.objsw.com/CrossGCC/
I suggest using binutils-2.10 rather than binutils-2.9.1. The newer version includes the patch they supply, so the instructions boil down to this sequence of commands:
bash mkdir ~/djcross cd ~/djcross wget ftp://ftp.objsw.com/pub/crossgcc/build-djgpp.sh mkdir tars cd tars # can't get it to build with djcrx203 wget ftp://ftp.simtel.net/pub/simtelnet/gnu/djgpp/v2/old/djcrx202.zip # can't get 2.95.3 to build wget http://sunsite.org.uk/gnu/gcc/gcc-2.95.2.tar.gz # can't get 2.10.1 to build wget http://sunsite.org.uk/gnu/binutils/binutils-2.10.tar.gz cd .. patch -l build-djgpp.sh <<END 26c26 < binutils=binutils-2.9.1 --- > binutils=binutils-2.10 97c97 < patch -p1 <\$patches/\$binutilsdiff --- > #patch -p1 <\$patches/\$binutilsdiff END sh build-djgpp.sh
Then you need to build and install the Allegro graphics library:
http://prdownloads.sourceforge.net/alleg/allegro-4.0.1.tar.gz
And follow the instructions for building using a cross-compiler which you can find starting from readme.txt. In 4.0.1 these boil down to:
cd allegro-4.0.1 ./fix.sh djgpp --quick NATIVEPATH=$PATH export NATIVEPATH DJDIR=/opt/crosstools/i386-pc-msdosdjgpp export DJDIR PATH=$DJDIR/bin:/opt/crosstools/bin:$PATH CROSSCOMPILE=1 export CROSSCOMPILE make make install PATH=$NATIVEPATH
Building Survex under DOS in a native djgpp environment will require some tinkering. Best bet is either to install bash and use the current configure script, or perhaps simpler to modify miniam.pl to generate a suitable makefile. I'm happy to help if you want to try this, and I'll incorporate patches provided they're fairly clean.
Currently I build this with a Linux hosted cross-compiler. I use the packaged cross-compiler in the debian testing/unstable distribution. You can probably install these on other distributions using alien to convert them to RPMs or similar. Alternatively, before that I used to use pre-built binaries for gcc 2.95.2 obtained from:
http://www.devolution.com/~slouken/SDL/Xmingw32/
Building on Windows in a native mingw environment will probably require tinkering. Best bet is probably to install bash and use the current configure script. I'm happy to help if you want to try this, and I'll incorporate patches provided they're fairly clean.
Building on Windows with MSVC/BorlandC/Watcom/... is likely to be more work, but could be a worthwhile project. I'd suggest patching the perl script miniam.pl to generate a suitable makefile. Again, send patches if you get this to work.
Wookey currently builds this with a rather elderly BorlandC++ 3.1. BorlandC++ 5.5 can be downloaded for free, but it appears to only compile to 32 bit code. You can also download TurboC version 2, which might do the job (I've not tried).
You can build a suitable source archive for this version using
`make alien_src_zip' on the source distribution on a Unix box (you need to
have run `./configure' first).  Then unzip the src<version>.zip file
produced on the MSDOS machine and run make.bat.
We now build this with Acorn C V5. It will probably still build with Acorn C V4. You also need to get and install OSLib from:
http://www.arcade.demon.co.uk/oslib/homepage.html
You can build a suitable source archive for compiling the RISC OS version by running `make alien_src_zip' on the source distribution on a Unix box (you need to have run `./configure' first). However for this you'll need a specially tweaked version of zip to create the zip file with the correct RISC OS file types. I can supply this on request. You need to put it in the top level of the source tree and call it `zip-magic'.
You'll probably need to use Acorn's Make Utility (`amu') to build - the GNU make 1.02 port doesn't seem up to the job.
To build, create a fresh directory (or empty one) and unpack the contents of srcN_NN.zip into it (using !SparkFS or similar). Then double-click on `!ObeyMe' in the unpacked directory to rename the source files into c and h subdirectories. Then double-click on `!MakeMe' to build survex.
Survex needs various support files. Under UNIX the path to the support files needs to be built into the programs, but this causes a problem if the support files need to be installed elsewhere for some reason and the programs can't be rebuilt. To get around this problem, you can define an environmental variable SURVEXHOME to point to a directory in which to look for support files.
This mechanism may sometimes useful on other operating systems.
Under UNIX, use "setenv SURVEXHOME /home/user/survex" (csh) or "SURVEXHOME=/home/user/survex ; export SURVEXHOME" (sh).
For DOS, put SET SURVEXHOME=C:\SURVEX in your AUTOEXEC.BAT file
For RISC OS put *Set SURVEXHOME ADFS::4.$.Survex.!Survex into your Boot !Run or !DeskTop