X-Git-Url: http://git.marmaro.de/?p=mmh;a=blobdiff_plain;f=uip%2Frmf.c;h=38a93ff86bd9adca00899107acf22bdf6c55d773;hp=050817bf0ae64781fb0bbcc2a75be11adfef77db;hb=714b5c530ece27ea2835a313013f5b770163403c;hpb=ced6090a330d3d83d0bce709f756aa3d7d65fea4 diff --git a/uip/rmf.c b/uip/rmf.c index 050817b..38a93ff 100644 --- a/uip/rmf.c +++ b/uip/rmf.c @@ -24,11 +24,11 @@ static struct swit switches[] = { ** static prototypes */ static int rmf(char *); -static void rma (char *); +static void rma(char *); int -main (int argc, char **argv) +main(int argc, char **argv) { int defolder = 0, interactive = -1; char *cp, *folder = NULL, newfolder[BUFSIZ]; @@ -37,30 +37,30 @@ main (int argc, char **argv) #ifdef LOCALE setlocale(LC_ALL, ""); #endif - invo_name = r1bindex (argv[0], '/'); + invo_name = r1bindex(argv[0], '/'); /* read user profile/context */ context_read(); - arguments = getarguments (invo_name, argc, argv, 1); + arguments = getarguments(invo_name, argc, argv, 1); argp = arguments; while ((cp = *argp++)) { if (*cp == '-') { - switch (smatch (++cp, switches)) { + switch (smatch(++cp, switches)) { case AMBIGSW: - ambigsw (cp, switches); - done (1); + ambigsw(cp, switches); + done(1); case UNKWNSW: - adios (NULL, "-%s unknown", cp); + adios(NULL, "-%s unknown", cp); case HELPSW: - snprintf (buf, sizeof(buf), "%s [+folder] [switches]", invo_name); - print_help (buf, switches, 1); - done (1); + snprintf(buf, sizeof(buf), "%s [+folder] [switches]", invo_name); + print_help(buf, switches, 1); + done(1); case VERSIONSW: print_version(invo_name); - done (1); + done(1); case INTRSW: interactive = 1; @@ -72,61 +72,61 @@ main (int argc, char **argv) } if (*cp == '+' || *cp == '@') { if (folder) - adios (NULL, "only one folder at a time!"); + adios(NULL, "only one folder at a time!"); else - folder = pluspath (cp); + folder = pluspath(cp); } else { - adios (NULL, "usage: %s [+folder] [switches]", + adios(NULL, "usage: %s [+folder] [switches]", invo_name); } } - if (!context_find ("path")) - free (path ("./", TFOLDER)); + if (!context_find("path")) + free(path("./", TFOLDER)); if (!folder) { - folder = getfolder (1); + folder = getfolder(1); defolder++; } - if (strcmp (m_mailpath (folder), pwd ()) == 0) - adios (NULL, "sorry, you can't remove the current working directory"); + if (strcmp(m_mailpath(folder), pwd()) == 0) + adios(NULL, "sorry, you can't remove the current working directory"); if (interactive == -1) interactive = defolder; - if (strchr (folder, '/') && (*folder != '/') && (*folder != '.')) { - for (cp = copy (folder, newfolder); + if (strchr(folder, '/') && (*folder != '/') && (*folder != '.')) { + for (cp = copy(folder, newfolder); cp > newfolder && *cp != '/'; cp--) continue; if (cp > newfolder) *cp = '\0'; else - strncpy (newfolder, getfolder(0), sizeof(newfolder)); + strncpy(newfolder, getfolder(0), sizeof(newfolder)); } else { - strncpy (newfolder, getfolder(0), sizeof(newfolder)); + strncpy(newfolder, getfolder(0), sizeof(newfolder)); } if (interactive) { - cp = concat ("Remove folder \"", folder, "\"? ", NULL); - if (!getanswer (cp)) - done (0); - free (cp); + cp = concat("Remove folder \"", folder, "\"? ", NULL); + if (!getanswer(cp)) + done(0); + free(cp); } - if (rmf (folder) == OK) { + if (rmf(folder) == OK) { char *cfolder = context_find(pfolder); - if (cfolder && strcmp (cfolder, newfolder)) { - printf ("[+%s now current]\n", newfolder); + if (cfolder && strcmp(cfolder, newfolder)) { + printf("[+%s now current]\n", newfolder); /* update current folder */ - context_replace (pfolder, newfolder); + context_replace(pfolder, newfolder); } } - context_save (); /* save the context file */ - done (0); + context_save(); /* save the context file */ + done(0); return 1; } static int -rmf (char *folder) +rmf(char *folder) { int i, j, others; register char *maildir; @@ -134,25 +134,25 @@ rmf (char *folder) register struct dirent *dp; register DIR *dd; - switch (i = chdir (maildir = m_maildir (folder))) { + switch (i = chdir(maildir = m_maildir(folder))) { case OK: - if (access (".", W_OK) != NOTOK && - access ("..", W_OK) != NOTOK) + if (access(".", W_OK) != NOTOK && + access("..", W_OK) != NOTOK) break; /* fall otherwise */ case NOTOK: - snprintf (cur, sizeof(cur), "atr-%s-%s", - current, m_mailpath (folder)); - if (!context_del (cur)) { - printf ("[+%s de-referenced]\n", folder); + snprintf(cur, sizeof(cur), "atr-%s-%s", + current, m_mailpath(folder)); + if (!context_del(cur)) { + printf("[+%s de-referenced]\n", folder); return OK; } - advise (NULL, "you have no profile entry for the %s folder +%s", i == NOTOK ? "unreadable" : "read-only", folder); + advise(NULL, "you have no profile entry for the %s folder +%s", i == NOTOK ? "unreadable" : "read-only", folder); return NOTOK; } - if ((dd = opendir (".")) == NULL) - adios (NULL, "unable to read folder +%s", folder); + if ((dd = opendir(".")) == NULL) + adios(NULL, "unable to read folder +%s", folder); others = 0; /* @@ -162,12 +162,11 @@ rmf (char *folder) (void)ext_hook("del-hook", maildir, (char *)0); j = strlen(backup_prefix); - while ((dp = readdir (dd))) { + while ((dp = readdir(dd))) { switch (dp->d_name[0]) { case '.': - if (strcmp (dp->d_name, ".") == 0 - || strcmp (dp->d_name, "..") - == 0) + if (strcmp(dp->d_name, ".") == 0 || + strcmp(dp->d_name, "..") == 0) continue; /* else fall */ case ',': @@ -181,43 +180,43 @@ rmf (char *folder) break; default: - if (m_atoi (dp->d_name)) + if (m_atoi(dp->d_name)) break; - if (strcmp (dp->d_name, altmsglink) == 0 - || strncmp (dp->d_name, + if (strcmp(dp->d_name, altmsglink) == 0 || + strncmp(dp->d_name, backup_prefix, j) == 0) break; - admonish (NULL, "file \"%s/%s\" not deleted", + admonish(NULL, "file \"%s/%s\" not deleted", folder, dp->d_name); others++; continue; } - if (unlink (dp->d_name) == NOTOK) { - admonish (dp->d_name, "unable to unlink %s:", folder); + if (unlink(dp->d_name) == NOTOK) { + admonish(dp->d_name, "unable to unlink %s:", folder); others++; } } - closedir (dd); + closedir(dd); /* ** Remove any relevant private sequences ** or attributes from context file. */ - rma (folder); + rma(folder); - chdir (".."); + chdir(".."); if (others == 0) { context_save(); /* Is this needed? meillo 2011-10 */ fflush(stdout); /* Is this needed? meillo 2011-10 */ if (rmdir(maildir) != -1) { return OK; } - admonish (maildir, "unable to remove directory"); + admonish(maildir, "unable to remove directory"); } - advise (NULL, "folder +%s not removed", folder); + advise(NULL, "folder +%s not removed", folder); return NOTOK; } @@ -228,26 +227,26 @@ rmf (char *folder) */ static void -rma (char *folder) +rma(char *folder) { register int alen, j, plen; register char *cp; register struct node *np, *pp; - alen = strlen ("atr-"); - plen = strlen (cp = m_mailpath (folder)) + 1; + alen = strlen("atr-"); + plen = strlen(cp = m_mailpath(folder)) + 1; /* ** Search context list for keys that look like ** "atr-something-folderpath", and remove them. */ for (np = m_defs, pp = NULL; np; np = np->n_next) { - if (ssequal ("atr-", np->n_name) - && (j = strlen (np->n_name) - plen) > alen - && *(np->n_name + j) == '-' - && strcmp (cp, np->n_name + j + 1) == 0) { + if (ssequal("atr-", np->n_name) && + (j = strlen(np->n_name) - plen) > alen && + *(np->n_name + j) == '-' && + strcmp(cp, np->n_name + j + 1) == 0) { if (!np->n_context) - admonish (NULL, "bug: context_del(key=\"%s\")", + admonish(NULL, "bug: context_del(key=\"%s\")", np->n_name); if (pp) { pp->n_next = np->n_next;