updated for version 7.3.786
Problem: Python threads don't run in the background (issue 103). Solution: Move the statements to manipulate thread state.
This commit is contained in:
		| @ -740,12 +740,11 @@ Python_Init(void) | |||||||
| #else | #else | ||||||
| 	PyMac_Initialize(); | 	PyMac_Initialize(); | ||||||
| #endif | #endif | ||||||
| 	/* Initialise threads, and save the state using PyGILState_Ensure. | 	/* Initialise threads, and below save the state using | ||||||
| 	 * Without the call to PyGILState_Ensure, thread specific state (such | 	 * PyGILState_Ensure.  Without the call to PyGILState_Ensure, thread | ||||||
| 	 * as the system trace hook), will be lost between invocations of | 	 * specific state (such as the system trace hook), will be lost | ||||||
| 	 * Python code. */ | 	 * between invocations of Python code. */ | ||||||
| 	PyEval_InitThreads(); | 	PyEval_InitThreads(); | ||||||
| 	pygilstate = PyGILState_Ensure(); |  | ||||||
| #ifdef DYNAMIC_PYTHON | #ifdef DYNAMIC_PYTHON | ||||||
| 	get_exceptions(); | 	get_exceptions(); | ||||||
| #endif | #endif | ||||||
| @ -756,6 +755,10 @@ Python_Init(void) | |||||||
| 	if (PythonMod_Init()) | 	if (PythonMod_Init()) | ||||||
| 	    goto fail; | 	    goto fail; | ||||||
|  |  | ||||||
|  | 	/* The first python thread is vim's, release the lock. */ | ||||||
|  | 	Python_SaveThread(); | ||||||
|  | 	pygilstate = PyGILState_Ensure(); | ||||||
|  |  | ||||||
| 	globals = PyModule_GetDict(PyImport_AddModule("__main__")); | 	globals = PyModule_GetDict(PyImport_AddModule("__main__")); | ||||||
|  |  | ||||||
| 	/* Remove the element from sys.path that was added because of our | 	/* Remove the element from sys.path that was added because of our | ||||||
| @ -764,8 +767,7 @@ Python_Init(void) | |||||||
| 	 * the current directory in sys.path. */ | 	 * the current directory in sys.path. */ | ||||||
| 	PyRun_SimpleString("import sys; sys.path = filter(lambda x: x != '/must>not&exist', sys.path)"); | 	PyRun_SimpleString("import sys; sys.path = filter(lambda x: x != '/must>not&exist', sys.path)"); | ||||||
|  |  | ||||||
| 	/* the first python thread is vim's, release the lock */ | 	PyGILState_Release(pygilstate); | ||||||
| 	Python_SaveThread(); |  | ||||||
|  |  | ||||||
| 	initialised = 1; | 	initialised = 1; | ||||||
|     } |     } | ||||||
|  | |||||||
| @ -725,6 +725,8 @@ static char *(features[]) = | |||||||
|  |  | ||||||
| static int included_patches[] = | static int included_patches[] = | ||||||
| {   /* Add new patch number below this line */ | {   /* Add new patch number below this line */ | ||||||
|  | /**/ | ||||||
|  |     786, | ||||||
| /**/ | /**/ | ||||||
|     785, |     785, | ||||||
| /**/ | /**/ | ||||||
|  | |||||||
		Reference in New Issue
	
	Block a user