Macintosh Programmer's Workshop (mpw) compatibility layer
Go to file
Kelvin Sherlock ada525cc4b update readme
2013-08-16 22:45:57 -04:00
bin home-brew lemon uses asserts 2013-08-15 23:58:31 -04:00
cpu disassembler - calculate pc relative addresses 2013-07-02 18:49:21 -04:00
macos traps 2013-07-01 22:40:55 -04:00
mplite
mpw new path conversion code 2013-08-03 00:33:24 -04:00
toolbox GetResInfo, LoadResource 2013-08-03 19:19:44 -04:00
verbatim updated Environment.text 2013-08-16 22:03:46 -04:00
.gitignore
CHANGELOG.text updated changelog 2013-08-03 19:21:44 -04:00
CMakeLists.txt move debugger code into bin, clean up dispatch 2013-07-07 23:42:27 -04:00
README.md update readme 2013-08-16 22:45:57 -04:00
README.text update readme 2013-08-16 22:45:57 -04:00
TODO.txt set LMTime global at start 2013-07-14 16:45:06 -04:00

MPW Emulator

by Kelvin W Sherlock, et alia

System compatibility:

Currently, only OS X 10.8 with case-insensitive HFS+ is supported.

License.

The 680x0 CPU code is from WinFellow (http://fellow.sourceforge.net) and is licensed under GPL v2 or later. Consequently, the rest of the code is licensed under the GPL v2 as well.

The memory allocator (NewHandle/NewPointer) code is from mempoolite, which is a fork of the SQLite zero-alloc allocator by Jefty Negapatan jeftyneg@gmail.com. It, as is SQLite, is in the public domain.

Building

Compiling requires cmake, ragel, lemon, and a recent version of clang++ with c++11 support. It has only been built and tested with OS X 10.8.

mkdir build cd build cmake .. make

This will generate bin/mpw and bin/disasm.

Installation

Certain configuration and execution files are generally useful. They are stored in an mpw directory, which may be located:

$MPW (shell variable)
~/mpw/ (your home directory)
/usr/local/share/mpw/
/usr/share/mpw/

The layout is reminiscent of actual MPW installations.

mpw/Environment.text
mpw/Tools/...
mpw/Interfaces/...
mpw/Libraries/...
mpw/Help/...

Environment file

The Environment.text file is new; it contains MPW environment variables (many of them set the library and include file locations). The format is fairly simple.

# this is a comment

#this sets a variable
name = value

# this sets a variable if it is undefined.
name ?= value

# values may refer to other variables
Libraries=$MPW:Libraries:Libraries:
Libraries=${MPW}:Libraries:Libraries:

Usage

mpw [mpw flags] command-name [command arguments]

you may also create shell aliases:

alias AsmIIgs='mpw AsmIIgs'

or create a shell script (in /usr/local/bin, etc)

/usr/local/bin/AsmIIgs:

#!/usr/bin/sh

exec mpw AsmIIgs $@

mpw looks in the current directory and then in the $MPW:Tools: directory for the command to run. The MPW $Commands variable is not yet supported.