-
-
Notifications
You must be signed in to change notification settings - Fork 30.9k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
gh-108901: Deprecate inspect.getargs
, slate it for removal in 3.15
#112279
base: main
Are you sure you want to change the base?
Conversation
import warnings | ||
with warnings.catch_warnings(): | ||
warnings.simplefilter('ignore', category=DeprecationWarning) | ||
args, varargs, varkw = getargs(frame.f_code) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Maybe we should follow our own advice and use inspect.signature(types.FunctionType(frame.f_code, {}))
here? :)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I don't think so. Right now getargs
does some ugly things:
Line 1384 in fef6fb8
return Arguments(args + kwonlyargs, varargs, varkw) |
pos_or_kw_args
together with kw_only_args
, but ignores pos_only_args
.
I think that we can just keep it as-is and then remove all of them together in 3.15 (because getargvalues
will also be deprecated and removed at the same time, PR is just not ready yet).
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Okay, I see. Maybe we should do the getargvalues()
deprecation first, though, in that case? It makes me a little uncomfortable adding this deprecation warning now, if we're not able to make the mandated change in our own code yet.
(I'm fine suppressing DeprecationWarning
s in a function that is itself deprecated, but getargvalues()
isn't, yet. And I know you plan to work on deprecating it immediately after this PR, but if I had a pound for every time somebody promised me they'd work on something the next day, and then discovered it was harder than they expected, I'd be a rich man :)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Sure, I can open a PR about getargvalues()
first 👍
Misc/NEWS.d/next/Library/2023-11-20-12-31-14.gh-issue-108901.abVgVe.rst
Outdated
Show resolved
Hide resolved
Co-authored-by: Alex Waygood <[email protected]>
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
LGTM, thanks! As discussed in https://github.com/python/cpython/pull/112279/files#r1402002908, however, let's deprecate getargvalues()
first 👍
Following the discussion of #108902, I documented that
getargs
is deprecated (since it is not documented anywhere, I just modified its docstring) and thatinspect.signature(types.FunctionType(co, {}))
is the modern alternative. I think that it is safe to remove this function in two versions, because it does not work anyway (pos-only, kw-only params are incorrect).I also don't think that modernizing
getargvalues
is valuable, because it will also be deprecated in 3.13 and hopefully removed in 3.15 as well.CC @AlexWaygood @merwok @vstinner who reviewed the first PR.
inspect
module, deprecate old incorrect APIs #108901