-
- Notifications
You must be signed in to change notification settings - Fork 33.2k
Closed
Labels
type-featureA feature request or enhancementA feature request or enhancement
Description
Bug report
Right now both list
and dict
have incorrrect text signatures of __getitem__
.
What is affected?
>>> help(list.__getitem__) Help on method_descriptor: __getitem__(...) x.__getitem__(y) <==> x[y] >>> help(dict.__getitem__) Help on method_descriptor: __getitem__(...) x.__getitem__(y) <==> x[y]
In constrast with __setitem__
and __delitem__
:
>>> help(list.__setitem__) Help on wrapper_descriptor: __setitem__(self, key, value, /) Set self[key] to value. >>> help(dict.__setitem__) Help on wrapper_descriptor: __setitem__(self, key, value, /) Set self[key] to value. >>> help(dict.__delitem__) Help on wrapper_descriptor: __delitem__(self, key, /) Delete self[key].
It also affects .__text_signature__
:
>>> list.__getitem__.__text_signature__ >>> dict.__getitem__.__text_signature__ >>> list.__setitem__.__text_signature__ '($self, key, value, /)' >>> dict.__setitem__.__text_signature__ '($self, key, value, /)'
And inspect.signature
:
>>> inspect.signature(dict.__getitem__) Traceback (most recent call last): File "<stdin>", line 1, in <module> File "/Users/sobolev/.pyenv/versions/3.8.9/lib/python3.8/inspect.py", line 3105, in signature return Signature.from_callable(obj, follow_wrapped=follow_wrapped) File "/Users/sobolev/.pyenv/versions/3.8.9/lib/python3.8/inspect.py", line 2854, in from_callable return _signature_from_callable(obj, sigcls=cls, File "/Users/sobolev/.pyenv/versions/3.8.9/lib/python3.8/inspect.py", line 2308, in _signature_from_callable return _signature_from_builtin(sigcls, obj, File "/Users/sobolev/.pyenv/versions/3.8.9/lib/python3.8/inspect.py", line 2119, in _signature_from_builtin raise ValueError("no signature found for builtin {!r}".format(func)) ValueError: no signature found for builtin <method '__getitem__' of 'dict' objects> >>> inspect.signature(dict.__setitem__) <Signature (self, key, value, /)>
I think that this can be fixed quite easily!
My plan is to modify these two descriptions:
Line 2827 in e860e52
{"__getitem__", (PyCFunction)list_subscript, METH_O|METH_COEXIST, "x.__getitem__(y) <==> x[y]"}, Line 3594 in e860e52
PyDoc_STRVAR(getitem__doc__, "x.__getitem__(y) <==> x[y]");
With something like typeobject.c
has: "__getitem__($self, key, /)\n--\n\nReturn self[key]."
Using clinic
here seems impossible / overly-complex.
Should I send a PR for this? 🙂
AlexWaygood
Metadata
Metadata
Assignees
Labels
type-featureA feature request or enhancementA feature request or enhancement