header files included.
#include "macdefs.h"
char *
-getbootvol()
+getbootvol(void)
{
short vrefnum;
static unsigned char name[32];
#define ROOTID 2 /* Root directory ID */
char *
-getwd(cwd)
- char *cwd;
+getwd(char *cwd)
{
/* Universal parameter block. */
union {
#define S_IWRITE 0200
#define S_IEXEC 0100
+extern int macstat(char *, struct macstat *);
/* To stop inclusion of MWerks header: */
#ifndef _STAT
#define _STAT
#include "macdefs.h"
int
-sync()
+sync(void)
{
if (FlushVol((StringPtr)0, 0) == noErr)
return 0;
#endif
/* We may be able to use a std routine in think, don't know */
-unsigned char *Pstring(char *);
-
+extern unsigned char *Pstring(char *);
+extern char *getbootvol(void);
+extern char *getwd(char *);
+extern int sync(void);
/* Universal constants: */
#define MAXPATH 256
void PyMac_SetSchedParams(PyMacSchedParams *); /* Set schedulers params */
PyObject *PyErr_Mac(PyObject *, int); /* Exception with a mac error */
PyObject *PyMac_Error(OSErr); /* Uses PyMac_GetOSErrException */
+int PyOS_CheckStack(void); /* Check that we aren't overflowing our stack */
int PyMac_DoYield(int, int); /* Yield cpu. First arg is maxtime, second ok to call python */
int PyMac_HandleEvent(EventRecord *); /* Handle one event, possibly in Python */
void PyMac_HandleEventIntern(EventRecord *); /* Handle one event internal only */
/* From macfiletype.c: */
-long getfiletype(char *); /* Get file type */
-int setfiletype(char *, long, long); /* Set file creator and type */
+long PyMac_getfiletype(char *); /* Get file type */
+int PyMac_setfiletype(char *, long, long); /* Set file creator and type */
+
+/* from macmain.c: */
+void PyMac_Exit(int);
+void PyMac_InitApplication(void);
+#ifdef USE_MAC_APPLET_SUPPORT
+void PyMac_InitApplet(void);
+#endif
+
+/* from macgetargv: */
+OSErr PyMac_init_process_location(void);
+#ifndef HAVE_STRDUP
+char * strdup(const char *str);
+#endif
+
#ifdef __cplusplus
}
#endif
#include "getapplbycreator.h"
+/* Should this be in macglue.h? */
+extern FSSpec *mfs_GetFSSpecFSSpec(PyObject *);
+
static PyObject *ErrorObject;
/* ----------------------------------------------------- */
return Py_FindMethod(mfsa_methods, (PyObject *)self, name);
}
-mfsaobject *
-newmfsaobject(alias)
- AliasHandle alias;
+static mfsaobject *
+newmfsaobject(AliasHandle alias)
{
mfsaobject *self;
** object is a python fsspec object, else NULL
*/
FSSpec *
-mfs_GetFSSpecFSSpec(self)
- PyObject *self;
+mfs_GetFSSpecFSSpec(PyObject *self)
{
if ( is_mfssobject(self) )
return &((mfssobject *)self)->fsspec;
#include "Python.h"
+#include "macglue.h"
#include <Gestalt.h>
#include "Speech.h"
#pragma lib_export on
#endif
-extern void PyMac_InitApplet();
+extern void PyMac_InitApplication(void);
#ifdef USE_MAC_APPLET_SUPPORT
-extern void PyMac_InitApplication();
+extern void PyMac_InitApplet(void);
#endif /* USE_MAC_APPLET_SUPPORT */
+/* From the MSL runtime: */
+extern void __initialize(void);
/*
** Alternative initialization entry point for some very special cases.
/* Duplicate a string to the heap. We also export this since it isn't standard
** and others use it
*/
-
+#ifndef HAVE_STRDUP
char *
-strdup(char *src)
+strdup(const char *src)
{
char *dst = malloc(strlen(src) + 1);
if (dst)
strcpy(dst, src);
return dst;
}
+#endif
/* Initialize FSSpec and full name of current application */
/* Return a string representing the compiler name */
#include "config.h"
+#include "Python.h"
#ifdef __MWERKS__
#ifdef USE_GUSI1
#endif
#endif
-char *
-Py_GetCompiler()
+const char *
+Py_GetCompiler(void)
{
return COMPILER;
}
#include "osdefs.h"
#include "macglue.h"
#include "pythonresources.h"
+#ifdef HAVE_UNISTD_H
+#include <unistd.h>
+#endif
/* Return the initial python search path. This is called once from
#include <GUSI.h>
#endif
+#ifndef USE_BUILTIN_PATH
+staticforward char *PyMac_GetPythonPath();
+#endif
+
#define PYTHONPATH "\
:\n\
:Lib\n\
char *p, *endp;
int newlen;
char *curwd;
-#ifndef USE_BUILTIN_PATH
- staticforward char *PyMac_GetPythonPath();
-#endif
if ( pythonpath ) return pythonpath;
#ifndef USE_BUILTIN_PATH
#ifndef USE_BUILTIN_PATH
char *
-PyMac_GetPythonPath()
+PyMac_GetPythonPath(void)
{
short oldrh, prefrh = -1;
char *rv;
******************************************************************/
-char *
-Py_GetPlatform()
+#include "Python.h"
+
+const char *
+Py_GetPlatform(void)
{
return "mac";
}
#include <TextUtils.h>
#ifdef __MWERKS__
#include <SIOUX.h>
+extern void SIOUXSetupMenus(void);
+extern void SIOUXDoAboutBox(void);
#endif
+#ifdef USE_GUSI
+/* Functions we redefine because they're in obscure libraries */
+extern void SpinCursor(short x);
+extern void RotateCursor(short x);
+extern pascal void PLstrcpy(unsigned char *, unsigned char *);
+extern pascal int PLstrcmp(unsigned char *, unsigned char *);
+extern pascal unsigned char *PLstrrchr(unsigned char *, unsigned char);
+
+#endif
+
#ifdef USE_GUSI1
#include <TFileSpec.h> /* For Path2FSSpec */
#include <GUSI.h>
#define fnfErr -43
/* Declared in macfsmodule.c: */
-extern FSSpec *mfs_GetFSSpecFSSpec();
+extern FSSpec *mfs_GetFSSpecFSSpec(PyObject *);
extern PyObject *newmfssobject(FSSpec *);
/* Interrupt code variables: */
** StdCLib. Moreover, that implementation is broken under cfm68k...
*/
pascal void
-PLstrcpy(to, fr)
- unsigned char *to, *fr;
+PLstrcpy(unsigned char *to, unsigned char *fr)
{
memcpy(to, fr, fr[0]+1);
}
pascal int
-PLstrcmp(s1, s2)
- unsigned char *s1, *s2;
+PLstrcmp(unsigned char *s1, unsigned char *s2)
{
int res;
int l = s1[0] < s2[0] ? s1[0] : s2[0];
}
pascal unsigned char *
-PLstrrchr(str, chr)
- unsigned char *str;
- unsigned char chr;
+PLstrrchr(unsigned char *str, unsigned char chr)
{
unsigned char *ptr = 0;
unsigned char *p;
return interrupted;
}
/* Check whether we are in the foreground */
-int
-PyMac_InForeground()
+static int
+PyMac_InForeground(void)
{
static ProcessSerialNumber ours;
static inited;
#include <string.h>
/* Interface used by parsetok.c */
-
+#error
guesstabsize(path)
char *path;
{
unsigned char fnbuf[64];
int modnamelen = strlen(module);
FSSpec fss;
+#ifdef USE_GUSI1
FInfo finfo;
+#endif
short refnum;
long dirid;
#ifdef __MWERKS__
#include <SIOUX.h>
#define USE_SIOUX
+extern int ccommand(char ***);
#if __profile__ == 1
#include <profiler.h>
#endif
This is rare, but it is needed by the secureware extension. */
void
-Py_GetArgcArgv(argc,argv)
- int *argc;
- char ***argv;
+Py_GetArgcArgv(int *argc,char ***argv)
{
*argc = orig_argc;
*argv = orig_argv;
*
*/
+#include "Python.h"
+#include "macglue.h"
#include "macdefs.h"
int
-setfiletype(name, creator, type)
+PyMac_setfiletype(name, creator, type)
char *name;
long creator, type;
{
}
long
-getfiletype(name)
+PyMac_getfiletype(name)
char *name;
{
FInfo info;
#include <stdlib.h>
#include <string.h>
+#ifndef NULL
#define NULL 0
+#endif
static void morecore();