8c353f380b53a19936dab4cad4822df86b023fb4
[mmh] / sbr / seq_del.c
1
2 /*
3  * seq_del.c -- delete message(s) from a sequence
4  *
5  * This code is Copyright (c) 2002, by the authors of nmh.  See the
6  * COPYRIGHT file in the root directory of the nmh distribution for
7  * complete copyright information.
8  */
9
10 #include <h/mh.h>
11
12
13 /*
14  * Delete all SELECTED messages from sequence
15  *
16  * If public ==  1, make sequence public.
17  * If public ==  0, make sequence private.
18  * If public == -1, leave the public/private bit alone for existing
19  *                  sequences.  For new sequences, set this bit based
20  *                  on its readonly status.
21  *
22  * If error, return 0, else return 1.
23  */
24
25 int
26 seq_delsel (struct msgs *mp, char *cp, int public, int zero)
27 {
28     unsigned int i;
29     int msgnum, new_seq = 1;
30
31     if (!seq_nameok (cp))
32         return 0;
33
34     /*
35      * Get the number for this sequence
36      */
37     for (i = 0; mp->msgattrs[i]; i++) {
38         if (!strcmp (mp->msgattrs[i], cp)) {
39             new_seq = 0;
40             break;
41         }
42     }
43
44     /*
45      * If the zero flag is set, first add all existing
46      * messages in this folder to the sequence.
47      */
48     if (zero) {
49         /*
50          * create the sequence, if necessary
51          */
52         if (new_seq) {
53             if (i >= NUMATTRS) {
54                 advise (NULL, "only %d sequences allowed (no room for %s)!", NUMATTRS, cp);
55                 return 0;
56             }
57             if (!(mp->msgattrs[i] = strdup (cp))) {
58                 advise (NULL, "strdup failed");
59                 return 0;
60             }
61             mp->msgattrs[i + 1] = NULL;
62         }
63         /*
64          * now add sequence bit to all existing messages
65          */
66         for (msgnum = mp->lowmsg; msgnum <= mp->hghmsg; msgnum++) {
67             if (does_exist (mp, msgnum))
68                 add_sequence (mp, i, msgnum);
69             else
70                 clear_sequence (mp, i, msgnum);
71         }
72     } else {
73         if (new_seq) {
74             advise (NULL, "no such sequence as %s", cp);
75             return 0;
76         }
77     }
78
79     /*
80      * Now clear the bit on all selected messages
81      */
82     for (msgnum = mp->lowsel; msgnum <= mp->hghsel; msgnum++)
83         if (is_selected (mp, msgnum))
84             clear_sequence (mp, i, msgnum);
85
86     /*
87      * Set the public/private bit for this sequence.
88      */
89     if (public == 1)
90         make_seq_public (mp, i);
91     else if (public == 0)
92         make_seq_private (mp, i);
93     else if (new_seq) {
94         /*
95          * If public == -1, then only set the
96          * public/private bit for new sequences.
97          */
98         if (is_readonly (mp))
99             make_seq_private (mp, i);
100         else
101             make_seq_public (mp, i);
102     }
103
104     mp->msgflags |= SEQMOD;
105     return 1;
106 }
107
108
109 /*
110  * Delete message from sequence.
111  *
112  * If error, return 0, else return 1.
113  */
114
115 int
116 seq_delmsg (struct msgs *mp, char *cp, int msgnum)
117 {
118     int i;
119
120     if (!seq_nameok (cp))
121         return 0;
122
123     for (i = 0; mp->msgattrs[i]; i++) {
124         if (!strcmp (mp->msgattrs[i], cp)) {
125             clear_sequence (mp, i, msgnum);
126             mp->msgflags |= SEQMOD;
127             return 1;
128         }
129     }
130
131     advise (NULL, "no such sequence as %s", cp);
132     return 0;
133 }