mirror of
https://github.com/python/cpython.git
synced 2025-12-08 06:10:17 +00:00
Lazy imports grammar / AST changes
This commit is contained in:
parent
fb114cf497
commit
1c691ea756
25 changed files with 1016 additions and 338 deletions
|
|
@ -22,6 +22,7 @@
|
|||
#include "pycore_interpolation.h" // _PyInterpolation_Build()
|
||||
#include "pycore_intrinsics.h"
|
||||
#include "pycore_jit.h"
|
||||
#include "pycore_lazyimportobject.h"
|
||||
#include "pycore_list.h" // _PyList_GetItemRef()
|
||||
#include "pycore_long.h" // _PyLong_GetZero()
|
||||
#include "pycore_moduleobject.h" // PyModuleObject
|
||||
|
|
@ -2986,11 +2987,11 @@ _PyEval_SliceIndexNotNone(PyObject *v, Py_ssize_t *pi)
|
|||
}
|
||||
|
||||
PyObject *
|
||||
_PyEval_ImportName(PyThreadState *tstate, _PyInterpreterFrame *frame,
|
||||
_PyEval_ImportName(PyThreadState *tstate, PyObject *builtins, PyObject *globals, PyObject *locals,
|
||||
PyObject *name, PyObject *fromlist, PyObject *level)
|
||||
{
|
||||
PyObject *import_func;
|
||||
if (PyMapping_GetOptionalItem(frame->f_builtins, &_Py_ID(__import__), &import_func) < 0) {
|
||||
if (PyMapping_GetOptionalItem(builtins, &_Py_ID(__import__), &import_func) < 0) {
|
||||
return NULL;
|
||||
}
|
||||
if (import_func == NULL) {
|
||||
|
|
@ -2998,7 +2999,6 @@ _PyEval_ImportName(PyThreadState *tstate, _PyInterpreterFrame *frame,
|
|||
return NULL;
|
||||
}
|
||||
|
||||
PyObject *locals = frame->f_locals;
|
||||
if (locals == NULL) {
|
||||
locals = Py_None;
|
||||
}
|
||||
|
|
@ -3012,18 +3012,50 @@ _PyEval_ImportName(PyThreadState *tstate, _PyInterpreterFrame *frame,
|
|||
}
|
||||
return PyImport_ImportModuleLevelObject(
|
||||
name,
|
||||
frame->f_globals,
|
||||
globals,
|
||||
locals,
|
||||
fromlist,
|
||||
ilevel);
|
||||
}
|
||||
|
||||
PyObject* args[5] = {name, frame->f_globals, locals, fromlist, level};
|
||||
PyObject* args[5] = {name, globals, locals, fromlist, level};
|
||||
PyObject *res = PyObject_Vectorcall(import_func, args, 5, NULL);
|
||||
Py_DECREF(import_func);
|
||||
return res;
|
||||
}
|
||||
|
||||
|
||||
PyObject *
|
||||
_PyEval_LazyImportName(PyThreadState *tstate, PyObject *builtins, PyObject *globals,
|
||||
PyObject *name, PyObject *fromlist, PyObject *level)
|
||||
{
|
||||
PyObject *res = NULL;
|
||||
PyObject *abs_name = NULL;
|
||||
int ilevel = PyLong_AsInt(level);
|
||||
if (ilevel == -1 && PyErr_Occurred()) {
|
||||
goto error;
|
||||
}
|
||||
if (ilevel > 0) {
|
||||
abs_name = _PyImport_ResolveName(tstate, name, globals, ilevel);
|
||||
if (abs_name == NULL) {
|
||||
goto error;
|
||||
}
|
||||
} else { /* ilevel == 0 */
|
||||
if (PyUnicode_GET_LENGTH(name) == 0) {
|
||||
PyErr_SetString(PyExc_ValueError, "Empty module name");
|
||||
goto error;
|
||||
}
|
||||
abs_name = name;
|
||||
Py_INCREF(abs_name);
|
||||
}
|
||||
|
||||
// TODO: check sys.modules for module
|
||||
res = _PyLazyImport_New(builtins, abs_name, fromlist);
|
||||
error:
|
||||
Py_XDECREF(abs_name);
|
||||
return res;
|
||||
}
|
||||
|
||||
PyObject *
|
||||
_PyEval_ImportFrom(PyThreadState *tstate, PyObject *v, PyObject *name)
|
||||
{
|
||||
|
|
@ -3192,6 +3224,33 @@ _PyEval_ImportFrom(PyThreadState *tstate, PyObject *v, PyObject *name)
|
|||
return NULL;
|
||||
}
|
||||
|
||||
PyObject *
|
||||
_PyEval_LazyImportFrom(PyThreadState *tstate, PyObject *v, PyObject *name)
|
||||
{
|
||||
assert(PyLazyImport_CheckExact(v));
|
||||
assert(name && PyUnicode_Check(name));
|
||||
PyObject *ret;
|
||||
PyLazyImportObject *d = (PyLazyImportObject *)v;
|
||||
if (d->lz_attr != NULL) {
|
||||
if (PyUnicode_Check(d->lz_attr)) {
|
||||
PyObject *from = PyUnicode_FromFormat("%U.%U", d->lz_from, d->lz_attr);
|
||||
ret = _PyLazyImport_New(d->lz_builtins, from, name);
|
||||
Py_DECREF(from);
|
||||
return ret;
|
||||
}
|
||||
} else {
|
||||
Py_ssize_t dot = PyUnicode_FindChar(d->lz_from, '.', 0, PyUnicode_GET_LENGTH(d->lz_from), 1);
|
||||
if (dot >= 0) {
|
||||
PyObject *from = PyUnicode_Substring(d->lz_from, 0, dot);
|
||||
ret = _PyLazyImport_New(d->lz_builtins, from, name);
|
||||
Py_DECREF(from);
|
||||
return ret;
|
||||
}
|
||||
}
|
||||
ret = _PyLazyImport_New(d->lz_builtins, d->lz_from, name);
|
||||
return ret;
|
||||
}
|
||||
|
||||
#define CANNOT_CATCH_MSG "catching classes that do not inherit from "\
|
||||
"BaseException is not allowed"
|
||||
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue