diff options
author | Kaz Kylheku <kaz@kylheku.com> | 2017-06-06 06:25:58 -0700 |
---|---|---|
committer | Kaz Kylheku <kaz@kylheku.com> | 2017-06-06 06:25:58 -0700 |
commit | 840330f271f25b093c7a86b41e7cddaec0cb6d7f (patch) | |
tree | d6d603f3a783b217959746c9bcc9410548dfb9a6 /stream.c | |
parent | 9bc7cb70ae8d216f90f11ba66e202e941c469a91 (diff) | |
download | txr-840330f271f25b093c7a86b41e7cddaec0cb6d7f.tar.gz txr-840330f271f25b093c7a86b41e7cddaec0cb6d7f.tar.bz2 txr-840330f271f25b093c7a86b41e7cddaec0cb6d7f.zip |
c++ maintenance: signed/unsigned comparisons.
* ffi.c (ffi_sbit_put, make_ffi_type_struct): Fix
signed/unsigned comparison warning from g++.
(pad_retval): Likewise.
* stream.c (stdio_put_buf, stdio_fill_buf): Likewise.
Diffstat (limited to 'stream.c')
-rw-r--r-- | stream.c | 8 |
1 files changed, 4 insertions, 4 deletions
@@ -860,9 +860,9 @@ static val stdio_put_buf(val stream, val buf, cnum pos) ucnum len = c_unum(length_buf(buf)); mem_t *ptr = buf_get(buf, self); struct stdio_handle *h = coerce(struct stdio_handle *, stream->co.handle); - if ((size_t) len != len) + if ((size_t) len != len || len > INT_PTR_MAX) uw_throwf(error_s, lit("~a: buffer too large"), self, nao); - if (pos >= len) + if (convert(ucnum, pos) >= len) return num(len); errno = 0; if (h->f != 0) { @@ -880,9 +880,9 @@ static val stdio_fill_buf(val stream, val buf, cnum pos) ucnum len = c_unum(length_buf(buf)); mem_t *ptr = buf_get(buf, self); struct stdio_handle *h = coerce(struct stdio_handle *, stream->co.handle); - if ((size_t) len != len) + if ((size_t) len != len || len > INT_PTR_MAX) uw_throwf(error_s, lit("~a: buffer too large"), self, nao); - if (pos >= len) + if (convert(ucnum, pos) >= len) return num(len); errno = 0; if (h->f != 0) { |