Issue #6915: Under Windows, os.listdir() didn't release the Global

Interpreter Lock around all system calls.  Original patch by Ryan Kelly.
This commit is contained in:
Antoine Pitrou 2010-08-09 23:39:31 +00:00
parent 5af4f4b983
commit b73caab436
3 changed files with 9 additions and 1 deletions

View File

@ -419,6 +419,7 @@ Jacob Kaplan-Moss
Lou Kates
Hiroaki Kawai
Sebastien Keim
Ryan Kelly
Robert Kern
Randall Kern
Magnus Kessler

View File

@ -30,6 +30,9 @@ Core and Builtins
Extensions
----------
- Issue #6915: Under Windows, os.listdir() didn't release the Global
Interpreter Lock around all system calls. Original patch by Ryan Kelly.
- Issue #8524: Add a detach() method to socket objects, so as to put the
socket into the closed state without closing the underlying file
descriptor.

View File

@ -1229,7 +1229,7 @@ win32_stat_w(const wchar_t* path, struct win32_stat *result)
/* FILE_FLAG_BACKUP_SEMANTICS is required to open a directory */
FILE_ATTRIBUTE_NORMAL|FILE_FLAG_BACKUP_SEMANTICS,
NULL);
if(hFile == INVALID_HANDLE_VALUE) {
/* Either the target doesn't exist, or we don't have access to
get a handle to it. If the former, we need to return an error.
@ -2353,7 +2353,9 @@ posix_listdir(PyObject *self, PyObject *args)
free(wnamebuf);
return NULL;
}
Py_BEGIN_ALLOW_THREADS
hFindFile = FindFirstFileW(wnamebuf, &wFileData);
Py_END_ALLOW_THREADS
if (hFindFile == INVALID_HANDLE_VALUE) {
int error = GetLastError();
if (error == ERROR_FILE_NOT_FOUND) {
@ -2430,7 +2432,9 @@ posix_listdir(PyObject *self, PyObject *args)
if ((d = PyList_New(0)) == NULL)
return NULL;
Py_BEGIN_ALLOW_THREADS
hFindFile = FindFirstFile(namebuf, &FileData);
Py_END_ALLOW_THREADS
if (hFindFile == INVALID_HANDLE_VALUE) {
int error = GetLastError();
if (error == ERROR_FILE_NOT_FOUND)