homepage

This issue tracker has been migrated to GitHub , and is currently read-only.
For more information, see the GitHub FAQs in the Python's Developer Guide.

Author vstinner
Recipients eric.smith, serhiy.storchaka, vstinner
Date 2018年09月09日.07:53:53
SpamBayes Score -1.0
Marked as misclassified Yes
Message-id <1536479633.66.0.56676864532.issue34595@psf.upfronthosting.co.za>
In-reply-to
Content
> I think we need to handle only two cases: short and fully qualified names. __qualname__ without __module__ doesn't make sense, and the value of tp_name depends on implementation details (is it Python class or builtin class, heap class or dynamic class?). Maybe use %t and %T?
Ok, I wrote PR 9122 to add %t format and modify %T format:
* %t <=> type(obj).__name__
* %T <=> f"{type(obj).__module__}.{type(obj).__qualname__}"
> But we may want to support formatting the name of the type itself and the name of the object's type. This give us 4 variants.
Again, I'm not sure about these ones. _PyType_Name() can be used for %t-like directly on a type. Later we can expose _PyType_FullName() (function that I added in my latest PR) as a private function for %T-like directly on a type.
> For old string formatting we can introduce new % codes (with possible modifiers). But in modern string formatting "T" can have meaning for some types (e.g. for datetime). We can implement __format__ for the type type itself (though it can cause confusion if cls.__format__() is different from cls.__format__(instance)), but for formatting the name of the object's type (as in your original proposition) we need to add a new conversion flag like "!r".
I'm not sure that I understood directly.
Do you want to add a third formatter in PyUnicode_FromFormat() which would use Py_TYPE(obj)->tp_name? I dislike Py_TYPE(obj)->tp_name, since my intent is to conform to the PEP 399: tp_name is not accessible at the Python level, only type(obj).__name__ and type(obj).__qualname__.
Or do you want to add a new formatter to type.__format__() to expose %T at the Python level, f"{type(obj).__module__}.{type(obj).__qualname__}"?
Currently, type(obj).__name__ is the most popular way to format a string. Would it break the backward compatibility to modify *existing* error messages?
History
Date User Action Args
2018年09月09日 07:53:53vstinnersetrecipients: + vstinner, eric.smith, serhiy.storchaka
2018年09月09日 07:53:53vstinnersetmessageid: <1536479633.66.0.56676864532.issue34595@psf.upfronthosting.co.za>
2018年09月09日 07:53:53vstinnerlinkissue34595 messages
2018年09月09日 07:53:53vstinnercreate

AltStyle によって変換されたページ (->オリジナル) /