diff options
author | Benjamin Peterson <benjamin@python.org> | 2008-05-29 21:09:51 (GMT) |
---|---|---|
committer | Benjamin Peterson <benjamin@python.org> | 2008-05-29 21:09:51 (GMT) |
commit | ebacd26869220b2f300d1b88c59ec3efc60ac00d (patch) | |
tree | 9a1f9a3850fb50f9971fceb633d254e0c8230d1e | |
parent | 7dca3ebc97661da9fe2945b9c65d58c234d10629 (diff) | |
download | cpython-ebacd26869220b2f300d1b88c59ec3efc60ac00d.zip cpython-ebacd26869220b2f300d1b88c59ec3efc60ac00d.tar.gz cpython-ebacd26869220b2f300d1b88c59ec3efc60ac00d.tar.bz2 |
add the gestalt module back as _gestalt
-rwxr-xr-x | Lib/platform.py | 8 | ||||
-rw-r--r-- | Modules/_gestalt.c | 72 | ||||
-rw-r--r-- | setup.py | 8 |
3 files changed, 83 insertions, 5 deletions
diff --git a/Lib/platform.py b/Lib/platform.py index 415d83f..2a69fd6 100755 --- a/Lib/platform.py +++ b/Lib/platform.py @@ -676,14 +676,13 @@ def win32_ver(release='',version='',csd='',ptype=''): def _mac_ver_lookup(selectors,default=None): - from gestalt import gestalt - import MacOS + from _gestalt import gestalt l = [] append = l.append for selector in selectors: try: append(gestalt(selector)) - except (RuntimeError, MacOS.Error): + except (RuntimeError, OSError): append(default) return l @@ -709,8 +708,7 @@ def mac_ver(release='',versioninfo=('','',''),machine=''): """ # Check whether the version info module is available try: - import gestalt - import MacOS + import _gestalt except ImportError: return release,versioninfo,machine # Get the infos diff --git a/Modules/_gestalt.c b/Modules/_gestalt.c new file mode 100644 index 0000000..d106068 --- /dev/null +++ b/Modules/_gestalt.c @@ -0,0 +1,72 @@ +/*********************************************************** +Copyright 1991-1997 by Stichting Mathematisch Centrum, Amsterdam, +The Netherlands. + + All Rights Reserved + +Permission to use, copy, modify, and distribute this software and its +documentation for any purpose and without fee is hereby granted, +provided that the above copyright notice appear in all copies and that +both that copyright notice and this permission notice appear in +supporting documentation, and that the names of Stichting Mathematisch +Centrum or CWI not be used in advertising or publicity pertaining to +distribution of the software without specific, written prior permission. + +STICHTING MATHEMATISCH CENTRUM DISCLAIMS ALL WARRANTIES WITH REGARD TO +THIS SOFTWARE, INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND +FITNESS, IN NO EVENT SHALL STICHTING MATHEMATISCH CENTRUM BE LIABLE +FOR ANY SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES +WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN +ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT +OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. + +******************************************************************/ + +/* Macintosh Gestalt interface */ + +#include "Python.h" + +#include <Carbon/Carbon.h> + +/* Convert a 4-char string object argument to an OSType value */ +static int +convert_to_OSType(PyObject *v, OSType *pr) +{ + uint32_t tmp; + if (!PyUnicode_Check(v) || PyUnicode_GetSize(v) != 4) { + PyErr_SetString(PyExc_TypeError, + "OSType arg must be string of 4 chars"); + return 0; + } + memcpy((char *)&tmp, PyUnicode_AsString(v), 4); + *pr = (OSType)ntohl(tmp); + return 1; +} + +static PyObject * +gestalt_gestalt(PyObject *self, PyObject *args) +{ + OSErr iErr; + OSType selector; + SInt32 response; + if (!PyArg_ParseTuple(args, "O&", convert_to_OSType, &selector)) + return NULL; + iErr = Gestalt(selector, &response); + if (iErr != 0) { + PyErr_SetString(PyExc_OSError, + "non-zero exit code!"); + return NULL; + } + return PyLong_FromLong(response); +} + +static struct PyMethodDef gestalt_methods[] = { + {"gestalt", gestalt_gestalt, METH_VARARGS}, + {NULL, NULL} /* Sentinel */ +}; + +void +init_gestalt(void) +{ + Py_InitModule("_gestalt", gestalt_methods); +} @@ -1118,6 +1118,14 @@ class PyBuildExt(build_ext): else: missing.append('ossaudiodev') + if sys.platform == 'darwin': + exts.append( + Extension('_gestalt', ['_gestalt.c'], + extra_link_args=['-framework', 'Carbon']) + ) + else: + missing.append('_gestalt') + self.extensions.extend(exts) # Call the method for detecting whether _tkinter can be compiled |