diff options
author | Thomas Heller <theller@ctypes.org> | 2007-07-13 17:12:23 (GMT) |
---|---|---|
committer | Thomas Heller <theller@ctypes.org> | 2007-07-13 17:12:23 (GMT) |
commit | fa704c6adef703271844349bad94fbf7d09143d9 (patch) | |
tree | 89f2d504b9c3a9a5f852e3808a871ee1f2539b63 | |
parent | ad0cfe3dd7df3b58486e51ab881ddfe1d71d90ba (diff) | |
download | cpython-fa704c6adef703271844349bad94fbf7d09143d9.zip cpython-fa704c6adef703271844349bad94fbf7d09143d9.tar.gz cpython-fa704c6adef703271844349bad94fbf7d09143d9.tar.bz2 |
Fix for SF# 1701409: segfault in c_char_p of ctypes. The repr output
of c_char_p and c_wchar_p has changed as a sideeffect.
-rw-r--r-- | Lib/ctypes/__init__.py | 8 | ||||
-rw-r--r-- | Misc/NEWS | 4 |
2 files changed, 12 insertions, 0 deletions
diff --git a/Lib/ctypes/__init__.py b/Lib/ctypes/__init__.py index f8b2d75..7dff3a7 100644 --- a/Lib/ctypes/__init__.py +++ b/Lib/ctypes/__init__.py @@ -226,6 +226,14 @@ _check_size(c_char) class c_char_p(_SimpleCData): _type_ = "z" + if _os.name == "nt": + def __repr__(self): + if not windll.kernel32.IsBadStringPtrA(self, -1): + return "%s(%r)" % (self.__class__.__name__, self.value) + return "%s(%s)" % (self.__class__.__name__, cast(self, c_void_p).value) + else: + def __repr__(self): + return "%s(%s)" % (self.__class__.__name__, cast(self, c_void_p).value) _check_size(c_char_p, "P") class c_void_p(_SimpleCData): @@ -234,6 +234,10 @@ Core and builtins Library ------- +- Bug #1701409: Fix a segfault in printing ctypes.c_char_p and + ctypes.c_wchar_p when they point to an invalid location. As a + sideeffect the representation of these instances has changed. + - tarfile.py: Added "exclude" keyword argument to TarFile.add(). - Bug #1734723: Fix repr.Repr() so it doesn't ignore the maxtuple attribute. |