summaryrefslogtreecommitdiffstats
path: root/Objects/stringobject.c
diff options
context:
space:
mode:
authorMarc-André Lemburg <mal@egenix.com>2001-05-02 14:21:53 (GMT)
committerMarc-André Lemburg <mal@egenix.com>2001-05-02 14:21:53 (GMT)
commit542fe56cb9ed36bd8af8bd5cbfba9cdc7f3514f0 (patch)
treef922b0ff8a38e28912bd5c962ada6c4e8e2e636a /Objects/stringobject.c
parent0e57abf0cdc7cd3f8cca518ded422d782587740c (diff)
downloadcpython-542fe56cb9ed36bd8af8bd5cbfba9cdc7f3514f0.zip
cpython-542fe56cb9ed36bd8af8bd5cbfba9cdc7f3514f0.tar.gz
cpython-542fe56cb9ed36bd8af8bd5cbfba9cdc7f3514f0.tar.bz2
Fix for bug #417030: "print '%*s' fails for unicode string"
Diffstat (limited to 'Objects/stringobject.c')
-rw-r--r--Objects/stringobject.c5
1 files changed, 3 insertions, 2 deletions
diff --git a/Objects/stringobject.c b/Objects/stringobject.c
index bf5056e..b905679 100644
--- a/Objects/stringobject.c
+++ b/Objects/stringobject.c
@@ -2781,6 +2781,7 @@ PyString_Format(PyObject *format, PyObject *args)
int len;
char formatbuf[FORMATBUFLEN]; /* For format{float,int,char}() */
char *fmt_start = fmt;
+ int argidx_start = argidx;
fmt++;
if (*fmt == '(') {
@@ -2934,6 +2935,7 @@ PyString_Format(PyObject *format, PyObject *args)
case 'r':
if (PyUnicode_Check(v)) {
fmt = fmt_start;
+ argidx = argidx_start;
goto unicode;
}
if (c == 's')
@@ -3098,8 +3100,7 @@ PyString_Format(PyObject *format, PyObject *args)
Py_DECREF(args);
args_owned = 0;
}
- /* Fiddle args right (remove the first argidx-1 arguments) */
- --argidx;
+ /* Fiddle args right (remove the first argidx arguments) */
if (PyTuple_Check(orig_args) && argidx > 0) {
PyObject *v;
int n = PyTuple_GET_SIZE(orig_args) - argidx;