diff options
author | Bram Moolenaar <Bram@vim.org> | 2020-10-11 18:05:02 +0200 |
---|---|---|
committer | Bram Moolenaar <Bram@vim.org> | 2020-10-11 18:05:02 +0200 |
commit | efc0d94afc48a03b07955e91315e7e67945cd079 (patch) | |
tree | 75e42d881bc5f83429372139eb0cb5f8d554fb59 /src | |
parent | 204ade6bcb85f48f56e52e040d1ebf40548d92be (diff) |
patch 8.2.1834: PyEval_InitThreads() is deprecated in Python 3.9v8.2.1834
Problem: PyEval_InitThreads() is deprecated in Python 3.9.
Solution: Do not call PyEval_InitThreads in Python 3.9 and later. (Ken
Takata, closes #7113) Avoid warnings for functions.
Diffstat (limited to 'src')
-rw-r--r-- | src/if_py_both.h | 8 | ||||
-rw-r--r-- | src/if_python3.c | 21 | ||||
-rw-r--r-- | src/version.c | 2 |
3 files changed, 17 insertions, 14 deletions
diff --git a/src/if_py_both.h b/src/if_py_both.h index 86942b686c..36dedaf2d5 100644 --- a/src/if_py_both.h +++ b/src/if_py_both.h @@ -307,7 +307,7 @@ ObjectDir(PyObject *self, char **attributes) // Output buffer management // Function to write a line, points to either msg() or emsg(). -typedef void (*writefn)(char_u *); +typedef int (*writefn)(char *); static PyTypeObject OutputType; @@ -359,8 +359,8 @@ PythonIO_Flush(void) { if (old_fn != NULL && io_ga.ga_len > 0) { - ((char_u *)io_ga.ga_data)[io_ga.ga_len] = NUL; - old_fn((char_u *)io_ga.ga_data); + ((char *)io_ga.ga_data)[io_ga.ga_len] = NUL; + old_fn((char *)io_ga.ga_data); } io_ga.ga_len = 0; } @@ -390,7 +390,7 @@ writer(writefn fn, char_u *str, PyInt n) mch_memmove(((char *)io_ga.ga_data) + io_ga.ga_len, str, (size_t)len); ((char *)io_ga.ga_data)[io_ga.ga_len + len] = NUL; - fn((char_u *)io_ga.ga_data); + fn((char *)io_ga.ga_data); str = ptr + 1; n -= len + 1; io_ga.ga_len = 0; diff --git a/src/if_python3.c b/src/if_python3.c index e148e53bb7..495aed3596 100644 --- a/src/if_python3.c +++ b/src/if_python3.c @@ -1002,11 +1002,10 @@ Python3_Init(void) reset_stdin(); Py_Initialize(); - // Initialise threads, and below save the state using - // PyEval_SaveThread. Without the call to PyEval_SaveThread, thread - // specific state (such as the system trace hook), will be lost - // between invocations of Python code. +#if PY_VERSION_HEX < 0x03090000 + // Initialise threads. This is deprecated since Python 3.9. PyEval_InitThreads(); +#endif #ifdef DYNAMIC_PYTHON3 get_py3_exceptions(); #endif @@ -1024,12 +1023,14 @@ Python3_Init(void) // sys.path. PyRun_SimpleString("import vim; import sys; sys.path = list(filter(lambda x: not x.endswith('must>not&exist'), sys.path))"); - // lock is created and acquired in PyEval_InitThreads() and thread - // state is created in Py_Initialize() - // there _PyGILState_NoteThreadState() also sets gilcounter to 1 - // (python must have threads enabled!) - // so the following does both: unlock GIL and save thread state in TLS - // without deleting thread state + // Without the call to PyEval_SaveThread, thread specific state (such + // as the system trace hook), will be lost between invocations of + // Python code. + // GIL may have been created and acquired in PyEval_InitThreads() and + // thread state is created in Py_Initialize(); there + // _PyGILState_NoteThreadState() also sets gilcounter to 1 (python must + // have threads enabled!), so the following does both: unlock GIL and + // save thread state in TLS without deleting thread state PyEval_SaveThread(); py3initialised = 1; diff --git a/src/version.c b/src/version.c index 43613450cd..ced1ef78d6 100644 --- a/src/version.c +++ b/src/version.c @@ -751,6 +751,8 @@ static char *(features[]) = static int included_patches[] = { /* Add new patch number below this line */ /**/ + 1834, +/**/ 1833, /**/ 1832, |