diff options
author | Kristján Valur Jónsson <kristjan@ccpgames.com> | 2009-01-09 20:10:59 +0000 |
---|---|---|
committer | Kristján Valur Jónsson <kristjan@ccpgames.com> | 2009-01-09 20:10:59 +0000 |
commit | 3b2a6b819d93868c960da91aeebca7093d6f1627 (patch) | |
tree | 16e83a453f2418b982d5daa5e14f8648eb2b7f49 /Python/import.c | |
parent | 00f2df495a6fcb40d70243c34f296f26ccc72719 (diff) | |
download | cpython-git-3b2a6b819d93868c960da91aeebca7093d6f1627.tar.gz |
Issue 3677: Fix import from UNC paths on Windows.
Diffstat (limited to 'Python/import.c')
-rw-r--r-- | Python/import.c | 34 |
1 files changed, 19 insertions, 15 deletions
diff --git a/Python/import.c b/Python/import.c index e9ff922fd0..b00986c697 100644 --- a/Python/import.c +++ b/Python/import.c @@ -3198,24 +3198,11 @@ NullImporter_init(NullImporter *self, PyObject *args, PyObject *kwds) return -1; } else { #ifndef RISCOS +#ifndef MS_WINDOWS struct stat statbuf; int rv; rv = stat(path, &statbuf); -#ifdef MS_WINDOWS - /* MS Windows stat() chokes on paths like C:\path\. Try to - * recover *one* time by stripping off a trailing slash or - * backslash. http://bugs.python.org/issue1293 - */ - if (rv != 0 && pathlen <= MAXPATHLEN && - (path[pathlen-1] == '/' || path[pathlen-1] == '\\')) { - char mangled[MAXPATHLEN+1]; - - strcpy(mangled, path); - mangled[pathlen-1] = '\0'; - rv = stat(mangled, &statbuf); - } -#endif if (rv == 0) { /* it exists */ if (S_ISDIR(statbuf.st_mode)) { @@ -3225,7 +3212,24 @@ NullImporter_init(NullImporter *self, PyObject *args, PyObject *kwds) return -1; } } -#else +#else /* MS_WINDOWS */ + DWORD rv; + /* see issue1293 and issue3677: + * stat() on Windows doesn't recognise paths like + * "e:\\shared\\" and "\\\\whiterab-c2znlh\\shared" as dirs. + */ + rv = GetFileAttributesA(path); + if (rv != INVALID_FILE_ATTRIBUTES) { + /* it exists */ + if (rv & FILE_ATTRIBUTE_DIRECTORY) { + /* it's a directory */ + PyErr_SetString(PyExc_ImportError, + "existing directory"); + return -1; + } + } +#endif +#else /* RISCOS */ if (object_exists(path)) { /* it exists */ if (isdir(path)) { |