mirror of
https://github.com/python/cpython.git
synced 2026-06-28 20:00:46 +00:00
gh-151665: Fix inspect.signature() on type alias and type parameter evaluators (#151837)
This commit is contained in:
parent
30aeeb375b
commit
7782794850
3 changed files with 52 additions and 10 deletions
|
|
@ -733,14 +733,8 @@ codegen_setup_annotations_scope(compiler *c, location loc,
|
|||
}
|
||||
|
||||
static int
|
||||
codegen_leave_annotations_scope(compiler *c, location loc)
|
||||
codegen_rename_annotations_format_param(PyCodeObject *co)
|
||||
{
|
||||
ADDOP_IN_SCOPE(c, loc, RETURN_VALUE);
|
||||
PyCodeObject *co = _PyCompile_OptimizeAndAssemble(c, 1);
|
||||
if (co == NULL) {
|
||||
return ERROR;
|
||||
}
|
||||
|
||||
// We want the parameter to __annotate__ to be named "format" in the
|
||||
// signature shown by inspect.signature(), but we need to use a
|
||||
// different name (.format) in the symtable; if the name
|
||||
|
|
@ -749,19 +743,16 @@ codegen_leave_annotations_scope(compiler *c, location loc)
|
|||
// co->co_localsplusnames = ("format", *co->co_localsplusnames[1:])
|
||||
const Py_ssize_t size = PyObject_Size(co->co_localsplusnames);
|
||||
if (size == -1) {
|
||||
Py_DECREF(co);
|
||||
return ERROR;
|
||||
}
|
||||
PyObject *new_names = PyTuple_New(size);
|
||||
if (new_names == NULL) {
|
||||
Py_DECREF(co);
|
||||
return ERROR;
|
||||
}
|
||||
PyTuple_SET_ITEM(new_names, 0, Py_NewRef(&_Py_ID(format)));
|
||||
for (int i = 1; i < size; i++) {
|
||||
PyObject *item = PyTuple_GetItem(co->co_localsplusnames, i);
|
||||
if (item == NULL) {
|
||||
Py_DECREF(co);
|
||||
Py_DECREF(new_names);
|
||||
return ERROR;
|
||||
}
|
||||
|
|
@ -769,6 +760,22 @@ codegen_leave_annotations_scope(compiler *c, location loc)
|
|||
PyTuple_SET_ITEM(new_names, i, item);
|
||||
}
|
||||
Py_SETREF(co->co_localsplusnames, new_names);
|
||||
return SUCCESS;
|
||||
}
|
||||
|
||||
static int
|
||||
codegen_leave_annotations_scope(compiler *c, location loc)
|
||||
{
|
||||
ADDOP_IN_SCOPE(c, loc, RETURN_VALUE);
|
||||
PyCodeObject *co = _PyCompile_OptimizeAndAssemble(c, 1);
|
||||
if (co == NULL) {
|
||||
return ERROR;
|
||||
}
|
||||
|
||||
if (codegen_rename_annotations_format_param(co) < 0) {
|
||||
Py_DECREF(co);
|
||||
return ERROR;
|
||||
}
|
||||
|
||||
_PyCompile_ExitScope(c);
|
||||
int ret = codegen_make_closure(c, loc, co, 0);
|
||||
|
|
@ -1269,6 +1276,10 @@ codegen_type_param_bound_or_default(compiler *c, expr_ty e,
|
|||
if (co == NULL) {
|
||||
return ERROR;
|
||||
}
|
||||
if (codegen_rename_annotations_format_param(co) < 0) {
|
||||
Py_DECREF(co);
|
||||
return ERROR;
|
||||
}
|
||||
int ret = codegen_make_closure(c, LOC(e), co, MAKE_FUNCTION_DEFAULTS);
|
||||
Py_DECREF(co);
|
||||
RETURN_IF_ERROR(ret);
|
||||
|
|
@ -1770,6 +1781,10 @@ codegen_typealias_body(compiler *c, stmt_ty s)
|
|||
if (co == NULL) {
|
||||
return ERROR;
|
||||
}
|
||||
if (codegen_rename_annotations_format_param(co) < 0) {
|
||||
Py_DECREF(co);
|
||||
return ERROR;
|
||||
}
|
||||
int ret = codegen_make_closure(c, loc, co, MAKE_FUNCTION_DEFAULTS);
|
||||
Py_DECREF(co);
|
||||
RETURN_IF_ERROR(ret);
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue