X-Git-Url: https://diplodocus.org/git/nmh/blobdiff_plain/1c91be5784ddebaa6a54f1f2c42a8016f10af6de..d6b2ae5fa68b9a82ffc006c233aef64c5cdb3bd2:/uip/new.c diff --git a/uip/new.c b/uip/new.c index 8d235b17..2bb8c17a 100644 --- a/uip/new.c +++ b/uip/new.c @@ -114,11 +114,11 @@ get_msgnums(char *folder, char *sequences[]) return NULL; if ((fp = lkfopendata (seqfile, "r", & failed_to_lock)) == NULL) { - free(seqfile); if (failed_to_lock) { adios (seqfile, "failed to lock"); } else { + free(seqfile); return NULL; } } @@ -261,7 +261,9 @@ check_folders(struct node **first, struct node **last, b.sequences = sequences; if (folders == NULL) { - chdir(m_maildir("")); + if (chdir(m_maildir("")) < 0) { + advise (m_maildir(""), "chdir"); + } crawl_folders(".", crawl_callback, &b); } else { fp = fopen(folders, "r"); @@ -386,7 +388,9 @@ doit(char *cur, char *folders, char *sequences[]) /* TODO: Split enough of scan.c out so that we can call it here. */ command = concat("scan +", node->n_name, " ", sequences_s, (void *)NULL); - system(command); + if (system(command) == NOTOK) { + adios (command, "system"); + } free(command); } else { if (node->n_field == NULL) { @@ -406,8 +410,11 @@ doit(char *cur, char *folders, char *sequences[]) /* If we're fnext, we haven't checked the last node yet. If it's the * current folder, return the first node. */ - if (run_mode == FNEXT && strcmp(last->n_name, cur) == 0) { - return first; + if (run_mode == FNEXT) { + assert(last != NULL); + if (strcmp(last->n_name, cur) == 0) { + return first; + } } if (run_mode == NEW) {