diff options
author | Thomas Heller <theller@ctypes.org> | 2008-08-19 19:49:49 +0000 |
---|---|---|
committer | Thomas Heller <theller@ctypes.org> | 2008-08-19 19:49:49 +0000 |
commit | dca7aa3ab9141a8c9b49163d5790e8184ddcc5e8 (patch) | |
tree | f161f3c50a5c31a7be047e6e508ef1d32c5c88a6 /Modules | |
parent | 336284ba3d04bdb2f4887864cbc5b50cfcbb6e3a (diff) | |
download | cpython-dca7aa3ab9141a8c9b49163d5790e8184ddcc5e8.tar.gz |
Merged revisions 65868,65870 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r65868 | thomas.heller | 2008-08-19 21:25:04 +0200 (Di, 19 Aug 2008) | 3 lines
Fix a regression introduced by rev. 63792: ctypes function pointers
that are COM methods must have a boolean True value.
........
r65870 | thomas.heller | 2008-08-19 21:40:23 +0200 (Di, 19 Aug 2008) | 1 line
COM method code is windows specific
........
Diffstat (limited to 'Modules')
-rw-r--r-- | Modules/_ctypes/_ctypes.c | 33 |
1 files changed, 28 insertions, 5 deletions
diff --git a/Modules/_ctypes/_ctypes.c b/Modules/_ctypes/_ctypes.c index 7ef3ea1df0..11a725dc97 100644 --- a/Modules/_ctypes/_ctypes.c +++ b/Modules/_ctypes/_ctypes.c @@ -3858,12 +3858,16 @@ CFuncPtr_repr(CFuncPtrObject *self) } static int -Pointer_bool(CDataObject *self) +CFuncPtr_bool(CFuncPtrObject *self) { - return *(void **)self->b_ptr != NULL; + return ((*(void **)self->b_ptr != NULL) +#ifdef MS_WIN32 + || (self->index != 0) +#endif + ); } -static PyNumberMethods Pointer_as_number = { +static PyNumberMethods CFuncPtr_as_number = { 0, /* nb_add */ 0, /* nb_subtract */ 0, /* nb_multiply */ @@ -3873,7 +3877,7 @@ static PyNumberMethods Pointer_as_number = { 0, /* nb_negative */ 0, /* nb_positive */ 0, /* nb_absolute */ - (inquiry)Pointer_bool, /* nb_bool */ + (inquiry)CFuncPtr_bool, /* nb_bool */ }; PyTypeObject CFuncPtr_Type = { @@ -3887,7 +3891,7 @@ PyTypeObject CFuncPtr_Type = { 0, /* tp_setattr */ 0, /* tp_compare */ (reprfunc)CFuncPtr_repr, /* tp_repr */ - &Pointer_as_number, /* tp_as_number */ + &CFuncPtr_as_number, /* tp_as_number */ 0, /* tp_as_sequence */ 0, /* tp_as_mapping */ 0, /* tp_hash */ @@ -4960,6 +4964,25 @@ static PyMappingMethods Pointer_as_mapping = { Pointer_subscript, }; +static int +Pointer_bool(CDataObject *self) +{ + return (*(void **)self->b_ptr != NULL); +} + +static PyNumberMethods Pointer_as_number = { + 0, /* nb_add */ + 0, /* nb_subtract */ + 0, /* nb_multiply */ + 0, /* nb_remainder */ + 0, /* nb_divmod */ + 0, /* nb_power */ + 0, /* nb_negative */ + 0, /* nb_positive */ + 0, /* nb_absolute */ + (inquiry)Pointer_bool, /* nb_bool */ +}; + PyTypeObject Pointer_Type = { PyVarObject_HEAD_INIT(NULL, 0) "_ctypes._Pointer", |