executor/README

105 lines
4.3 KiB
Plaintext

Executor is a Macintosh emulator that is able to run many ancient Mac
OS 680x0 binaries (System 6 era, early System 7) without using any
intellectual property from Apple Computer.
Executor has not been actively worked on for many years. It is more
of a curiousity than anything practical; it does not run PowerPC
binaries, nor did it even run most System 7 applications. Unless you
have a particular application that you know works with Executor, or
just like emulation a lot, you probably don't want to spend any time
with Executor.
Included are a bunch of auxiliarly files and miscellaneous front-ends.
The DOS port required various other libraries that we had permission
to use, but that we did not necessarily have the permission to publish
the source for, so the source to some of the packages that the DOS
port requires is not present in the github repository.
If you want to try to build a version of Executor, try this:
cd src
autoreconf --install
cd ..
mkdir build
cd build
../src/configure
make
make install
That should leave you with a binary called "executor" (at least on
32-bit x86 Linux systems, or a Mac (Intel or PowerPC) with XCode 3
installed) and a directory called "skel". By default, executor will
be installed in "/usr/local/bin" and skel will be installed in
"/usr/local/share/executor".
skel itself isn't meant to be written to; it's meant to be copied
somewhere and for the copy to be read/write. For example,
cp -Rp /usr/local/share/executor/skel/volume /tmp/ExecutorVolume
export SystemFolder="/tmp/ExecutorVolume/System Folder"
executor
The environment variables that drive Executor including where Executor
looks for the system folder are a bit arcane and meant to fit together
with installers that we no longer use. It may make sense to make it
so that Executor automatically copies the contents of skel/volume to a
users home-directory the first time Executor is run, but that's an
exercise left to the reader.
If you're on an x86_64 based machine and you have the ability to compile
32-bit binaries and you have these packages installed (where the ? is 3 for
Fedora 10, 5 for Fedora 11 and 6 for Fedora 12):
SDL-devel.i?86
libX11-devel.i?86
db4-devel.i?86
libXext.i?86
libXrender.i?86
libXrandr.i?86
you may be able to build a copy of Executor by using our old build system
and doing something like
mkdir -p build/debug-linux
cd build/debug-linux
../../util/configure.sh '--host=i486-linux' '--build=i486-linux' '--front-end=sdl' '--host-gcc=gcc -m32' '--cflags=-fno-strict-aliasing -I/usr/X11R6/include -O0 -finline-functions -g -Wall' '--root=../..' '--host-file-format=glibc' '--sound=sdl' '--syn68k-host=i486-linux-glibc'
make
The above works on Fedora 10, 11 and 12 x86_64. Unfortunately, you'll have
to manually copy skel from ../../src, e.g.:
cp -rp ../../src/skel/volume /tmp/ExecutorVolume
export SystemFolder='/tmp/ExecutorVolume/System Folder'
./executor
Yes, the above is pretty messy. It would be great if someone could make it
so that we don't need to use the old build system to get the 32-bit version
to compile on a 64-bit machine and if someone could make the build process
detect when various 32-bit libraries aren't available, but don't hold your
breath.
In the past it was possible to cross-compile a version of Executor for
Windows using mingw32. So far that port hasn't been tried since
putting the code on Github. It probably doesn't work, but probably
could be made to work without much effort.
At one time we had Executor running on the Alpha, a 64-bit
environment. We actually modified gcc to support "pointer bit-fields"
and were able to get Executor to run. Now that 64-bit machines are
more popular, I've begun an experiment in supporting 64-bit machines
without modifying the compiler. See README.64 for more info.
As I continue Executor's transition to a recent gnu build system I may
inadvertantly push versions that don't build when using the above
commands. Don't hesitate to ask me if you're having trouble
compiling, linking or running any of the above platforms.
My email address is still <ctm@ardi.com>, although ARDI itself is
defunct. I get a ridiculous amount of spam and will quite possibly
not see email addressed to me. I'm ctm on github (http://github.com)
and typically check my email there once a day.
--Cliff Matthews