STINNER Victor <vstin...@redhat.com> added the comment:
> 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? ---------- _______________________________________ Python tracker <rep...@bugs.python.org> <https://bugs.python.org/issue34595> _______________________________________ _______________________________________________ Python-bugs-list mailing list Unsubscribe: https://mail.python.org/mailman/options/python-bugs-list/archive%40mail-archive.com