diff options
author | Eric Smith <eric@trueblade.com> | 2009-02-20 14:02:36 (GMT) |
---|---|---|
committer | Eric Smith <eric@trueblade.com> | 2009-02-20 14:02:36 (GMT) |
commit | e9fb6863da50d843ad3e26f81b807320be385adc (patch) | |
tree | 36e0ed3f15f098cae600d29f7d54d9ec259ebda7 | |
parent | 8b8c2df9b176acc9162a9c6e730f7de15b48e4b3 (diff) | |
download | cpython-e9fb6863da50d843ad3e26f81b807320be385adc.zip cpython-e9fb6863da50d843ad3e26f81b807320be385adc.tar.gz cpython-e9fb6863da50d843ad3e26f81b807320be385adc.tar.bz2 |
Issue #5247: Improve error message when unknown format codes are used when using str.format() with str, unicode, long, int, and float arguments.
-rw-r--r-- | Misc/NEWS | 4 | ||||
-rw-r--r-- | Objects/stringlib/formatter.h | 48 |
2 files changed, 35 insertions, 17 deletions
@@ -12,6 +12,10 @@ What's New in Python 2.7 alpha 1 Core and Builtins ----------------- +- Issue #5247: Improve error message when unknown format codes are + used when using str.format() with str, unicode, long, int, and + float arguments. + - Running Python with the -3 option now also warns about classic division for ints and longs. diff --git a/Objects/stringlib/formatter.h b/Objects/stringlib/formatter.h index aa99123..2e3e5a6 100644 --- a/Objects/stringlib/formatter.h +++ b/Objects/stringlib/formatter.h @@ -15,6 +15,34 @@ #define ALLOW_PARENS_FOR_SIGN 0 +/* Raises an exception about an unknown presentation type for this + * type. */ + +static void +unknown_presentation_type(STRINGLIB_CHAR presentation_type, + const char* type_name) +{ +#if STRINGLIB_IS_UNICODE + /* If STRINGLIB_CHAR is Py_UNICODE, %c might be out-of-range, + hence the two cases. If it is char, gcc complains that the + condition below is always true, hence the ifdef. */ + if (presentation_type > 32 && presentation_type < 128) +#endif + PyErr_Format(PyExc_ValueError, + "Unknown format code '%c' " + "for object of type '%.200s'", + presentation_type, + type_name); +#if STRINGLIB_IS_UNICODE + else + PyErr_Format(PyExc_ValueError, + "Unknown format code '\\x%x' " + "for object of type '%.200s'", + (unsigned int)presentation_type, + type_name); +#endif +} + /* get_integer consumes 0 or more decimal digit characters from an input string, updates *result with the corresponding positive @@ -854,19 +882,7 @@ FORMAT_STRING(PyObject *obj, break; default: /* unknown */ - #if STRINGLIB_IS_UNICODE - /* If STRINGLIB_CHAR is Py_UNICODE, %c might be out-of-range, - hence the two cases. If it is char, gcc complains that the - condition below is always true, hence the ifdef. */ - if (format.type > 32 && format.type <128) - #endif - PyErr_Format(PyExc_ValueError, "Unknown conversion type %c", - (char)format.type); - #if STRINGLIB_IS_UNICODE - else - PyErr_Format(PyExc_ValueError, "Unknown conversion type '\\x%x'", - (unsigned int)format.type); - #endif + unknown_presentation_type(format.type, obj->ob_type->tp_name); goto done; } @@ -928,8 +944,7 @@ format_int_or_long(PyObject* obj, default: /* unknown */ - PyErr_Format(PyExc_ValueError, "Unknown conversion type %c", - format.type); + unknown_presentation_type(format.type, obj->ob_type->tp_name); goto done; } @@ -1031,8 +1046,7 @@ FORMAT_FLOAT(PyObject *obj, default: /* unknown */ - PyErr_Format(PyExc_ValueError, "Unknown conversion type %c", - format.type); + unknown_presentation_type(format.type, obj->ob_type->tp_name); goto done; } |