diff options
author | Guido van Rossum <guido@python.org> | 1998-09-18 14:14:13 (GMT) |
---|---|---|
committer | Guido van Rossum <guido@python.org> | 1998-09-18 14:14:13 (GMT) |
commit | 78694d970fbdc70cfbda5b21a556f6e11f684fb0 (patch) | |
tree | d71e26b1713a75e19efb6520c3f5499e4025fa66 /Objects | |
parent | 43b655c0abe49fc5fd08c2a4c5a763cdaa8afb11 (diff) | |
download | cpython-78694d970fbdc70cfbda5b21a556f6e11f684fb0.zip cpython-78694d970fbdc70cfbda5b21a556f6e11f684fb0.tar.gz cpython-78694d970fbdc70cfbda5b21a556f6e11f684fb0.tar.bz2 |
Patches from Greg Stein to support 'P' format in struct module's
native format, as void* (translated to Python int or long).
Also adds PyLong_FromVoidPtr and PyLong_AsVoidPtr to longobject.c.
Diffstat (limited to 'Objects')
-rw-r--r-- | Objects/longobject.c | 55 |
1 files changed, 55 insertions, 0 deletions
diff --git a/Objects/longobject.c b/Objects/longobject.c index 5a09255..7dbb542 100644 --- a/Objects/longobject.c +++ b/Objects/longobject.c @@ -277,6 +277,61 @@ PyLong_AsDouble(vv) return x * sign; } +/* Create a new long (or int) object from a C pointer */ + +PyObject * +PyLong_FromVoidPtr(p) + void *p; +{ +#if SIZEOF_VOID_P == SIZEOF_LONG + return PyInt_FromLong((long)p); +#else + /* optimize null pointers */ + if ( p == NULL ) + return PyInt_FromLong(0); + + /* we can assume that HAVE_LONG_LONG is true. if not, then the + configuration process should have bailed (having big pointers + without long longs seems non-sensical) */ + return PyLong_FromLongLong((LONG_LONG)p); +#endif /* SIZEOF_VOID_P == SIZEOF_LONG */ +} + +/* Get a C pointer from a long object (or an int object in some cases) */ + +void * +PyLong_AsVoidPtr(vv) + PyObject *vv; +{ + /* This function will allow int or long objects. If vv is neither, + then the PyLong_AsLong*() functions will raise the exception: + PyExc_SystemError, "bad argument to internal function" + */ + +#if SIZEOF_VOID_P == SIZEOF_LONG + long x; + + if ( PyInt_Check(vv) ) + x = PyInt_AS_LONG(vv); + else + x = PyLong_AsLong(vv); +#else + /* we can assume that HAVE_LONG_LONG is true. if not, then the + configuration process should have bailed (having big pointers + without long longs seems non-sensical) */ + LONG_LONG x; + + if ( PyInt_Check(vv) ) + x = PyInt_AS_LONG(vv); + else + x = PyLong_AsLongLong(vv); +#endif /* SIZEOF_VOID_P == SIZEOF_LONG */ + + if (x == -1 && PyErr_Occurred()) + return NULL; + return (void *)x; +} + #ifdef HAVE_LONG_LONG /* * LONG_LONG support by Chris Herborth (chrish@qnx.com) |