mirror of
https://github.com/python/cpython.git
synced 2025-07-24 11:44:31 +00:00
bpo-30061: Check if PyObject_Size()/PySequence_Size()/PyMapping_Size() (#1096)
raised an error. Replace them with using concrete types API that never fails if appropriate.
This commit is contained in:
parent
c209b70d61
commit
bf623ae884
14 changed files with 108 additions and 48 deletions
|
@ -6642,7 +6642,7 @@ static PyObject *
|
|||
os_setgroups(PyObject *module, PyObject *groups)
|
||||
/*[clinic end generated code: output=3fcb32aad58c5ecd input=fa742ca3daf85a7e]*/
|
||||
{
|
||||
int i, len;
|
||||
Py_ssize_t i, len;
|
||||
gid_t grouplist[MAX_GROUPS];
|
||||
|
||||
if (!PySequence_Check(groups)) {
|
||||
|
@ -6650,6 +6650,9 @@ os_setgroups(PyObject *module, PyObject *groups)
|
|||
return NULL;
|
||||
}
|
||||
len = PySequence_Size(groups);
|
||||
if (len < 0) {
|
||||
return NULL;
|
||||
}
|
||||
if (len > MAX_GROUPS) {
|
||||
PyErr_SetString(PyExc_ValueError, "too many groups");
|
||||
return NULL;
|
||||
|
@ -7877,9 +7880,9 @@ os_read_impl(PyObject *module, int fd, Py_ssize_t length)
|
|||
#if (defined(HAVE_SENDFILE) && (defined(__FreeBSD__) || defined(__DragonFly__) \
|
||||
|| defined(__APPLE__))) || defined(HAVE_READV) || defined(HAVE_WRITEV)
|
||||
static Py_ssize_t
|
||||
iov_setup(struct iovec **iov, Py_buffer **buf, PyObject *seq, int cnt, int type)
|
||||
iov_setup(struct iovec **iov, Py_buffer **buf, PyObject *seq, Py_ssize_t cnt, int type)
|
||||
{
|
||||
int i, j;
|
||||
Py_ssize_t i, j;
|
||||
Py_ssize_t blen, total = 0;
|
||||
|
||||
*iov = PyMem_New(struct iovec, cnt);
|
||||
|
@ -7956,8 +7959,7 @@ static Py_ssize_t
|
|||
os_readv_impl(PyObject *module, int fd, PyObject *buffers)
|
||||
/*[clinic end generated code: output=792da062d3fcebdb input=e679eb5dbfa0357d]*/
|
||||
{
|
||||
int cnt;
|
||||
Py_ssize_t n;
|
||||
Py_ssize_t cnt, n;
|
||||
int async_err = 0;
|
||||
struct iovec *iov;
|
||||
Py_buffer *buf;
|
||||
|
@ -7969,6 +7971,8 @@ os_readv_impl(PyObject *module, int fd, PyObject *buffers)
|
|||
}
|
||||
|
||||
cnt = PySequence_Size(buffers);
|
||||
if (cnt < 0)
|
||||
return -1;
|
||||
|
||||
if (iov_setup(&iov, &buf, buffers, cnt, PyBUF_WRITABLE) < 0)
|
||||
return -1;
|
||||
|
@ -8107,15 +8111,24 @@ posix_sendfile(PyObject *self, PyObject *args, PyObject *kwdict)
|
|||
"sendfile() headers must be a sequence");
|
||||
return NULL;
|
||||
} else {
|
||||
Py_ssize_t i = 0; /* Avoid uninitialized warning */
|
||||
sf.hdr_cnt = PySequence_Size(headers);
|
||||
if (sf.hdr_cnt > 0 &&
|
||||
(i = iov_setup(&(sf.headers), &hbuf,
|
||||
headers, sf.hdr_cnt, PyBUF_SIMPLE)) < 0)
|
||||
Py_ssize_t i = PySequence_Size(headers);
|
||||
if (i < 0)
|
||||
return NULL;
|
||||
if (i > INT_MAX) {
|
||||
PyErr_SetString(PyExc_OverflowError,
|
||||
"sendfile() header is too large");
|
||||
return NULL;
|
||||
}
|
||||
if (i > 0) {
|
||||
sf.hdr_cnt = (int)i;
|
||||
i = iov_setup(&(sf.headers), &hbuf,
|
||||
headers, sf.hdr_cnt, PyBUF_SIMPLE);
|
||||
if (i < 0)
|
||||
return NULL;
|
||||
#ifdef __APPLE__
|
||||
sbytes += i;
|
||||
sbytes += i;
|
||||
#endif
|
||||
}
|
||||
}
|
||||
}
|
||||
if (trailers != NULL) {
|
||||
|
@ -8124,15 +8137,24 @@ posix_sendfile(PyObject *self, PyObject *args, PyObject *kwdict)
|
|||
"sendfile() trailers must be a sequence");
|
||||
return NULL;
|
||||
} else {
|
||||
Py_ssize_t i = 0; /* Avoid uninitialized warning */
|
||||
sf.trl_cnt = PySequence_Size(trailers);
|
||||
if (sf.trl_cnt > 0 &&
|
||||
(i = iov_setup(&(sf.trailers), &tbuf,
|
||||
trailers, sf.trl_cnt, PyBUF_SIMPLE)) < 0)
|
||||
Py_ssize_t i = PySequence_Size(trailers);
|
||||
if (i < 0)
|
||||
return NULL;
|
||||
if (i > INT_MAX) {
|
||||
PyErr_SetString(PyExc_OverflowError,
|
||||
"sendfile() trailer is too large");
|
||||
return NULL;
|
||||
}
|
||||
if (i > 0) {
|
||||
sf.trl_cnt = (int)i;
|
||||
i = iov_setup(&(sf.trailers), &tbuf,
|
||||
trailers, sf.trl_cnt, PyBUF_SIMPLE);
|
||||
if (i < 0)
|
||||
return NULL;
|
||||
#ifdef __APPLE__
|
||||
sbytes += i;
|
||||
sbytes += i;
|
||||
#endif
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -8402,7 +8424,7 @@ static Py_ssize_t
|
|||
os_writev_impl(PyObject *module, int fd, PyObject *buffers)
|
||||
/*[clinic end generated code: output=56565cfac3aac15b input=5b8d17fe4189d2fe]*/
|
||||
{
|
||||
int cnt;
|
||||
Py_ssize_t cnt;
|
||||
Py_ssize_t result;
|
||||
int async_err = 0;
|
||||
struct iovec *iov;
|
||||
|
@ -8414,6 +8436,8 @@ os_writev_impl(PyObject *module, int fd, PyObject *buffers)
|
|||
return -1;
|
||||
}
|
||||
cnt = PySequence_Size(buffers);
|
||||
if (cnt < 0)
|
||||
return -1;
|
||||
|
||||
if (iov_setup(&iov, &buf, buffers, cnt, PyBUF_SIMPLE) < 0) {
|
||||
return -1;
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue