accumulate status over multiple mailboxes, i.e., don't abort after first
failure
This commit is contained in:
parent
feee93c26d
commit
38d46cc03e
31
src/main.c
31
src/main.c
|
@ -104,7 +104,8 @@ usage (int code)
|
||||||
{
|
{
|
||||||
fputs (
|
fputs (
|
||||||
PACKAGE " " VERSION " IMAP4 to maildir synchronizer\n"
|
PACKAGE " " VERSION " IMAP4 to maildir synchronizer\n"
|
||||||
"Copyright (C) 2000-2 Michael R. Elkins <me@mutt.org>\n"
|
"Copyright (C) 2000-2002 Michael R. Elkins <me@mutt.org>\n"
|
||||||
|
"Copyright (C) 2002-2003 Oswald Buddenhagen <ossi@users.sf.net>\n"
|
||||||
"usage:\n"
|
"usage:\n"
|
||||||
" " PACKAGE " [ flags ] mailbox [mailbox ...]\n"
|
" " PACKAGE " [ flags ] mailbox [mailbox ...]\n"
|
||||||
" " PACKAGE " [ flags ] -a\n"
|
" " PACKAGE " [ flags ] -a\n"
|
||||||
|
@ -115,7 +116,7 @@ PACKAGE " " VERSION " IMAP4 to maildir synchronizer\n"
|
||||||
" -R, --create-remote create remote imap mailbox if nonexistent\n"
|
" -R, --create-remote create remote imap mailbox if nonexistent\n"
|
||||||
" -C, --create create both local and remote mailboxes if nonexistent\n"
|
" -C, --create create both local and remote mailboxes if nonexistent\n"
|
||||||
" -d, --delete delete local msgs that don't exist on the server\n"
|
" -d, --delete delete local msgs that don't exist on the server\n"
|
||||||
" -e, --expunge expunge deleted messages from the server\n"
|
" -e, --expunge expunge deleted messages\n"
|
||||||
" -f, --fast only fetch new messages\n"
|
" -f, --fast only fetch new messages\n"
|
||||||
" -r, --remote BOX remote mailbox\n"
|
" -r, --remote BOX remote mailbox\n"
|
||||||
" -F, --folder DIR remote IMAP folder containing mailboxes\n"
|
" -F, --folder DIR remote IMAP folder containing mailboxes\n"
|
||||||
|
@ -182,6 +183,7 @@ int
|
||||||
main (int argc, char **argv)
|
main (int argc, char **argv)
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
|
int ret = 1;
|
||||||
config_t *box = 0;
|
config_t *box = 0;
|
||||||
mailbox_t *mail = 0;
|
mailbox_t *mail = 0;
|
||||||
imap_t *imap = 0;
|
imap_t *imap = 0;
|
||||||
|
@ -354,8 +356,9 @@ main (int argc, char **argv)
|
||||||
{
|
{
|
||||||
for (box = boxes; box; box = box->next)
|
for (box = boxes; box; box = box->next)
|
||||||
puts (box->path);
|
puts (box->path);
|
||||||
exit (0);
|
return 0;
|
||||||
}
|
}
|
||||||
|
ret = 0;
|
||||||
for (box = boxes; (all && box) || (!all && argv[optind]); optind++)
|
for (box = boxes; (all && box) || (!all && argv[optind]); optind++)
|
||||||
{
|
{
|
||||||
if (!all)
|
if (!all)
|
||||||
|
@ -388,6 +391,7 @@ main (int argc, char **argv)
|
||||||
if (!mail)
|
if (!mail)
|
||||||
{
|
{
|
||||||
fprintf (stderr, "%s: unable to open mailbox\n", box->path);
|
fprintf (stderr, "%s: unable to open mailbox\n", box->path);
|
||||||
|
ret = 1;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -396,6 +400,7 @@ main (int argc, char **argv)
|
||||||
{
|
{
|
||||||
fprintf (stderr, "%s: skipping mailbox due to IMAP error\n",
|
fprintf (stderr, "%s: skipping mailbox due to IMAP error\n",
|
||||||
box->path);
|
box->path);
|
||||||
|
ret = 1;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -408,6 +413,7 @@ main (int argc, char **argv)
|
||||||
* what the problem was.
|
* what the problem was.
|
||||||
*/
|
*/
|
||||||
imap = NULL; /* context no longer valid */
|
imap = NULL; /* context no longer valid */
|
||||||
|
ret = 1;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -422,19 +428,26 @@ main (int argc, char **argv)
|
||||||
{
|
{
|
||||||
imap_close (imap);
|
imap_close (imap);
|
||||||
imap = NULL;
|
imap = NULL;
|
||||||
|
ret = 1;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
info ("Expunging %d messages from local mailbox\n",
|
info ("Expunging %d messages from local mailbox\n",
|
||||||
mail->deleted);
|
mail->deleted);
|
||||||
if (maildir_expunge (mail, 0))
|
if (maildir_expunge (mail, 0)) {
|
||||||
|
ret = 1;
|
||||||
break;
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
/* remove messages deleted from server. this can safely be an
|
/* remove messages deleted from server. this can safely be an
|
||||||
* `else' clause since dead messages are marked as deleted by
|
* `else' clause since dead messages are marked as deleted by
|
||||||
* sync_mailbox.
|
* sync_mailbox.
|
||||||
*/
|
*/
|
||||||
else if (delete)
|
else if (delete) {
|
||||||
maildir_expunge (mail, 1);
|
if (maildir_expunge (mail, 1)) {
|
||||||
|
ret = 1;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
} while (0);
|
} while (0);
|
||||||
|
@ -456,9 +469,5 @@ main (int argc, char **argv)
|
||||||
bork:
|
bork:
|
||||||
free_config ();
|
free_config ();
|
||||||
|
|
||||||
#if DEBUG
|
return ret;
|
||||||
debug_cleanup ();
|
|
||||||
#endif
|
|
||||||
|
|
||||||
exit (0);
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue
Block a user