summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorBram Moolenaar <Bram@vim.org>2012-10-14 05:20:12 +0200
committerBram Moolenaar <Bram@vim.org>2012-10-14 05:20:12 +0200
commitb88adbf844612281d3ed11166bbf03368f7ed704 (patch)
treed6d9dacf4d3451f85c7ad6bfe667c843900111be
parentdac7569612d4088084ef81dfc32c3bb86aec090f (diff)
downloadvim-git-b88adbf844612281d3ed11166bbf03368f7ed704.tar.gz
updated for version 7.3.691v7.3.691
Problem: State specific to the Python thread is discarded. Solution: Keep state between threads. (Paul)
-rw-r--r--src/if_python.c6
-rw-r--r--src/version.c2
2 files changed, 6 insertions, 2 deletions
diff --git a/src/if_python.c b/src/if_python.c
index c194598b7..2a53c93b0 100644
--- a/src/if_python.c
+++ b/src/if_python.c
@@ -740,9 +740,11 @@ Python_Init(void)
#else
PyMac_Initialize();
#endif
- /* initialise threads */
+ /* Initialise threads and save the state using PyGILState_Ensure.
+ * Without this call, thread-specific state (such as the system trace
+ * hook), will be lost between invocations of Python code. */
PyEval_InitThreads();
-
+ pygilstate = PyGILState_Ensure();
#ifdef DYNAMIC_PYTHON
get_exceptions();
#endif
diff --git a/src/version.c b/src/version.c
index 01d679301..2d9529ce5 100644
--- a/src/version.c
+++ b/src/version.c
@@ -720,6 +720,8 @@ static char *(features[]) =
static int included_patches[] =
{ /* Add new patch number below this line */
/**/
+ 691,
+/**/
690,
/**/
689,