aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorTatsuya Kinoshita <tats@debian.org>2021-02-28 21:48:57 +0000
committerTatsuya Kinoshita <tats@debian.org>2021-02-28 21:50:32 +0000
commite37579c13c466b0704b2c3ce17edd2ecf0cc9f36 (patch)
treeb6ee44f49d9a68126e611ff93c0543a7aaf627ad
parentPrevent unintentional integer overflow in libwc (diff)
downloadw3m-0.5.3+git20210102+deb11u0.5.tar.gz
w3m-0.5.3+git20210102+deb11u0.5.zip
Prevent zero size allocation in Str.cv0.5.3+git20210102+deb11u0.5master-deb11
-rw-r--r--Str.c8
1 files changed, 4 insertions, 4 deletions
diff --git a/Str.c b/Str.c
index aa47dc6..03e0950 100644
--- a/Str.c
+++ b/Str.c
@@ -69,7 +69,7 @@ Strnew_charp(const char *p)
return Strnew();
x = GC_MALLOC(sizeof(struct _Str));
n = strlen(p) + 1;
- if (n < 0 || n > STR_SIZE_MAX)
+ if (n <= 0 || n > STR_SIZE_MAX)
n = STR_SIZE_MAX;
x->ptr = GC_MALLOC_ATOMIC(n);
x->area_size = n;
@@ -206,14 +206,14 @@ Strcat_charp_n(Str x, const char *y, int n)
if (n < 0)
n = STR_SIZE_MAX - 1;
newlen = x->length + n + 1;
- if (newlen < 0 || newlen > STR_SIZE_MAX) {
+ if (newlen <= 0 || newlen > STR_SIZE_MAX) {
newlen = STR_SIZE_MAX;
n = newlen - x->length - 1;
}
if (x->area_size < newlen) {
char *old = x->ptr;
newlen += newlen / 2;
- if (newlen < 0 || newlen > STR_SIZE_MAX)
+ if (newlen <= 0 || newlen > STR_SIZE_MAX)
newlen = STR_SIZE_MAX;
x->ptr = GC_MALLOC_ATOMIC(newlen);
x->area_size = newlen;
@@ -259,7 +259,7 @@ Strgrow(Str x)
newlen = x->area_size + x->area_size / 5;
if (newlen == x->area_size)
newlen += 2;
- if (newlen < 0 || newlen > STR_SIZE_MAX) {
+ if (newlen <= 0 || newlen > STR_SIZE_MAX) {
newlen = STR_SIZE_MAX;
if (x->length + 1 >= newlen)
x->length = newlen - 2;