update README.md for Universal Interfaces requirements

This commit is contained in:
Wolfgang Thaller 2017-04-23 17:02:11 +02:00
parent 3ef227b418
commit 6eb2b66987
2 changed files with 30 additions and 14 deletions

View File

@ -19,7 +19,7 @@ Installing/Building
- CMake 2.8 - CMake 2.8
- GCC dependencies: GMP 4.2+, MPFR 2.3.1+ and MPC 0.8.0+ - GCC dependencies: GMP 4.2+, MPFR 2.3.1+ and MPC 0.8.0+
- bison version 3.0.2 or later - bison version 3.0.2 or later
- Apple Universal Interfaces (tested with versions 3.1 and 3.4 - see below) - Apple Universal Interfaces (version 3.x; version 3.4 is tested)
- An ancient Mac and/or an emulator. - An ancient Mac and/or an emulator.
For Ubuntu Linux, the following should help a bit: For Ubuntu Linux, the following should help a bit:
@ -37,26 +37,40 @@ In that case, get the tigerbrew package manager and
### Apple Universal Interfaces ### Apple Universal Interfaces
Before you can build Retro68, you need to find a copy of Apple's Universal Interfaces
and put it inside the InterfacesAndLibraries directory in the source tree.
Version 3.4 has received the most testing, but any 3.x version could theoretically
work.
The exact directory layout inside the InterfacesAndLibraries directory does
not matter. The resource forks of the files are not required.
The Universal Interfaces used to be a free download from Apple. However, The Universal Interfaces used to be a free download from Apple. However,
they have taken the site offline and the license agreement prohibits they have taken the site off-line and the license agreement does not allow
redistribution, so this might be a bit hard to find nowadays. redistribution, which is why it's not included in this repository.
The concept of fair use might cover keeping it available for reasons of historical
interest, or it might not. I am not a lawyer.
You do need a version that still supports 68K Mac development. The Universal Interfaces were also included with Apple's free-to-download
Macintosh Programmer's Workshop (MPW; redistribution is not officially allowed, either)
and with Metrowerks CodeWarrior.
The package might be somewhere in this huge snapshot of Apple's FTP site made One of the most easily found downloads is the MPW 3.5 Golden Master release,
by the Internet Archive: usually in a file named mpg-gm.img_.bin. At the time of this writing, this can be
https://archive.org/details/ftpsites_developer.apple.com found at:
If you have a Mac or some other way to read DiskCopy images, grab the MPW 3.5 http://macintoshgarden.org/apps/macintosh-programmers-workshop
image from: https://www.macintoshrepository.org/1360-macintosh-programmer-s-workshop-mpw-3-0-to-3-5
http://macintoshgarden.org/apps/macintosh-programmer%E2%80%99s-workshop
and use the CIncludes and RIncludes directories from there. You will need a Mac or a Mac emulator (with DiscCopy) to read that file.
If all else fails, the package is somewhere in this huge (4.7GB) snapshot of
Apple's FTP site at Internet Archive:
https://archive.org/details/ftpsites_developer.apple.com
Put the C header files into a directory called "CIncludes" at the top
level of the Retro68 directory; likewise, the Rez includes should go into
a directory called "RIncludes".
### Compiling Retro68 ### Compiling Retro68

View File

@ -360,6 +360,8 @@ fi # SKIP_THIRDPARTY
##################### Build host-based components: MakePEF, MakeImport, ConvertObj, Rez, ... ##################### Build host-based components: MakePEF, MakeImport, ConvertObj, Rez, ...
echo "Building host-based tools..."
# Copy PEFBinaryFormat.h from Universal Interfaces, needed by MakePEF & MakeImport # Copy PEFBinaryFormat.h from Universal Interfaces, needed by MakePEF & MakeImport
(export LANG=en; sed 's/\r$//' < "$CINCLUDES/PEFBinaryFormat.h" | tr '\r' '\n' > "toolchain/include/PEFBinaryFormat.h") (export LANG=en; sed 's/\r$//' < "$CINCLUDES/PEFBinaryFormat.h" | tr '\r' '\n' > "toolchain/include/PEFBinaryFormat.h")