X Tutup
Skip to content

Commit d094130

Browse files
committed
Revert r56044 (which changed the %c format specifier to accept a
unicode char into an int variable) and add %C which does this.
1 parent 8934fc2 commit d094130

File tree

4 files changed

+21
-2
lines changed

4 files changed

+21
-2
lines changed

Modules/arraymodule.c

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1785,7 +1785,7 @@ array_new(PyTypeObject *type, PyObject *args, PyObject *kwds)
17851785
if (type == &Arraytype && !_PyArg_NoKeywords("array.array()", kwds))
17861786
return NULL;
17871787

1788-
if (!PyArg_ParseTuple(args, "c|O:array", &c, &initial))
1788+
if (!PyArg_ParseTuple(args, "C|O:array", &c, &initial))
17891789
return NULL;
17901790

17911791
if (!(initial == NULL || PyList_Check(initial)

Modules/datetimemodule.c

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -4033,7 +4033,7 @@ datetime_isoformat(PyDateTime_DateTime *self, PyObject *args, PyObject *kw)
40334033
PyObject *result;
40344034
int us = DATE_GET_MICROSECOND(self);
40354035

4036-
if (!PyArg_ParseTupleAndKeywords(args, kw, "|c:isoformat", keywords, &sep))
4036+
if (!PyArg_ParseTupleAndKeywords(args, kw, "|C:isoformat", keywords, &sep))
40374037
return NULL;
40384038
if (us)
40394039
result = PyUnicode_FromFormat("%04d-%02d-%02d%c%02d:%02d:%02d.%06d",

Python/getargs.c

Lines changed: 13 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -761,6 +761,19 @@ convertsimple(PyObject *arg, const char **p_format, va_list *p_va, int flags,
761761
#endif /* WITHOUT_COMPLEX */
762762

763763
case 'c': {/* char */
764+
char *p = va_arg(*p_va, char *);
765+
if (PyString_Check(arg) && PyString_Size(arg) == 1)
766+
*p = PyString_AS_STRING(arg)[0];
767+
else if (PyUnicode_Check(arg) &&
768+
PyUnicode_GET_SIZE(arg) == 1 &&
769+
PyUnicode_AS_UNICODE(arg)[0] < 256)
770+
*p = PyUnicode_AS_UNICODE(arg)[0];
771+
else
772+
return converterr("char < 256", arg, msgbuf, bufsize);
773+
break;
774+
}
775+
776+
case 'C': {/* unicode char */
764777
int *p = va_arg(*p_va, int *);
765778
if (PyString_Check(arg) && PyString_Size(arg) == 1)
766779
*p = PyString_AS_STRING(arg)[0];

Python/modsupport.c

Lines changed: 6 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -384,6 +384,12 @@ do_mkvalue(const char **p_format, va_list *p_va, int flags)
384384
#endif /* WITHOUT_COMPLEX */
385385

386386
case 'c':
387+
{
388+
char p[1];
389+
p[0] = (char)va_arg(*p_va, int);
390+
return PyString_FromStringAndSize(p, 1);
391+
}
392+
case 'C':
387393
{
388394
int i = va_arg(*p_va, int);
389395
Py_UNICODE c;

0 commit comments

Comments
 (0)
X Tutup