diff options
| author | Mattias Andrée <maandree@kth.se> | 2016-03-03 23:02:59 +0100 |
|---|---|---|
| committer | Mattias Andrée <maandree@kth.se> | 2016-03-03 23:02:59 +0100 |
| commit | d6987458f21cf1890045f2606d0f8ec4d2225b44 (patch) | |
| tree | 90afabbea01b01c4dedcb41748eb534ce04fbf77 /src/zbset.c | |
| parent | zsets: minor optimisation (diff) | |
| download | libzahl-d6987458f21cf1890045f2606d0f8ec4d2225b44.tar.gz libzahl-d6987458f21cf1890045f2606d0f8ec4d2225b44.tar.bz2 libzahl-d6987458f21cf1890045f2606d0f8ec4d2225b44.tar.xz | |
Cleanup and fix bug in ztrunc
Signed-off-by: Mattias Andrée <maandree@kth.se>
Diffstat (limited to 'src/zbset.c')
| -rw-r--r-- | src/zbset.c | 14 |
1 files changed, 4 insertions, 10 deletions
diff --git a/src/zbset.c b/src/zbset.c index 6833e5f..526309a 100644 --- a/src/zbset.c +++ b/src/zbset.c @@ -1,9 +1,6 @@ /* See LICENSE file for copyright and license details. */ #include "internals" -#include <stdlib.h> -#include <string.h> - void zbset(z_t a, z_t b, size_t bit, int action) @@ -15,8 +12,7 @@ zbset(z_t a, z_t b, size_t bit, int action) bit = BITS_IN_LAST_CHAR(bit); x <<= bit; - if (a != b) - zset(a, b); + SET(a, b); if (action) { if (zzero(a)) { @@ -24,11 +20,9 @@ zbset(z_t a, z_t b, size_t bit, int action) SET_SIGNUM(a, 1); } if (a->used <= chars) { - if (a->alloced <= chars) { - a->alloced = chars + 1; - a->chars = realloc(a->chars, a->alloced * sizeof(*(a->chars))); - } - memset(a->chars + a->used, 0, (chars - a->used + 1) * sizeof(*(a->chars))); + if (a->alloced <= chars) + zahl_realloc(a, chars + 1); + zmemset(a->chars + a->used, 0, chars - a->used + 1); } } |
