- Added cfm68k instructions

- Changed names of various things
- Explain how to recreate .exp files.
This commit is contained in:
Jack Jansen 1996-08-23 15:44:18 +00:00
parent 97662c89fa
commit 27b10eced7
1 changed files with 67 additions and 15 deletions

View File

@ -57,12 +57,13 @@ <H2>What you need.</H2>
<A NAME="optional">The MacPython project files are configured to <A NAME="optional">The MacPython project files are configured to
include a plethora of optional modules</A>, and these modules need a include a plethora of optional modules</A>, and these modules need a
number extra packages. To use the project files as-is you have to number extra packages. To use the project files as-is you have to
download these packages too. PPC Python has all such modules as download these packages too. PPC and CFM68K Python have all such modules as
dynamically loaded modules, so if you don't need a certain package it dynamically loaded modules, so if you don't need a certain package it
suffices to just refrain from builing the extension module. For 68K suffices to just refrain from builing the extension module. For static 68K
Python things are a bit more complicated: you have to edit the Python things are a bit more complicated: you have to edit the
interpreter project file to remove the reference to the module (and interpreter project file to remove the reference to the module (and
the libraries it uses). Here are the locations for the various things the libraries it uses), and edit the <code>Mac:mwerks:mwerks_nonshared_config.h</code>
file to remove the <code>USE_...</code> line. Here are the locations for the various things
you need: you need:
<UL> <UL>
@ -120,11 +121,12 @@ <H2>Setting Up</H2>
</PRE> </PRE>
Now build all the libraries. In <code>CWGUSI</code> you build the Now build all the libraries. In <code>CWGUSI</code> you build the
projects <code>GUSI.68K.µ</code> and <code>GUSI.PPC.µ</code>, in projects <code>GUSI.68K.µ</code>, <code>GUSI.CFM68K.µ</code>
and <code>GUSI.PPC.µ</code>, in
<code>MoreFiles</code>, <code>libjpeg</code>, <code>pbmplus</code> <code>MoreFiles</code>, <code>libjpeg</code>, <code>pbmplus</code>
and<code>libtiff</code> you build all projects. Tcl/tk is a special and<code>libtiff</code> you build all projects. Tcl/tk is a special
case, see below. Of course, if you are only interested in 68K you can case, see below. Of course, if you are only interested in one of
skip building the PPC libraries and vice versa. static 68K, CFM68K or PPC you can skip building the other libraries.
<H2><A NAME="tcltk">Building Tcl/Tk</H2> <H2><A NAME="tcltk">Building Tcl/Tk</H2>
@ -159,6 +161,12 @@ <H2><A NAME="tcltk">Building Tcl/Tk</H2>
use the resulting pointer without checking for <code>NULL</code> use the resulting pointer without checking for <code>NULL</code>
values. Needless to say, this wreaks havoc on a Macintosh. values. Needless to say, this wreaks havoc on a Macintosh.
<LI> If you want to build for CFM68K you have to modify <code>TclMacNotify.c</code>
because there is an error in the Apple Universal headers (sic!). Read the
comments at the beginning of <code>Mac:Python:macglue.c</code> and copy the
code to <code>TclMacNotify.c</code>. If you get linker errors on <code>GetEvQHdr</code>
you have not done this correctly.
</UL> </UL>
Build first the MoreFiles library, then the Tcl library, then Build first the MoreFiles library, then the Tcl library, then
@ -187,11 +195,15 @@ <H2>The organization of the Python source tree</H2>
<DL> <DL>
<DT> build.mac68k.stand <DT> build.mac68k.stand
<DD> This is where you will build 68K interpreters. <DD> This is where you will build static 68K interpreters.
<DT> build.mac68k.shared
<DD> This is where you build the CFM68K shared library, interpreter
and applet framework.
<DT> build.macppc.shared <DT> build.macppc.shared
<DD> This is where you build the PPC shared library, interpreter and <DD> This is where you build the PPC shared library, interpreter and
applet framework. applet framework. You can also build the fat applet framework here.
<DT> build.macppc.stand <DT> build.macppc.stand
<DD> This is where you build a nonshared PPC interpreter (optional). <DD> This is where you build a nonshared PPC interpreter (optional).
@ -225,7 +237,7 @@ <H2>The organization of the Python source tree</H2>
<DD> The Python parser (machine-independent). <DD> The Python parser (machine-independent).
<DT> PlugIns <DT> PlugIns
<DD> This is where you build the PPC dynamically-loaded plugin modules. <DD> This is where you build the PPC and CFM68K dynamically-loaded plugin modules.
<DT> Python <DT> Python
<DD> The core interpreter. Most files are machine-independent, some <DD> The core interpreter. Most files are machine-independent, some
@ -318,6 +330,12 @@ <H2>Building the 68K interpreter</H2>
(<code>Relnotes-somethingorother</code>) and (<code>Relnotes-somethingorother</code>) and
<code>ReadMeOrSuffer</code> in the <code>Mac</code> folder. <code>ReadMeOrSuffer</code> in the <code>Mac</code> folder.
<H2>Building the CFM68K interpreter</H2>
Building the CFM68K interpreter is as almost exactly the same as building
the PPC interpreter, with the exception that you should read "CFM68K"
for "PPC" every time. Continue reading with the next section.
<H2>Building the PPC interpreter</H2> <H2>Building the PPC interpreter</H2>
First you build the interpreter, core library and applet skeleton in First you build the interpreter, core library and applet skeleton in
@ -325,12 +343,12 @@ <H2>Building the PPC interpreter</H2>
the following: the following:
<DL> <DL>
<DT> PythonCoreRuntime <DT> MWRuntimeStaticLib
<DD> A modified version of the MetroWerks runtime library that is <DD> A modified version of the MetroWerks runtime library that is
suitable for Pythons' shared library architecture. The sources all suitable for Pythons' shared library architecture. The sources all
come from the MW distribution. come from the MW distribution.
<DT> PythonCore <DT> PythonCorePPC
<DD> The shared library that contains the bulk of the interpreter and <DD> The shared library that contains the bulk of the interpreter and
its resources. It is a good idea to immedeately put an alias to this its resources. It is a good idea to immedeately put an alias to this
shared library in the <code>Extensions</code> folder of your system shared library in the <code>Extensions</code> folder of your system
@ -366,11 +384,12 @@ <H2>Building the PPC interpreter</H2>
PythonApplet). <p> PythonApplet). <p>
Next, you have to build the extension modules in the Next, you have to build the extension modules in the
<code>PlugIns</code> folder. Open each project and build it. After all <code>PlugIns</code> folder. Open each project with <code>.ppc</code> in the
name and build it. After all
the dynamically loaded modules are built you have to create a number the dynamically loaded modules are built you have to create a number
of aliases: some modules live together in a single dynamic of aliases: some modules live together in a single dynamic
library. Copy or move the <code>MkPluginAliases.py</code> script from library. Run the <code>MkPluginAliases.py</code> script from
<code>Mac:scripts</code> to the main python folder and run it. <p> <code>Mac:scripts</code> to create the aliases. <p>
Finally, you must build the standard applets: Finally, you must build the standard applets:
<code>EditPythonPrefs</code>, <code>mkapplet</code>, etc. This is <code>EditPythonPrefs</code>, <code>mkapplet</code>, etc. This is
@ -391,6 +410,24 @@ <H2>Building the PPC interpreter</H2>
You are all set now, and should read the release notes and You are all set now, and should read the release notes and
<code>ReadMeOrSuffer</code> file from the <code>Mac</code> folder. <code>ReadMeOrSuffer</code> file from the <code>Mac</code> folder.
<H2>Rebuilding <code>.exp</code> files for PPC and CFM68K</H2>
Occasionally it may be necessary to rebuild your PythonCore <code>.exp</code>
file, a file that controls which symbols are exported by your PythonCore
shared library. Rebuild it if you get unexpected undefined symbols when you
are building a plugin module. <p>
Rebuilding the .exp file is done by first removing the file and removing the
reference to it in the project (in the "config" section). Next, build PythonCore.
This will create a new .exp file. Edit this file to remove the references to
the symbols <code>__initialize</code>, <code>__terminate</code>, <code>setjmp</code>,
<code>longjmp</code> and <code>__ptmf_null</code>. Next, add the .exp file to the project
again and rebuild PythonCore. <p>
This rather convoluted procedure is needed to ensure that plugin modules don't
accidentally link with those entrypoints from PythonCore, which will not work because
those routines have to be in the same code fragment as they are used from.
<H2>Odds and ends</H2> <H2>Odds and ends</H2>
Some remarks that I could not fit in elsewhere: Some remarks that I could not fit in elsewhere:
@ -408,7 +445,22 @@ <H2>Odds and ends</H2>
<code>Include</code>, <code>Mac:Include</code> and <code>Include</code>, <code>Mac:Include</code> and
<code>Mac:mwerks</code> from the source distribution and you should be <code>Mac:mwerks</code> from the source distribution and you should be
all set. A template for a dynamic module can be found in all set. A template for a dynamic module can be found in
<code>xxmodule.µ</code>. <code>xx.ppc.µ</code> or <code>xx.CFM68K.µ</code>.
<LI> The Python shared library architecture is a variant of the architecture
described as "application with shared libraries and dropins" in the MetroWerks
"Targeting MacOS" documentation. The Python Application and applet-template use
the <code>AppRuntime.Lib</code> runtime library (with properly set CFM
initialization and termination routines). PythonCore uses <code>ShlibRuntime.Lib</code>
and <code>MWRuntimeStaticLib.Lib</code>, which is almost identical to the MW
standard <code>MWRuntimeLib</code>, but not dynamically loaded. This library contains
the part of the runtime that can (or must) be shared between all modules in the program.
It is linked statically into PythonCore (and exported to the applications and plugins)
so we do not have to distribute yet another shared library. Plugin modules use
<code>ShlibRuntime.Lib</code> and obtain the rest from PythonCore. PythonCore uses a
non-standard initialization entry point, <code>__initialize_with_resources</code>, to
be able to obtain resources from the library file lateron. Plugins can do the same or
use the standard <code>__initialize</code> entry point.
<UL> <UL>