]> granicus.if.org Git - python/commitdiff
add the gestalt module back as _gestalt
authorBenjamin Peterson <benjamin@python.org>
Thu, 29 May 2008 21:09:51 +0000 (21:09 +0000)
committerBenjamin Peterson <benjamin@python.org>
Thu, 29 May 2008 21:09:51 +0000 (21:09 +0000)
Lib/platform.py
Modules/_gestalt.c [new file with mode: 0644]
setup.py

index 415d83f8dde66b1e47c6c8cb9559c86607b2946e..2a69fd60e8badb6965dcec404d14c7b521a4a465 100755 (executable)
@@ -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 (file)
index 0000000..d106068
--- /dev/null
@@ -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);
+}
index 639b42f1f1c02f0408a8f17b86b98989a33f01c0..4921ded784086e0225a393d7863891e70fa054e5 100644 (file)
--- a/setup.py
+++ b/setup.py
@@ -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