Commit e4110dc1 authored by Victor Stinner's avatar Victor Stinner

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.
parent 8c126d7a
...@@ -1057,6 +1057,15 @@ if sys.platform != 'win32': ...@@ -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 ...@@ -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."); ...@@ -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 */
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment