diff options
| author | Mattias Andrée <maandree@kth.se> | 2016-03-04 23:50:00 +0100 |
|---|---|---|
| committer | Mattias Andrée <maandree@kth.se> | 2016-03-04 23:50:00 +0100 |
| commit | 76d0af5599554d11f104d582cdac8fbaa8569fcc (patch) | |
| tree | 0ed9889a86d52ebd208382f2fd49dad0570d1f8c /src/zlsh.c | |
| parent | Clean up, fix a few bugs, and add a test (diff) | |
| download | libzahl-76d0af5599554d11f104d582cdac8fbaa8569fcc.tar.gz libzahl-76d0af5599554d11f104d582cdac8fbaa8569fcc.tar.bz2 libzahl-76d0af5599554d11f104d582cdac8fbaa8569fcc.tar.xz | |
Clean up, add zerror and zperror, fix bugs and add more tests
Signed-off-by: Mattias Andrée <maandree@kth.se>
Diffstat (limited to 'src/zlsh.c')
| -rw-r--r-- | src/zlsh.c | 30 |
1 files changed, 16 insertions, 14 deletions
@@ -19,25 +19,27 @@ zlsh(z_t a, z_t b, size_t bits) chars = FLOOR_BITS_TO_CHARS(bits); bits = BITS_IN_LAST_CHAR(bits); - cbits = BITS_PER_CHAR - 1 - bits; + cbits = BITS_PER_CHAR - bits; - a->used = b->used + chars; - ENSURE_SIZE(a, a->used); + ENSURE_SIZE(a, b->used + chars); if (a == b) - zmemmove(a->chars + chars, b->chars, a->used); + zmemmove(a->chars + chars, b->chars, b->used); else - zmemcpy(a->chars + chars, b->chars, a->used); + zmemcpy(a->chars + chars, b->chars, b->used); zmemset(a->chars, 0, chars); + a->used = b->used + chars; - for (i = chars; i < a->used; i++) { - carry[~i & 1] = a->chars[i] >> cbits; - a->chars[i] <<= bits; - a->chars[i] |= carry[i & 1]; - } - if (carry[i & 1]) { - ENSURE_SIZE(a, a->alloced << 1); - a->chars[i] = carry[i & 1]; - a->used++; + if (bits) { /* This if statement is very important in C. */ + for (i = chars; i < a->used; i++) { + carry[~i & 1] = a->chars[i] >> cbits; + a->chars[i] <<= bits; + a->chars[i] |= carry[i & 1]; + } + if (carry[i & 1]) { + ENSURE_SIZE(a, a->used + 1); + a->chars[i] = carry[i & 1]; + a->used++; + } } SET_SIGNUM(a, zsignum(b)); |
