]>
diplodocus.org Git - nmh/blob - sbr/seq_del.c
1 /* seq_del.c -- delete message(s) from a sequence
3 * This code is Copyright (c) 2002, by the authors of nmh. See the
4 * COPYRIGHT file in the root directory of the nmh distribution for
5 * complete copyright information.
12 * Delete all SELECTED messages from sequence
14 * If public == 1, make sequence public.
15 * If public == 0, make sequence private.
16 * If public == -1, leave the public/private bit alone for existing
17 * sequences. For new sequences, set this bit based
18 * on its readonly status.
20 * If error, return 0, else return 1.
24 seq_delsel (struct msgs
*mp
, char *cp
, int public, int zero
)
33 * Get the number for this sequence
36 for (i
= 0; i
< svector_size (mp
->msgattrs
); i
++) {
37 if (!strcmp (svector_at (mp
->msgattrs
, i
), cp
)) {
44 * If the zero flag is set, first add all existing
45 * messages in this folder to the sequence.
49 * create the sequence, if necessary
52 if (!(svector_push_back (mp
->msgattrs
, strdup (cp
)))) {
53 inform("strdup failed");
58 * now add sequence bit to all existing messages
60 for (msgnum
= mp
->lowmsg
; msgnum
<= mp
->hghmsg
; msgnum
++) {
61 if (does_exist (mp
, msgnum
))
62 add_sequence (mp
, i
, msgnum
);
64 clear_sequence (mp
, i
, msgnum
);
68 inform("no such sequence as %s", cp
);
74 * Now clear the bit on all selected messages
76 for (msgnum
= mp
->lowsel
; msgnum
<= mp
->hghsel
; msgnum
++)
77 if (is_selected (mp
, msgnum
))
78 clear_sequence (mp
, i
, msgnum
);
80 if (! strcmp (cp
, current
) &&
81 mp
->lowsel
<= mp
->curmsg
&& mp
->curmsg
<= mp
->hghsel
) {
82 /* Removed current message indication, so reset curmsg. */
87 * Set the public/private bit for this sequence.
90 make_seq_public (mp
, i
);
92 make_seq_private (mp
, i
);
95 * If public == -1, then only set the
96 * public/private bit for new sequences.
99 make_seq_private (mp
, i
);
101 make_seq_public (mp
, i
);
104 mp
->msgflags
|= SEQMOD
;
110 * Delete message from sequence.
112 * If error, return 0, else return 1.
116 seq_delmsg (struct msgs
*mp
, char *cp
, int msgnum
)
120 if (!seq_nameok (cp
))
123 for (i
= 0; i
< svector_size (mp
->msgattrs
); i
++) {
124 if (!strcmp (svector_at (mp
->msgattrs
, i
), cp
)) {
125 clear_sequence (mp
, i
, msgnum
);
126 mp
->msgflags
|= SEQMOD
;
131 inform("no such sequence as %s", cp
);