summaryrefslogtreecommitdiffstats
path: root/Mac/Python
diff options
context:
space:
mode:
authorJack Jansen <jack.jansen@cwi.nl>1995-01-18 13:53:49 (GMT)
committerJack Jansen <jack.jansen@cwi.nl>1995-01-18 13:53:49 (GMT)
commit5f653091d1c5a453b8a0c71b304c600c0f3f52b0 (patch)
treeb8f0cbf2b6633cbc04b22a056135a42501c4d268 /Mac/Python
parent9589e93491544e4f2775e7928734851703edeaa1 (diff)
downloadcpython-5f653091d1c5a453b8a0c71b304c600c0f3f52b0.zip
cpython-5f653091d1c5a453b8a0c71b304c600c0f3f52b0.tar.gz
cpython-5f653091d1c5a453b8a0c71b304c600c0f3f52b0.tar.bz2
- Moved some useful routines from macosmodule.c here
- Added GetFSSpec (tuple-style), BuildFSSpec and Pstring (platform-independent correct conversion of C to Pascal strings)
Diffstat (limited to 'Mac/Python')
-rw-r--r--Mac/Python/macglue.c98
1 files changed, 93 insertions, 5 deletions
diff --git a/Mac/Python/macglue.c b/Mac/Python/macglue.c
index 353c850..76e96a8 100644
--- a/Mac/Python/macglue.c
+++ b/Mac/Python/macglue.c
@@ -2,8 +2,9 @@
** macglue - A couple of mac-specific routines often needed.
**
** Jack Jansen, CWI, 1994.
+** Some routines by Guido, moved here from macosmodule.c
+** (since they are useable by other modules as well).
*/
-
#ifdef HAVE_CONFIG_H
#include "config.h"
#endif
@@ -18,6 +19,23 @@
#include <Windows.h>
#include <Desk.h>
+/* We should include Errors.h here, but it has a name conflict
+** with the python errors.h. */
+#define fnfErr -43
+
+/* Convert C to Pascal string. Returns pointer to static buffer. */
+unsigned char *
+Pstring(char *str)
+{
+ static Str255 buf;
+ int len;
+
+ len = strlen(str);
+ buf[0] = (unsigned char)len;
+ strncpy((char *)buf+1, str, len);
+ return buf;
+}
+
/* Replace strerror with something that might work */
char *macstrerror(int err)
{
@@ -44,7 +62,6 @@ PyErr_Mac(PyObject *eobj, int err)
{
char *msg;
PyObject *v;
- Handle h;
if (err == 0) {
Py_INCREF(Py_None);
@@ -70,9 +87,8 @@ PyMac_Idle()
EventRecord ev;
WindowPtr wp;
-#if 0
SystemTask();
- if ( intrcheck() )
+ if ( intrpeek() )
return 0;
if ( GetNextEvent(0xffff, &ev) ) {
if ( ev.what == mouseDown ) {
@@ -80,7 +96,79 @@ PyMac_Idle()
SystemClick(&ev, wp);
}
}
-#endif
return 1;
}
+
+/* Convert a ResType argument */
+int
+GetOSType(PyObject *v, ResType *pr)
+{
+ if (!PyString_Check(v) || PyString_Size(v) != 4) {
+ PyErr_SetString(PyExc_TypeError,
+ "OSType arg must be string of 4 chars");
+ return 0;
+ }
+ memcpy((char *)pr, PyString_AsString(v), 4);
+ return 1;
+}
+
+/* Convert a Str255 argument */
+int
+GetStr255(PyObject *v, Str255 pbuf)
+{
+ int len;
+ if (!PyString_Check(v) || (len = PyString_Size(v)) > 255) {
+ PyErr_SetString(PyExc_TypeError,
+ "Str255 arg must be string of at most 255 chars");
+ return 0;
+ }
+ pbuf[0] = len;
+ memcpy((char *)(pbuf+1), PyString_AsString(v), len);
+ return 1;
+}
+
+/*
+** Convert anything resembling an FSSpec argument
+** NOTE: This routine will fail on pre-sys7 machines.
+** The caller is responsible for not calling this routine
+** in those cases (which is fine, since everyone calling
+** this is probably sys7 dependent anyway).
+*/
+int
+GetFSSpec(PyObject *v, FSSpec *fs)
+{
+ Str255 path;
+ short refnum;
+ long parid;
+ OSErr err;
+
+ if ( PyString_Check(v) ) {
+ /* It's a pathname */
+ if( !PyArg_Parse(v, "O&", GetStr255, &path) )
+ return 0;
+ refnum = 0; /* XXXX Should get CurWD here... */
+ parid = 0;
+ } else {
+ PyErr_Clear();
+ if( !PyArg_Parse(v, "(hlO&); FSSpec should be fullpath or (int,int,string)",
+ &refnum, &parid, GetStr255, &path))
+ return 0;
+ }
+ err = FSMakeFSSpec(refnum, parid, path, fs);
+ if ( err && err != fnfErr ) {
+ PyErr_SetString(PyExc_TypeError,
+ "FSMakeFSSpec error");
+ return 0;
+ }
+ return 1;
+}
+
+/*
+** Return a python object that describes an FSSpec
+*/
+PyObject *
+PyMac_BuildFSSpec(FSSpec *fs)
+{
+ return Py_BuildValue("(iis#)", fs->vRefNum, fs->parID, &fs->name[1], fs->name[0]);
+}