diff options
author | Rodrigo Arias Mallo <rodarima@gmail.com> | 2025-04-13 19:15:26 +0200 |
---|---|---|
committer | Rodrigo Arias Mallo <rodarima@gmail.com> | 2025-05-10 21:04:50 +0200 |
commit | b47de46fa4189c8fa890851c1e63d57c6b7d1d9a (patch) | |
tree | afdddcea24df0fd62bcf344fdee0d47cabcf17bb /lout/misc.cc | |
parent | 0943cbbc5a3d7e1f60c2b5fe730cfda0d830cdd4 (diff) |
Don't use assert to check if realloc() failed
Avoid using assert as when building with NDEBUG defined they become a
no-operation so the realloc is never done. Always perform the check and
exit accordingly.
Diffstat (limited to 'lout/misc.cc')
-rw-r--r-- | lout/misc.cc | 10 |
1 files changed, 6 insertions, 4 deletions
diff --git a/lout/misc.cc b/lout/misc.cc index 72f01047..6bd5992d 100644 --- a/lout/misc.cc +++ b/lout/misc.cc @@ -2,6 +2,7 @@ * Dillo Widget * * Copyright 2005-2007 Sebastian Geerken <sgeerken@dillo.org> + * Copyright 2025 Rodrigo Arias Mallo <rodarima@gmail.com> * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by @@ -163,10 +164,11 @@ void BitSet::set(int i, bool val) int newNumBytes = numBytes; while (8 * i >= newNumBytes) newNumBytes *= 2; - - void *vp; - assert((vp = realloc(bits, newNumBytes * sizeof(unsigned char)))); - if (!vp) exit(-2); // when NDEBUG is defined + void *vp = realloc(bits, newNumBytes * sizeof(unsigned char)); + if (vp == NULL) { + perror("realloc failed"); + exit(1); + } bits = (unsigned char*)vp; memset(bits + numBytes, 0, newNumBytes - numBytes); numBytes = newNumBytes; |