Issue #9644: Fix the encoding used by os.statvfs(): use the filesystem encoding
with the surrogateescape error handler, instead of UTF-8 in strict mode.
This commit is contained in:
parent
8c126d7abd
commit
e4110dc11f
@ -1057,6 +1057,15 @@ if sys.platform != 'win32':
|
|||||||
f = open(os.path.join(self.dir, fn), 'rb')
|
f = open(os.path.join(self.dir, fn), 'rb')
|
||||||
f.close()
|
f.close()
|
||||||
|
|
||||||
|
@unittest.skipUnless(hasattr(os, 'statvfs'),
|
||||||
|
"need os.statvfs()")
|
||||||
|
def test_statvfs(self):
|
||||||
|
# issue #9645
|
||||||
|
for fn in self.unicodefn:
|
||||||
|
# should not fail with file not found error
|
||||||
|
fullname = os.path.join(self.dir, fn)
|
||||||
|
os.statvfs(fullname)
|
||||||
|
|
||||||
def test_stat(self):
|
def test_stat(self):
|
||||||
for fn in self.unicodefn:
|
for fn in self.unicodefn:
|
||||||
os.stat(os.path.join(self.dir, fn))
|
os.stat(os.path.join(self.dir, fn))
|
||||||
|
@ -189,6 +189,10 @@ Core and Builtins
|
|||||||
Library
|
Library
|
||||||
-------
|
-------
|
||||||
|
|
||||||
|
- Issue #9644: Fix the encoding used by os.statvfs(): use the filesystem
|
||||||
|
encoding with the surrogateescape error handler, instead of UTF-8 in strict
|
||||||
|
mode.
|
||||||
|
|
||||||
- Issue #16819: IDLE method completion now correctly works for bytes literals.
|
- Issue #16819: IDLE method completion now correctly works for bytes literals.
|
||||||
|
|
||||||
- Issue #9586: Redefine SEM_FAILED on MacOSX to keep compiler happy.
|
- Issue #9586: Redefine SEM_FAILED on MacOSX to keep compiler happy.
|
||||||
|
@ -6463,18 +6463,22 @@ Perform a statvfs system call on the given path.");
|
|||||||
static PyObject *
|
static PyObject *
|
||||||
posix_statvfs(PyObject *self, PyObject *args)
|
posix_statvfs(PyObject *self, PyObject *args)
|
||||||
{
|
{
|
||||||
|
PyObject *opath, *result = NULL;
|
||||||
char *path;
|
char *path;
|
||||||
int res;
|
int res;
|
||||||
struct statvfs st;
|
struct statvfs st;
|
||||||
if (!PyArg_ParseTuple(args, "s:statvfs", &path))
|
if (!PyArg_ParseTuple(args, "O&:statvfs", PyUnicode_FSConverter, &opath))
|
||||||
return NULL;
|
return NULL;
|
||||||
|
path = PyBytes_AS_STRING(opath);
|
||||||
Py_BEGIN_ALLOW_THREADS
|
Py_BEGIN_ALLOW_THREADS
|
||||||
res = statvfs(path, &st);
|
res = statvfs(path, &st);
|
||||||
Py_END_ALLOW_THREADS
|
Py_END_ALLOW_THREADS
|
||||||
if (res != 0)
|
if (res != 0)
|
||||||
return posix_error_with_filename(path);
|
return posix_error_with_allocated_filename(opath);
|
||||||
|
|
||||||
return _pystatvfs_fromstructstatvfs(st);
|
result = _pystatvfs_fromstructstatvfs(st);
|
||||||
|
Py_DECREF(opath);
|
||||||
|
return result;
|
||||||
}
|
}
|
||||||
#endif /* HAVE_STATVFS */
|
#endif /* HAVE_STATVFS */
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user