diff options
author | Walter Dörwald <walter@livinglogic.de> | 2007-05-19 21:49:49 (GMT) |
---|---|---|
committer | Walter Dörwald <walter@livinglogic.de> | 2007-05-19 21:49:49 (GMT) |
commit | 7569dfe11d51a11bfb11002d31245b889916fb11 (patch) | |
tree | 7e4cbbb7a27a366ea0cdc8eeacc05a23f649e4cd /Modules/arraymodule.c | |
parent | 94b59bb14474b6fe5a272a2c60b65f8375e827b3 (diff) | |
download | cpython-7569dfe11d51a11bfb11002d31245b889916fb11.zip cpython-7569dfe11d51a11bfb11002d31245b889916fb11.tar.gz cpython-7569dfe11d51a11bfb11002d31245b889916fb11.tar.bz2 |
Add a format specifier %R to PyUnicode_FromFormat(), which embeds
the result of a call to PyObject_Repr() into the string. This makes
it possible to simplify many repr implementations.
PyUnicode_FromFormat() uses two steps to create the final string: A first
pass through the format string determines the size of the final string and
a second pass creates the string. To avoid calling PyObject_Repr() twice
for each %R specifier, PyObject_Repr() is called during the size
calculation step and the results are stored in an array (whose size is
determined at the start by counting %R specifiers).
Diffstat (limited to 'Modules/arraymodule.c')
-rw-r--r-- | Modules/arraymodule.c | 14 |
1 files changed, 4 insertions, 10 deletions
diff --git a/Modules/arraymodule.c b/Modules/arraymodule.c index d61b1ae..7349527 100644 --- a/Modules/arraymodule.c +++ b/Modules/arraymodule.c @@ -1567,29 +1567,23 @@ static PyObject * array_repr(arrayobject *a) { char buf[256], typecode; - PyObject *s, *t, *v = NULL; + PyObject *s, *v = NULL; Py_ssize_t len; len = a->ob_size; typecode = a->ob_descr->typecode; if (len == 0) { - PyOS_snprintf(buf, sizeof(buf), "array('%c')", typecode); - return PyUnicode_FromString(buf); + return PyUnicode_FromFormat("array('%c')", typecode); } - if (typecode == 'c') v = array_tostring(a, NULL); else if (typecode == 'u') v = array_tounicode(a, NULL); else v = array_tolist(a, NULL); - t = PyObject_Repr(v); - Py_XDECREF(v); - PyOS_snprintf(buf, sizeof(buf), "array('%c', ", typecode); - s = PyUnicode_FromString(buf); - PyUnicode_AppendAndDel(&s, t); - PyUnicode_AppendAndDel(&s, PyUnicode_FromString(")")); + s = PyUnicode_FromFormat("array('%c', %R)", typecode, v); + Py_DECREF(v); return s; } |