]> granicus.if.org Git - python/commitdiff
Fix the array tests. Only a minor change to the C code was required.
authorGuido van Rossum <guido@python.org>
Thu, 10 May 2007 18:41:30 +0000 (18:41 +0000)
committerGuido van Rossum <guido@python.org>
Thu, 10 May 2007 18:41:30 +0000 (18:41 +0000)
Lib/test/test_array.py
Modules/arraymodule.c

index 3f8df52cdfa3b78b1c55dd47a32bbe41336e8e1d..937aa7e400afa2dc94eab90e53608bcd0fc5e712 100755 (executable)
@@ -755,32 +755,28 @@ tests.append(CharacterTest)
 if test_support.have_unicode:
     class UnicodeTest(StringTest):
         typecode = 'u'
-        example = str(r'\x01\u263a\x00\ufeff', 'unicode-escape')
-        smallerexample = str(r'\x01\u263a\x00\ufefe', 'unicode-escape')
-        biggerexample = str(r'\x01\u263a\x01\ufeff', 'unicode-escape')
+        example = '\x01\u263a\x00\ufeff'
+        smallerexample = '\x01\u263a\x00\ufefe'
+        biggerexample = '\x01\u263a\x01\ufeff'
         outside = str('\x33')
         minitemsize = 2
 
         def test_unicode(self):
-            self.assertRaises(TypeError, array.array, 'b', str('foo', 'ascii'))
+            self.assertRaises(TypeError, array.array, 'b', 'foo')
 
-            a = array.array('u', str(r'\xa0\xc2\u1234', 'unicode-escape'))
-            a.fromunicode(str(' ', 'ascii'))
-            a.fromunicode(str('', 'ascii'))
-            a.fromunicode(str('', 'ascii'))
-            a.fromunicode(str(r'\x11abc\xff\u1234', 'unicode-escape'))
+            a = array.array('u', '\xa0\xc2\u1234')
+            a.fromunicode(' ')
+            a.fromunicode('')
+            a.fromunicode('')
+            a.fromunicode('\x11abc\xff\u1234')
             s = a.tounicode()
-            self.assertEqual(
-                s,
-                str(r'\xa0\xc2\u1234 \x11abc\xff\u1234', 'unicode-escape')
-            )
+            self.assertEqual(s, '\xa0\xc2\u1234 \x11abc\xff\u1234')
 
-            s = str(r'\x00="\'a\\b\x80\xff\u0000\u0001\u1234', 'unicode-escape')
+            s = '\x00="\'a\\b\x80\xff\u0000\u0001\u1234'
             a = array.array('u', s)
             self.assertEqual(
                 repr(a),
-                r"""array('u', u'\x00="\'a\\b\x80\xff\x00\x01\u1234')"""
-            )
+                "array('u', '\\x00=\"\\'a\\\\b\\x80\\xff\\x00\\x01\\u1234')")
 
             self.assertRaises(TypeError, a.fromunicode)
 
index c6de243264e46aedd0b95de6d216d67327cda9c9..a5fd5038a9c19e6b52c50db90d643b616891a907 100644 (file)
@@ -104,7 +104,9 @@ in bounds; that's the responsibility of the caller.
 static PyObject *
 c_getitem(arrayobject *ap, Py_ssize_t i)
 {
-       return PyString_FromStringAndSize(&((char *)ap->ob_item)[i], 1);
+       Py_UNICODE buf[1];
+       buf[0] = ((unsigned char *)ap->ob_item)[i];
+       return PyUnicode_FromUnicode(buf, 1);
 }
 
 static int