]> granicus.if.org Git - python/commitdiff
Merged revisions 78544 via svnmerge from
authorGregory P. Smith <greg@mad-scientist.com>
Mon, 1 Mar 2010 04:59:27 +0000 (04:59 +0000)
committerGregory P. Smith <greg@mad-scientist.com>
Mon, 1 Mar 2010 04:59:27 +0000 (04:59 +0000)
svn+ssh://pythondev@svn.python.org/python/trunk

........
  r78544 | gregory.p.smith | 2010-02-28 20:56:12 -0800 (Sun, 28 Feb 2010) | 2 lines

  Adds c_ssize_t to ctypes.  issue 6729.
........

Doc/library/ctypes.rst
Lib/ctypes/__init__.py
Lib/ctypes/test/test_sizes.py
Misc/NEWS

index 652a2f4d32431bdc4a2a53115df06e48fb851c7f..32499d5a3ee82b65a033f4f091b44437426f066a 100644 (file)
@@ -2207,6 +2207,13 @@ These are the fundamental ctypes data types:
    Represents the C :ctype:`size_t` datatype.
 
 
+.. class:: c_ssize_t
+
+   Represents the C :ctype:`ssize_t` datatype.
+
+   .. versionadded:: 3.2
+
+
 .. class:: c_ubyte
 
    Represents the C :ctype:`unsigned char` datatype, it interprets the value as
index 1283f28a6d0e22b88fdfa21e1ea80de3b5623d84..8782db9c16febe25e537b603980940b24bea0ee8 100644 (file)
@@ -459,10 +459,13 @@ _pointer_type_cache[None] = c_void_p
 
 if sizeof(c_uint) == sizeof(c_void_p):
     c_size_t = c_uint
+    c_ssize_t = c_int
 elif sizeof(c_ulong) == sizeof(c_void_p):
     c_size_t = c_ulong
+    c_ssize_t = c_long
 elif sizeof(c_ulonglong) == sizeof(c_void_p):
     c_size_t = c_ulonglong
+    c_ssize_t = c_longlong
 
 # functions
 
index 0509cbb68082f39b1c2d1faf2db9aa6b8f8c3e5c..f9b5e9726009e05146fe20390bb8d486fd649741 100644 (file)
@@ -1,8 +1,11 @@
 # Test specifically-sized containers.
 
-import unittest
 from ctypes import *
 
+import sys
+import unittest
+
+
 class SizesTestCase(unittest.TestCase):
     def test_8(self):
         self.assertEqual(1, sizeof(c_int8))
@@ -23,5 +26,9 @@ class SizesTestCase(unittest.TestCase):
     def test_size_t(self):
         self.assertEqual(sizeof(c_void_p), sizeof(c_size_t))
 
+    def test_ssize_t(self):
+        self.assertEqual(sizeof(c_void_p), sizeof(c_ssize_t))
+
+
 if __name__ == "__main__":
     unittest.main()
index c36aab3e95e121aab5addd562fe17e74456c41b1..c529e18041d9e21fc00e245e844c3132b80697a3 100644 (file)
--- a/Misc/NEWS
+++ b/Misc/NEWS
@@ -717,6 +717,8 @@ Library
 - Issue #1068268: The subprocess module now handles EINTR in internal
   os.waitpid and os.read system calls where appropriate.
 
+- Issue #6729: Added ctypes.c_ssize_t to represent ssize_t.
+
 Extension Modules
 -----------------