isync should continue to process additional mailboxes even if there is an
error with a previous mailbox. added -a (--all) flag to synchronize all mailboxes defined in ~/.isyncrc
This commit is contained in:
parent
af941779f4
commit
9a5b57eb7d
6
config.c
6
config.c
@ -27,7 +27,7 @@
|
||||
#include <stdlib.h>
|
||||
#include "isync.h"
|
||||
|
||||
static config_t *box = 0;
|
||||
config_t *boxes = 0;
|
||||
|
||||
/* set defaults from the global configuration section */
|
||||
void
|
||||
@ -95,7 +95,7 @@ load_config (const char *where)
|
||||
char path[_POSIX_PATH_MAX];
|
||||
char buf[1024];
|
||||
struct passwd *pw;
|
||||
config_t **cur = &box;
|
||||
config_t **cur = &boxes;
|
||||
int line = 0;
|
||||
FILE *fp;
|
||||
char *p, *cmd, *val;
|
||||
@ -280,7 +280,7 @@ load_config (const char *where)
|
||||
config_t *
|
||||
find_box (const char *s)
|
||||
{
|
||||
config_t *p = box;
|
||||
config_t *p = boxes;
|
||||
|
||||
for (; p; p = p->next)
|
||||
if (!strcmp (s, p->path) || (p->alias && !strcmp (s, p->alias)))
|
||||
|
17
imap.c
17
imap.c
@ -797,13 +797,16 @@ imap_open (config_t * box, unsigned int minuid, imap_t * imap)
|
||||
void
|
||||
imap_close (imap_t * imap)
|
||||
{
|
||||
imap_exec (imap, "LOGOUT");
|
||||
close (imap->sock->fd);
|
||||
free (imap->sock);
|
||||
free (imap->buf);
|
||||
free_message (imap->msgs);
|
||||
memset (imap, 0xff, sizeof (imap_t));
|
||||
free (imap);
|
||||
if (imap)
|
||||
{
|
||||
imap_exec (imap, "LOGOUT");
|
||||
close (imap->sock->fd);
|
||||
free (imap->sock);
|
||||
free (imap->buf);
|
||||
free_message (imap->msgs);
|
||||
memset (imap, 0xff, sizeof (imap_t));
|
||||
free (imap);
|
||||
}
|
||||
}
|
||||
|
||||
/* write a buffer stripping all \r bytes */
|
||||
|
1
isync.h
1
isync.h
@ -150,6 +150,7 @@ imap_t;
|
||||
#define SYNC_EXPUNGE (1<<1) /* don't fetch deleted messages */
|
||||
|
||||
extern config_t global;
|
||||
extern config_t *boxes;
|
||||
extern unsigned int Tag;
|
||||
extern char Hostname[256];
|
||||
extern int Verbose;
|
||||
|
142
main.c
142
main.c
@ -33,6 +33,7 @@
|
||||
#include <getopt.h>
|
||||
|
||||
struct option Opts[] = {
|
||||
{"all", 0, NULL, 'a'},
|
||||
{"config", 1, NULL, 'c'},
|
||||
{"delete", 0, NULL, 'd'},
|
||||
{"expunge", 0, NULL, 'e'},
|
||||
@ -67,12 +68,10 @@ usage (void)
|
||||
printf ("%s %s IMAP4 to maildir synchronizer\n", PACKAGE, VERSION);
|
||||
puts ("Copyright (C) 2000 Michael R. Elkins <me@mutt.org>");
|
||||
printf ("usage: %s [ flags ] mailbox [mailbox ...]\n", PACKAGE);
|
||||
puts
|
||||
(" -c, --config CONFIG read an alternate config file (default: ~/.isyncrc)");
|
||||
puts
|
||||
(" -d, --delete delete local msgs that don't exist on the server");
|
||||
puts
|
||||
(" -e, --expunge expunge deleted messages from the server");
|
||||
puts (" -a, --all Synchronize all defined mailboxes");
|
||||
puts (" -c, --config CONFIG read an alternate config file (default: ~/.isyncrc)");
|
||||
puts (" -d, --delete delete local msgs that don't exist on the server");
|
||||
puts (" -e, --expunge expunge deleted messages from the server");
|
||||
puts (" -f, --fast only fetch new messages");
|
||||
puts (" -h, --help display this help message");
|
||||
puts (" -p, --port PORT server IMAP port");
|
||||
@ -80,8 +79,7 @@ usage (void)
|
||||
puts (" -s, --host HOST IMAP server address");
|
||||
puts (" -u, --user USER IMAP user name");
|
||||
puts (" -v, --version display version");
|
||||
puts
|
||||
(" -V, --verbose verbose mode (display network traffic)");
|
||||
puts (" -V, --verbose verbose mode (display network traffic)");
|
||||
exit (0);
|
||||
}
|
||||
|
||||
@ -127,7 +125,7 @@ int
|
||||
main (int argc, char **argv)
|
||||
{
|
||||
int i;
|
||||
config_t *box;
|
||||
config_t *box = 0;
|
||||
mailbox_t *mail;
|
||||
imap_t *imap = 0;
|
||||
int expunge = 0; /* by default, don't delete anything */
|
||||
@ -136,6 +134,7 @@ main (int argc, char **argv)
|
||||
char *config = 0;
|
||||
struct passwd *pw;
|
||||
int quiet = 0;
|
||||
int all = 0;
|
||||
|
||||
pw = getpwuid (getuid ());
|
||||
|
||||
@ -157,56 +156,61 @@ main (int argc, char **argv)
|
||||
global.use_tlsv1 = 1;
|
||||
#endif
|
||||
|
||||
#define FLAGS "ac:defhp:qu:r:s:vV"
|
||||
|
||||
#if HAVE_GETOPT_LONG
|
||||
while ((i = getopt_long (argc, argv, "c:defhp:qu:r:s:vV", Opts, NULL)) != -1)
|
||||
while ((i = getopt_long (argc, argv, FLAGS, Opts, NULL)) != -1)
|
||||
#else
|
||||
while ((i = getopt (argc, argv, "c:defhp:u:qr:s:vV")) != -1)
|
||||
while ((i = getopt (argc, argv, FLAGS)) != -1)
|
||||
#endif
|
||||
{
|
||||
switch (i)
|
||||
{
|
||||
case 'c':
|
||||
config = optarg;
|
||||
break;
|
||||
case 'd':
|
||||
delete = 1;
|
||||
break;
|
||||
case 'e':
|
||||
expunge = 1;
|
||||
break;
|
||||
case 'f':
|
||||
fast = 1;
|
||||
break;
|
||||
case 'p':
|
||||
global.port = atoi (optarg);
|
||||
break;
|
||||
case 'q':
|
||||
quiet = 1;
|
||||
Verbose = 0;
|
||||
break;
|
||||
case 'r':
|
||||
global.box = optarg;
|
||||
break;
|
||||
case 's':
|
||||
global.host = optarg;
|
||||
break;
|
||||
case 'u':
|
||||
free (global.user);
|
||||
global.user = optarg;
|
||||
break;
|
||||
case 'V':
|
||||
Verbose = 1;
|
||||
break;
|
||||
case 'v':
|
||||
version ();
|
||||
default:
|
||||
usage ();
|
||||
case 'a':
|
||||
all = 1;
|
||||
break;
|
||||
case 'c':
|
||||
config = optarg;
|
||||
break;
|
||||
case 'd':
|
||||
delete = 1;
|
||||
break;
|
||||
case 'e':
|
||||
expunge = 1;
|
||||
break;
|
||||
case 'f':
|
||||
fast = 1;
|
||||
break;
|
||||
case 'p':
|
||||
global.port = atoi (optarg);
|
||||
break;
|
||||
case 'q':
|
||||
quiet = 1;
|
||||
Verbose = 0;
|
||||
break;
|
||||
case 'r':
|
||||
global.box = optarg;
|
||||
break;
|
||||
case 's':
|
||||
global.host = optarg;
|
||||
break;
|
||||
case 'u':
|
||||
free (global.user);
|
||||
global.user = optarg;
|
||||
break;
|
||||
case 'V':
|
||||
Verbose = 1;
|
||||
break;
|
||||
case 'v':
|
||||
version ();
|
||||
default:
|
||||
usage ();
|
||||
}
|
||||
}
|
||||
|
||||
if (!argv[optind])
|
||||
if (!argv[optind] && !all)
|
||||
{
|
||||
puts ("No box specified");
|
||||
puts ("No mailbox specified");
|
||||
usage ();
|
||||
}
|
||||
|
||||
@ -214,21 +218,24 @@ main (int argc, char **argv)
|
||||
|
||||
load_config (config);
|
||||
|
||||
for (; argv[optind]; optind++)
|
||||
for (box = boxes; (all && box) || (!all && argv[optind]);
|
||||
box = box->next, optind++)
|
||||
{
|
||||
box = find_box (argv[optind]);
|
||||
if (!box)
|
||||
if (!all)
|
||||
{
|
||||
/* if enough info is given on the command line, don't worry if
|
||||
* the mailbox isn't defined.
|
||||
*/
|
||||
if (!global.host)
|
||||
if (NULL == (box = find_box (argv[optind])))
|
||||
{
|
||||
puts ("No such mailbox");
|
||||
exit (1);
|
||||
/* if enough info is given on the command line, don't worry if
|
||||
* the mailbox isn't defined.
|
||||
*/
|
||||
if (!global.host)
|
||||
{
|
||||
fprintf (stderr, "%s: no such mailbox\n", argv[optind]);
|
||||
continue;
|
||||
}
|
||||
global.path = argv[optind];
|
||||
box = &global;
|
||||
}
|
||||
global.path = argv[optind];
|
||||
box = &global;
|
||||
}
|
||||
|
||||
if (!box->pass)
|
||||
@ -248,18 +255,22 @@ main (int argc, char **argv)
|
||||
box->pass = strdup (global.pass);
|
||||
}
|
||||
|
||||
if(!quiet)
|
||||
if (!quiet)
|
||||
printf ("Reading %s\n", box->path);
|
||||
mail = maildir_open (box->path, fast);
|
||||
if (!mail)
|
||||
{
|
||||
puts ("Unable to load mailbox");
|
||||
exit (1);
|
||||
fprintf (stderr, "%s: unable to load mailbox\n", box->path);
|
||||
continue;
|
||||
}
|
||||
|
||||
imap = imap_open (box, fast ? mail->maxuid + 1 : 1, imap);
|
||||
if (!imap)
|
||||
exit (1);
|
||||
{
|
||||
fprintf (stderr, "%s: skipping mailbox due to IMAP error\n",
|
||||
box->path);
|
||||
continue;
|
||||
}
|
||||
|
||||
if (!quiet)
|
||||
puts ("Synchronizing");
|
||||
@ -274,7 +285,8 @@ main (int argc, char **argv)
|
||||
{
|
||||
/* remove messages marked for deletion */
|
||||
if (!quiet)
|
||||
printf ("Expunging %d messages from server\n", imap->deleted);
|
||||
printf ("Expunging %d messages from server\n",
|
||||
imap->deleted);
|
||||
if (imap_expunge (imap))
|
||||
exit (1);
|
||||
if (!quiet)
|
||||
|
Loading…
x
Reference in New Issue
Block a user