X-Git-Url: https://diplodocus.org/git/nmh/blobdiff_plain/1691e80890e5d8ba258c51c214a3e91880e1db2b..f1b704d05c9a2209edf851392220438e62470314:/sbr/folder_realloc.c diff --git a/sbr/folder_realloc.c b/sbr/folder_realloc.c index f3130f14..0d1f4979 100644 --- a/sbr/folder_realloc.c +++ b/sbr/folder_realloc.c @@ -2,10 +2,13 @@ /* * folder_realloc.c -- realloc a folder/msgs structure * - * $Id$ + * This code is Copyright (c) 2002, by the authors of nmh. See the + * COPYRIGHT file in the root directory of the nmh distribution for + * complete copyright information. */ #include +#include /* * Reallocate some of the space in the folder @@ -37,32 +40,47 @@ folder_realloc (struct msgs *mp, int lo, int hi) return mp; if (lo == mp->lowoff) { + bvector_t *v; + size_t old_size = mp->num_msgstats; + size_t new_size = hi - lo + 1; + size_t i; + /* * We are just extending (or shrinking) the end of message * status array. So we don't have to move anything and can * just realloc the message status array. */ - if (!(mp->msgstats = realloc (mp->msgstats, MSGSTATSIZE(mp, lo, hi)))) { - advise (NULL, "unable to reallocate message storage"); - return NULL; + + for (i = old_size, v = &mp->msgstats[old_size-1]; i > new_size; + --i, --v) { + bvector_free (*v); + } + mp->num_msgstats = MSGSTATNUM (lo, hi); + mp->msgstats = + mh_xrealloc (mp->msgstats, MSGSTATSIZE(mp)); + for (i = old_size, v = &mp->msgstats[old_size]; i < new_size; + ++i, ++v) { + *v = bvector_create (0); } } else { /* * We are changing the offset of the message status * array. So we will need to shift everything. */ - seqset_t *tmpstats; + bvector_t *tmpstats, *t; + size_t i; /* first allocate the new message status space */ - if (!(tmpstats = malloc (MSGSTATSIZE(mp, lo, hi)))) { - advise (NULL, "unable to reallocate message storage"); - return NULL; + mp->num_msgstats = MSGSTATNUM (lo, hi); + tmpstats = mh_xmalloc (MSGSTATSIZE(mp)); + for (i = 0, t = tmpstats; i < mp->num_msgstats; ++i, ++t) { + *t = bvector_create (0); } /* then copy messages status array with shift */ if (mp->nummsg > 0) { for (msgnum = mp->lowmsg; msgnum <= mp->hghmsg; msgnum++) - tmpstats[msgnum - lo] = mp->msgstats[msgnum - mp->lowoff]; + bvector_copy (tmpstats[msgnum - lo], msgstat (mp, msgnum)); } free(mp->msgstats); mp->msgstats = tmpstats;