Unverified Kaydet (Commit) 3ffa8b9b authored tarafından Serhiy Storchaka's avatar Serhiy Storchaka Kaydeden (comit) GitHub

bpo-35384: The repr of ctypes.CArgObject no longer fails for non-ascii character. (GH-10863)

üst 9dfc754d
...@@ -12,6 +12,7 @@ class BytesTest(unittest.TestCase): ...@@ -12,6 +12,7 @@ class BytesTest(unittest.TestCase):
x.value = "y" x.value = "y"
c_char.from_param(b"x") c_char.from_param(b"x")
self.assertRaises(TypeError, c_char.from_param, "x") self.assertRaises(TypeError, c_char.from_param, "x")
self.assertIn('xbd', repr(c_char.from_param(b"\xbd")))
(c_char * 3)(b"a", b"b", b"c") (c_char * 3)(b"a", b"b", b"c")
self.assertRaises(TypeError, c_char * 3, "a", "b", "c") self.assertRaises(TypeError, c_char * 3, "a", "b", "c")
......
...@@ -455,6 +455,12 @@ PyCArg_dealloc(PyCArgObject *self) ...@@ -455,6 +455,12 @@ PyCArg_dealloc(PyCArgObject *self)
PyObject_Del(self); PyObject_Del(self);
} }
static int
is_literal_char(unsigned char c)
{
return c < 128 && _PyUnicode_IsPrintable(c) && c != '\\' && c != '\'';
}
static PyObject * static PyObject *
PyCArg_repr(PyCArgObject *self) PyCArg_repr(PyCArgObject *self)
{ {
...@@ -501,8 +507,14 @@ PyCArg_repr(PyCArgObject *self) ...@@ -501,8 +507,14 @@ PyCArg_repr(PyCArgObject *self)
break; break;
case 'c': case 'c':
sprintf(buffer, "<cparam '%c' (%c)>", if (is_literal_char((unsigned char)self->value.c)) {
self->tag, self->value.c); sprintf(buffer, "<cparam '%c' ('%c')>",
self->tag, self->value.c);
}
else {
sprintf(buffer, "<cparam '%c' ('\\x%02x')>",
self->tag, (unsigned char)self->value.c);
}
break; break;
/* Hm, are these 'z' and 'Z' codes useful at all? /* Hm, are these 'z' and 'Z' codes useful at all?
...@@ -517,8 +529,14 @@ PyCArg_repr(PyCArgObject *self) ...@@ -517,8 +529,14 @@ PyCArg_repr(PyCArgObject *self)
break; break;
default: default:
sprintf(buffer, "<cparam '%c' at %p>", if (is_literal_char((unsigned char)self->tag)) {
self->tag, self); sprintf(buffer, "<cparam '%c' at %p>",
(unsigned char)self->tag, self);
}
else {
sprintf(buffer, "<cparam 0x%02x at %p>",
(unsigned char)self->tag, self);
}
break; break;
} }
return PyUnicode_FromString(buffer); return PyUnicode_FromString(buffer);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment