msg160805 - (view) |
Author: Jasper St. Pierre (magcius) |
Date: 2012-05-16 05:52 |
http://docs.python.org/dev/library/reprlib.html """ Formatting methods for specific types are implemented as methods with a name based on the type name. In the method name, TYPE is replaced by string.join(string.split(type(obj).__name__, '_')). Dispatch to these methods is handled by repr1(). Type-specific methods which need to recursively format a value should call self.repr1(subobj, level - 1). """ Outstanding. |
|
|
msg160810 - (view) |
Author: Chris Rebert (cvrebert) * |
Date: 2012-05-16 08:07 |
Patch. Though I ponder whether the expression in question might be equivalent to simply: type(obj).__name__.replace('_', ' ') |
|
|
msg160867 - (view) |
Author: Jasper St. Pierre (magcius) |
Date: 2012-05-16 14:18 |
Yes. Yes it would. In my opinion, it really shouldn't do this sort of name mangling, as it's a terrible idea, but whatever. |
|
|
msg161083 - (view) |
Author: Jasper St. Pierre (magcius) |
Date: 2012-05-18 20:38 |
The documentation is just flat out wrong, actually: if ' ' in typename: parts = typename.split() typename = '_'.join(parts) The documentation is claiming the inverse. I don't know why we would ever have a space in a typename, ever (and if someone does awful hacks to get to that state, he should probably also do awful hacks to make reprlib work properly). It would be for the best if we could just remove this brain damage, but whatever. |
|
|
msg169181 - (view) |
Author: Chris Rebert (cvrebert) * |
Date: 2012-08-27 05:59 |
Updated patch. I concur that anyone creating a type whose name has whitespace in it is just asking for trouble. |
|
|
msg227025 - (view) |
Author: Roundup Robot (python-dev)  |
Date: 2014-09-18 03:04 |
New changeset e9968782c9ba by Berker Peksag in branch '3.4': Issue #14824: Update Repr.repr_TYPE documentation to use correct name mangling implementation. https://hg.python.org/cpython/rev/e9968782c9ba New changeset a0372781eafb by Berker Peksag in branch 'default': Issue #14824: Update Repr.repr_TYPE documentation to use correct name mangling implementation. https://hg.python.org/cpython/rev/a0372781eafb |
|
|
msg227026 - (view) |
Author: Berker Peksag (berker.peksag) *  |
Date: 2014-09-18 03:08 |
> I don't know why we would ever have a space in a typename, ever (and if someone does awful hacks to get to that state, he should probably also do awful hacks to make reprlib work properly). That part of the code has been added 22 years ago: https://hg.python.org/cpython/rev/a0d4c5ef1d5d#l9.22 So probably the reason is that the code is just old. Thanks for the patch, Chris! |
|
|