3 * folder_pack.c -- pack (renumber) the messages in a folder
4 * -- into a contiguous range from 1 to n.
6 * This code is Copyright (c) 2002, by the authors of nmh. See the
7 * COPYRIGHT file in the root directory of the nmh distribution for
8 * complete copyright information.
14 * Pack the message in a folder.
15 * Return -1 if error, else return 0.
19 folder_pack (struct msgs **mpp, int verbose)
21 int hole, msgnum, newcurrent = 0;
22 char newmsg[BUFSIZ], oldmsg[BUFSIZ];
28 * Just return if folder is empty.
34 * Make sure we have message status space allocated
35 * for all numbers from 1 to current high message.
38 if ((mp = folder_realloc (mp, 1, mp->hghmsg)))
41 advise (NULL, "unable to allocate folder storage");
46 for (msgnum = mp->lowmsg, hole = 1; msgnum <= mp->hghmsg; msgnum++) {
47 if (does_exist (mp, msgnum)) {
49 strncpy (newmsg, m_name (hole), sizeof(newmsg));
50 strncpy (oldmsg, m_name (msgnum), sizeof(oldmsg));
52 printf ("message %s becomes %s\n", oldmsg, newmsg);
55 * Invoke the external refile hook for each message being renamed.
56 * This is done before the file is renamed so that the old message
57 * file is around for the hook.
60 (void)snprintf(oldmsg, sizeof (oldmsg), "%s/%d", mp->foldpath, msgnum);
61 (void)snprintf(newmsg, sizeof (newmsg), "%s/%d", mp->foldpath, hole);
62 ext_hook("ref-hook", oldmsg, newmsg);
64 /* move the message file */
65 if (rename (oldmsg, newmsg) == -1) {
66 advise (newmsg, "unable to rename %s to", oldmsg);
70 /* check if this is the current message */
71 if (msgnum == mp->curmsg)
74 /* copy the attribute flags for this message */
75 copy_msg_flags (mp, hole, msgnum);
77 if (msgnum == mp->lowsel)
79 if (msgnum == mp->hghsel)
82 /* mark that sequence information has been modified */
83 mp->msgflags |= SEQMOD;
89 /* record the new number for the high/low message */
91 mp->hghmsg = hole - 1;
93 /* update the "cur" sequence */
95 seq_setcur (mp, newcurrent);