Commit 40b61237 authored by Stefan Krah's avatar Stefan Krah

Merged revisions 86804 via svnmerge from

svn+ssh://pythondev@svn.python.org/python/branches/py3k

........
  r86804 | stefan.krah | 2010-11-26 13:58:05 +0100 (Fri, 26 Nov 2010) | 1 line

  Issue #10383: Fix two leaks.
........
parent 55aa2f39
...@@ -5138,8 +5138,10 @@ posix_read(PyObject *self, PyObject *args) ...@@ -5138,8 +5138,10 @@ posix_read(PyObject *self, PyObject *args)
buffer = PyBytes_FromStringAndSize((char *)NULL, size); buffer = PyBytes_FromStringAndSize((char *)NULL, size);
if (buffer == NULL) if (buffer == NULL)
return NULL; return NULL;
if (!_PyVerify_fd(fd)) if (!_PyVerify_fd(fd)) {
Py_DECREF(buffer);
return posix_error(); return posix_error();
}
Py_BEGIN_ALLOW_THREADS Py_BEGIN_ALLOW_THREADS
n = read(fd, PyBytes_AS_STRING(buffer), size); n = read(fd, PyBytes_AS_STRING(buffer), size);
Py_END_ALLOW_THREADS Py_END_ALLOW_THREADS
...@@ -5166,12 +5168,14 @@ posix_write(PyObject *self, PyObject *args) ...@@ -5166,12 +5168,14 @@ posix_write(PyObject *self, PyObject *args)
if (!PyArg_ParseTuple(args, "iy*:write", &fd, &pbuf)) if (!PyArg_ParseTuple(args, "iy*:write", &fd, &pbuf))
return NULL; return NULL;
if (!_PyVerify_fd(fd)) if (!_PyVerify_fd(fd)) {
PyBuffer_Release(&pbuf);
return posix_error(); return posix_error();
}
Py_BEGIN_ALLOW_THREADS Py_BEGIN_ALLOW_THREADS
size = write(fd, pbuf.buf, (size_t)pbuf.len); size = write(fd, pbuf.buf, (size_t)pbuf.len);
Py_END_ALLOW_THREADS Py_END_ALLOW_THREADS
PyBuffer_Release(&pbuf); PyBuffer_Release(&pbuf);
if (size < 0) if (size < 0)
return posix_error(); return posix_error();
return PyLong_FromSsize_t(size); return PyLong_FromSsize_t(size);
...@@ -5992,10 +5996,10 @@ posix_pathconf(PyObject *self, PyObject *args) ...@@ -5992,10 +5996,10 @@ posix_pathconf(PyObject *self, PyObject *args)
limit = pathconf(path, name); limit = pathconf(path, name);
if (limit == -1 && errno != 0) { if (limit == -1 && errno != 0) {
if (errno == EINVAL) if (errno == EINVAL)
/* could be a path or name problem */ /* could be a path or name problem */
posix_error(); posix_error();
else else
posix_error_with_filename(path); posix_error_with_filename(path);
} }
else else
result = PyLong_FromLong(limit); result = PyLong_FromLong(limit);
...@@ -6178,7 +6182,7 @@ posix_confstr(PyObject *self, PyObject *args) ...@@ -6178,7 +6182,7 @@ posix_confstr(PyObject *self, PyObject *args)
char buffer[256]; char buffer[256];
if (PyArg_ParseTuple(args, "O&:confstr", conv_confstr_confname, &name)) { if (PyArg_ParseTuple(args, "O&:confstr", conv_confstr_confname, &name)) {
int len; int len;
errno = 0; errno = 0;
len = confstr(name, buffer, sizeof(buffer)); len = confstr(name, buffer, sizeof(buffer));
......
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