diff options
| author | Tim Golden <mail@timgolden.me.uk> | 2013-08-01 12:44:00 +0100 | 
|---|---|---|
| committer | Tim Golden <mail@timgolden.me.uk> | 2013-08-01 12:44:00 +0100 | 
| commit | 6b528067c50b9dbf1c53fbc8b6fa959050c5dfcd (patch) | |
| tree | 523ab53f48183089526e9f3cdd6737fbc7f62027 /Modules/posixmodule.c | |
| parent | 536ffe161c014f3646cbf52bc527f2ba9ebd6478 (diff) | |
| download | cpython-git-6b528067c50b9dbf1c53fbc8b6fa959050c5dfcd.tar.gz | |
Issue #9035: os.path.ismount now recognises volumes mounted below
a drive root on Windows. Original patch by Atsuo Ishimoto.
Diffstat (limited to 'Modules/posixmodule.c')
| -rw-r--r-- | Modules/posixmodule.c | 42 | 
1 files changed, 42 insertions, 0 deletions
| diff --git a/Modules/posixmodule.c b/Modules/posixmodule.c index 820983c7b0..06cf1df5d5 100644 --- a/Modules/posixmodule.c +++ b/Modules/posixmodule.c @@ -3711,6 +3711,47 @@ check:      else          Py_RETURN_FALSE;  } + +PyDoc_STRVAR(posix__getvolumepathname__doc__, +"Return volume mount point of the specified path."); + +/* A helper function for ismount on windows */ +static PyObject * +posix__getvolumepathname(PyObject *self, PyObject *args) +{ +    PyObject *po, *result; +    wchar_t *path, *mountpath=NULL; +    size_t bufsize; +    BOOL ret; + +    if (!PyArg_ParseTuple(args, "U|:_getvolumepathname", &po)) +        return NULL; +    path = PyUnicode_AsUnicode(po); +    if (path == NULL) +        return NULL; + +    /* Volume path should be shorter than entire path */ +    bufsize = max(MAX_PATH, wcslen(path) * 2 * sizeof(wchar_t)+1); +    mountpath = (wchar_t *)PyMem_Malloc(bufsize); +    if (mountpath == NULL) +        return PyErr_NoMemory(); + +    Py_BEGIN_ALLOW_THREADS +    ret = GetVolumePathNameW(path, mountpath, bufsize); +    Py_END_ALLOW_THREADS + +    if (!ret) { +        result = win32_error_object("_getvolumepathname", po); +        goto exit; +    } +    result = PyUnicode_FromWideChar(mountpath, wcslen(mountpath)); + +exit: +    PyMem_Free(mountpath); +    return result; +} +/* end of posix__getvolumepathname */ +  #endif /* MS_WINDOWS */  PyDoc_STRVAR(posix_mkdir__doc__, @@ -10885,6 +10926,7 @@ static PyMethodDef posix_methods[] = {      {"_getfinalpathname",       posix__getfinalpathname, METH_VARARGS, NULL},      {"_isdir",                  posix__isdir, METH_VARARGS, posix__isdir__doc__},      {"_getdiskusage",           win32__getdiskusage, METH_VARARGS, win32__getdiskusage__doc__}, +    {"_getvolumepathname",      posix__getvolumepathname, METH_VARARGS, posix__getvolumepathname__doc__},  #endif  #ifdef HAVE_GETLOADAVG      {"getloadavg",      posix_getloadavg, METH_NOARGS, posix_getloadavg__doc__}, | 
