diff options
author | Steve Dower <steve.dower@microsoft.com> | 2017-02-04 22:38:11 (GMT) |
---|---|---|
committer | Steve Dower <steve.dower@microsoft.com> | 2017-02-04 22:38:11 (GMT) |
commit | eacee98679f324fca16852871e76f7be3a685b7c (patch) | |
tree | bb911295a4cbe8f7ed56a85de3445f2c1f7c913e /Modules | |
parent | bf0fc39edb87c71ec1c4ef8353f8d72bb7bb9d1b (diff) | |
download | cpython-eacee98679f324fca16852871e76f7be3a685b7c.zip cpython-eacee98679f324fca16852871e76f7be3a685b7c.tar.gz cpython-eacee98679f324fca16852871e76f7be3a685b7c.tar.bz2 |
Issue #29409: Implement PEP 529 for io.FileIO (Patch by Eryk Sun)
Diffstat (limited to 'Modules')
-rw-r--r-- | Modules/_io/fileio.c | 31 |
1 files changed, 14 insertions, 17 deletions
diff --git a/Modules/_io/fileio.c b/Modules/_io/fileio.c index 6854a44..7f3bcab 100644 --- a/Modules/_io/fileio.c +++ b/Modules/_io/fileio.c @@ -230,12 +230,13 @@ _io_FileIO___init___impl(fileio *self, PyObject *nameobj, const char *mode, int closefd, PyObject *opener) /*[clinic end generated code: output=23413f68e6484bbd input=193164e293d6c097]*/ { - const char *name = NULL; - PyObject *stringobj = NULL; - const char *s; #ifdef MS_WINDOWS Py_UNICODE *widename = NULL; +#else + const char *name = NULL; #endif + PyObject *stringobj = NULL; + const char *s; int ret = 0; int rwa = 0, plus = 0; int flags = 0; @@ -277,24 +278,21 @@ _io_FileIO___init___impl(fileio *self, PyObject *nameobj, const char *mode, PyErr_Clear(); } + if (fd < 0) { #ifdef MS_WINDOWS - if (PyUnicode_Check(nameobj)) { Py_ssize_t length; - widename = PyUnicode_AsUnicodeAndSize(nameobj, &length); - if (widename == NULL) - return -1; - if (wcslen(widename) != length) { - PyErr_SetString(PyExc_ValueError, "embedded null character"); + if (!PyUnicode_FSDecoder(nameobj, &stringobj)) { return -1; } - } else -#endif - if (fd < 0) - { + widename = PyUnicode_AsUnicodeAndSize(stringobj, &length); + if (widename == NULL) + return -1; +#else if (!PyUnicode_FSConverter(nameobj, &stringobj)) { return -1; } name = PyBytes_AS_STRING(stringobj); +#endif } s = mode; @@ -386,11 +384,10 @@ _io_FileIO___init___impl(fileio *self, PyObject *nameobj, const char *mode, do { Py_BEGIN_ALLOW_THREADS #ifdef MS_WINDOWS - if (widename != NULL) - self->fd = _wopen(widename, flags, 0666); - else + self->fd = _wopen(widename, flags, 0666); +#else + self->fd = open(name, flags, 0666); #endif - self->fd = open(name, flags, 0666); Py_END_ALLOW_THREADS } while (self->fd < 0 && errno == EINTR && !(async_err = PyErr_CheckSignals())); |