2 ** rmm.c -- remove a message(s)
4 ** This code is Copyright (c) 2002, by the authors of nmh. See the
5 ** COPYRIGHT file in the root directory of the nmh distribution for
6 ** complete copyright information.
15 static struct swit switches[] = {
29 main(int argc, char **argv)
31 int msgnum, unlink_msgs = 0, vecp = 0;
32 char *cp, *maildir, *folder = NULL, **vec;
33 char buf[BUFSIZ], **argp;
35 struct msgs_array msgs = { 0, 0, NULL };
38 setlocale(LC_ALL, "");
39 invo_name = mhbasename(argv[0]);
43 arguments = getarguments(invo_name, argc, argv, 1);
47 while ((cp = *argp++)) {
49 switch (smatch(++cp, switches)) {
51 ambigsw(cp, switches);
54 adios(EX_USAGE, NULL, "-%s unknown\n", cp);
57 snprintf(buf, sizeof(buf), "%s [+folder] [msgs] [switches]", invo_name);
58 print_help(buf, switches, 1);
59 exit(argc == 2 ? EX_OK : EX_USAGE);
61 print_version(invo_name);
62 exit(argc == 2 ? EX_OK : EX_USAGE);
72 if (*cp == '+' || *cp == '@') {
74 adios(EX_USAGE, NULL, "only one folder at a time!");
76 folder = getcpy(expandfol(cp));
79 app_msgarg(&msgs, cp);
84 app_msgarg(&msgs, seq_cur);
89 maildir = toabsdir(folder);
91 if (chdir(maildir) == NOTOK) {
92 adios(EX_OSERR, maildir, "unable to change directory to");
95 /* read folder and create message structure */
96 if (!(mp = folder_read(folder))) {
97 adios(EX_IOERR, NULL, "unable to read folder %s", folder);
99 if (mp->nummsg == 0) {
100 adios(EX_DATAERR, NULL, "no messages in %s", folder);
103 ** parse all the message ranges/sequences and set SELECTED
104 ** (We do this for the refiling case as well, to complain
105 ** about invalid msg arguments in rmm, before we call refile.)
107 for (msgnum = 0; msgnum < msgs.size; msgnum++) {
108 if (!m_convert(mp, msgs.msgs[msgnum])) {
113 context_replace(curfolder, folder);
117 /* "remove" the SELECTED messages */
118 folder_delmsgs(mp, 1);
125 /* remove by refiling. */
130 if (msgs.size+6 > MAXARGS) {
131 adios(EX_SOFTWARE, NULL, "more than %d messages for refile exec",
134 vec = (char **)mh_xmalloc((size_t)(msgs.size + 6) * sizeof(*vec));
135 vec[vecp++] = "refile";
136 vec[vecp++] = "-src";
137 vec[vecp++] = concat("+", folder, NULL);
138 vec[vecp++] = "-nolink";
139 vec[vecp++] = concat("+", trashfolder, NULL);
140 for (msgnum = 0; msgnum < msgs.size; msgnum++) {
141 vec[vecp++] = msgs.msgs[msgnum];
145 return execprog(*vec, vec);