[3.9] bpo-41631: _ast module uses again a global state (GH-21961) (GH-22258)
Partially revert commit ac46eb4ad6662cf6d771b20d8963658b2186c48c:
"bpo-38113: Update the Python-ast.c generator to PEP384 (gh-15957)".
Using a module state per module instance is causing subtle practical
problems.
For example, the Mercurial project replaces the __import__() function
to implement lazy import, whereas Python expected that "import _ast"
always return a fully initialized _ast module.
Add _PyAST_Fini() to clear the state at exit.
The _ast module has no state (set _astmodule.m_size to 0). Remove
astmodule_traverse(), astmodule_clear() and astmodule_free()
functions..
(cherry picked from commit e5fbe0cbd4be99ced5f000ad382208ad2a561c90)
Co-authored-by: Victor Stinner <vstinner@python.org>
diff --git a/Python/pylifecycle.c b/Python/pylifecycle.c
index 00a9b99..cfb3a7d 100644
--- a/Python/pylifecycle.c
+++ b/Python/pylifecycle.c
@@ -1255,6 +1255,7 @@
{
if (is_main_interp) {
/* Sundry finalizers */
+ _PyAST_Fini();
_PyFrame_Fini();
_PyTuple_Fini();
_PyList_Fini();